神经网络自适应PID控制及其应用

这篇具有很好参考价值的文章主要介绍了神经网络自适应PID控制及其应用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

神经网络自适应PID控制及其应用

总结来自重庆大学宋永瑞教授2022暑期校园行学术会议

1. 研究背景

  目前人工智能的发展为很多领域里的研究提供了可延展性,提供了新的研究问题的思路,无人系统和人工智能正走向深度融合,无人系统里具有核心驱动作用的智能控制算法的研究成为了热点问题。
人工智能的理论深度依赖人工神经网络,而人工神经网络又是人工智能的核心支撑,先进的控制系统实现了可靠的无人系统的底层支撑,当人工智能与无人系统深度融合时,可以使得实现一个可信、可靠、通用、普适的神经网络驱动的控制系统变得具有很强的可行性,所以,智能无人系统的一个热点就是聚焦于神经网络驱动的控制系统功效性及可靠性的研究。

2. PID

2.1 PID控制器系统简介

  PID算法是控制工程中的一种经典控制理论,其在控制系统中作用效果明显,适用范围广,在目前的实际工程应用中仍然是一种影响力最大适用最多的控制系统。
神经pid控制,科研,神经网络,人工智能
  PID控制器中的P指的是Proportional,即比例,反映参数为比例因子,是对输入到目标趋近速度影响最大的因子,其线性控制系统的驱动;I指的是Integral,即积分,反映参数为积分因子,是对于误差的累计,从而根据之前的误差来修正本次误差的修正;D指的是Derivative,即微分,反映参数为微分系数,是对于抑制误差的修正,防止过度修正和稳态误差的形成。

2.2 PID对于人类智慧的类比

  PID控制器的系统中其实蕴含了“人类智能”,实际表现为人类社会的行事纠正约束准则在系统调节中的适用, P t e r m = K p e ( t ) P_{term}=K_pe(t) Pterm=Kpe(t)为比例部分的调节描述, K p K_p Kp为比例系数,确定参数后,系统将会根据输入与目标差值相关的误差,进行按照比例系数线性调节系统,使得系统能够快速的接近目标值,这部分的调节类似于人类的奖惩机制,当误差大时,比例参数的作用就会大,系统变动大,当误差小时,比例参数的作用相对会小,对系统的调整输入量就会变小一些,当误差为正值的时候,其修正量为正继续修正,当误差为负值时,系统的修正量就要为负值,适当拉回过度修正的表现值,当系统误差为0时则比例部分不会做修正;当 I t e r m = K i ∫ 0 t e ( t ) d t I_{term}=K_i\int_0^te(t)dt Iterm=Ki0te(t)dt为积分部分的调节描述, K i K_i Ki为积分系数,此部分将每次的误差进行累计,在积分部分,此前系统的每一次误差都对系统有贡献,积分项蕴含了人类的记忆、经验、总结的机制,对之前所修正的每一次输入的误差都进行了考量,从而防止了稳态误差的出现,累加误差的过程就是吸取经验和教训的过程; D t e r m =   K d d e ( t ) d t D_{term}=\ K_d\frac{d_{e(t)}}{d_t} Dterm= Kddtde(t)为微分项部分的调节描述, K d K_d Kd为微分系数,此部分将对误差进行微分,以此来根据误差的变化趋势进行适当的修正,微分部分的蕴含了未来信息、预测机制,一定程度上可以防止过度修正情况的发生。
综上所述,一个PID控制器就是一个人类奖惩+记忆(经验)+预测(预判)运用在控制系统中的典范。

2.3 PID的当前存在的局限

  1. PID参数总是常量,从一开始设置之后就不会变动,在整个系统的运行过程中都会保持不变,这在应付复杂多变的工业系统环境时略显局限。
  2. PID的参数的设置往往是在大量的实验过程中确定的,效果表现良好达到要求时才会确定,这个确定参数的过程是很痛苦且耗费时间的。
  3. PID在非线性系统中的应用效果不明显,具有模糊性。
  4. 对于闭环系统缺乏理论上的保证。
    这几点体现在了灵活性、鲁棒性、适应性和其他的表现上。

3. 基于神经网络的自适应PID的设计

3.1 可信、可靠、可解释的PID

  一个PID的作用描述架构图如下所示。系统通过外部的感知得到输入数据,通过确定系数 γ 1 \gamma_1 γ1 γ 2 \gamma_2 γ2 γ 3 \gamma_3 γ3来得到奖惩、预测、经验的分量,加权求和后形成输出 u u u,而误差 e e e的运作机制往往不是单纯的计算输入与目标的差值,而是使用一种加权的形式进行重映射,这样做也更合理一些,将误差 e e e映射输出为z之后,利用确定好的比例系数、积分系数、微分系数,来对系统进行调节。
神经pid控制,科研,神经网络,人工智能

3.2 稳定性分析

  在控制原理中对于系统出错的处理有个经典的理论, u a ( t ) = ρ ( t ) u + ε ( t ) u_a\left(t\right)=\rho\left(t\right)u+\varepsilon(t) ua(t)=ρ(t)u+ε(t),其中 u = [ u 1 , … , u l ] ∈ R l u=[u_1,\ldots,u_l]∈Rl u=[u1,,ul]Rl为设计的输入, ε = [ ε 1 , … , ε l ] ∈ R l \varepsilon=[\varepsilon_1,\ldots,\varepsilon_l]∈Rl ε=[ε1,,εl]Rl为不可控部分, ρ = d i a g { ρ j } ϵ R l × l , j = 1 , … , l \rho=diag\left\{\rho_j\right\}\epsilon R^{l\times l},j=1,\ldots,l ρ=diag{ρj}ϵRl×l,j=1,,l,为健康指示,当 ρ i ( t ) \rho_i(t) ρi(t)为1且 ε ( t ) \varepsilon(t) ε(t)为0时,系统处于正常的执行器;当 ρ i ( t ) \rho_i(t) ρi(t)小于1且 ε ( t ) \varepsilon(t) ε(t)为0时,系统会损失一些有效性;当 ρ i ( t ) \rho_i(t) ρi(t)小于1且 ε ( t ) \varepsilon(t) ε(t)为常量时,系统能够在突发情况发生时进行适当的修正;当 ρ i ( t ) \rho_i(t) ρi(t)小于1且 ε ( t ) \varepsilon(t) ε(t)为随时间变化的量时,系统在突发故障发生时将会失去有效性。
神经pid控制,科研,神经网络,人工智能
  一般 ρ \rho ρ不为1的情况反应如下
神经pid控制,科研,神经网络,人工智能
  一般 ε \varepsilon ε不为0的信号反应如下
神经pid控制,科研,神经网络,人工智能

3.3 误差滤波处理

  系统的实际误差定义为 e i = x l ( i − 1 ) − y ∗ ( i − 1 ) , i = 1 , … , n e_i={x_l}^{(i-1)}-y^{\ast\left(i-1\right)},i=1,\ldots,n ei=xl(i1)y(i1),i=1,,n,对误差进行加权求和,即引入滤波误差 z ( t ) z(t) z(t) z ( t ) = λ n − 2 e 1 + … + λ 1 e n − 2 + e n − 1 ⇐ ( x , … , x ( n − 2 ) ) , z ˙ ( t ) = λ n − 2 e 2 + … + λ 1 e n − 1 + e n ⇐ ( x , x ˙ , … , x ( n − 1 ) ) z\left(t\right)=\lambda_{n-2}e_1+\ldots+\lambda_1e_{n-2}+e_{n-1}\Leftarrow(x,\ldots,x^{(n-2)}),\dot{z}\left(t\right)=\lambda_{n-2}e_2+\ldots+\lambda_1e_{n-1}+e_n\Leftarrow(x,\dot{x},\ldots,x^{(n-1)}) z(t)=λn2e1++λ1en2+en1(x,,x(n2))z˙(t)=λn2e2++λ1en1+en(x,x˙,,x(n1)),两者为导数关系,经过1991年Slotine和Li的论文验证,当 z ( t ) , z ( t ) ∈ l ∞ z\left(t\right),z(t)∈l∞ z(t)z(t)l时, e 1 , … . , e n ∈ ℓ ∞ e_1,\ldots.,e_n\in\ell_\infty e1,.,en,也即滤波后的 z ( t ) z(t) z(t)最小时 e ( t ) e(t) e(t)也最小,所以误差的问题研究滤波后的误差更具有代表性和可行性。
由于我们的目标是设计一个自适应的容错的PID控制器来获得 z ( t ) z(t) z(t) z ˙ ( t ) \dot{z}(t) z˙(t),使其确保所有的闭环系统的信号达到边界,生成最小的残差集。将系统中所有的不可控因素都添加进来,得到了 z ¨ ( t ) \ddot{z}(t) z¨(t),如下所示
神经pid控制,科研,神经网络,人工智能
  其第一部分为不确定项,第二部分为未知的生成输入,第三部分为已知项,通过标准化误差z函数,获得以下公式如下
神经pid控制,科研,神经网络,人工智能
  所讨论的系统应当分为两类,一类是方系统,一类是非线性的非方系统,方系统指的是输入个数与输出个数相同的系统,反之,非方系统指的就是输入与输出不同的系统,一般方系统的分析较为标准,解决方法灵活,对于控制系数矩阵,其正定性决定了控制系统的走向,正定矩阵代表着系统要朝增强的方向输出信号,负定则代表着系统要朝着反向进行输出信号。
引入一般化的误差 e ( t ) e(t) e(t),即 z ( t ) = λ n − 2 e 1 + … + λ 1 e n − 2 + e n − 1 ⇐ ( x , … , x ( n − 2 ) ) z\left(t\right)=\lambda_{n-2}e_1+\ldots+\lambda_1e_{n-2}+e_{n-1}\Leftarrow(x,\ldots,x^{(n-2)}) z(t)=λn2e1++λ1en2+en1(x,,x(n2)),对其进行再次滤波,可得到

E = 2 γ z + γ 2 ∫ 0 t z ( ∙ ) d τ + d z d t E=2\gamma z+\gamma^2\int_{0}^{t}z\left(\bullet\right)d\tau+\frac{dz}{dt} E=2γz+γ20tz()dτ+dtdz
  那么整个建模的设计思路就是通过 E E E反映了 z z z,而 z z z反映了 e e e,将E最小化是我们的目标。
L L L为所有不确定因素的综合,不确定因素包括系统的抖动、故障、人为因素、环境因素等等,而对于不确定因素的处理是整个系统设计最困难的部分,目前的处理方法有三种:

  1. 参数分解法: L ( x ) = ψ p L\left(x\right)=\psi p L(x)=ψp,其中 p p p为未知参数向量, ψ \psi ψ为已知的矩阵函数(回归算子),这种处理方式的解是理想的解,但是处理过程和执行难度复杂,且通常不可分解。
  2. 提取核函数 ∣ ∣ L ( x ) ∣ ∣ ≤ ψ , p ≥ 0 \left|\left|L\left(x\right)\right|\right|\le\psi,p\geq0 L(x)ψ,p0为未知参数向量, ψ ≥ 0 \psi\geq0 ψ0为已知的光滑函数,此方式基于本质信息且易于实现,缺点是效果不明显容易受扰动。
  3. 采用神经网络(NN)逼近,此种方式为与人工智能神经网络结合解决问题的典型思路,思路来源为万能逼近定理,但是运用此定理解决问题的数据集是有条件的,要求数据必须是同一紧集,处理数据时可以采用引入约束的方式规范数据为同一紧集,第二个就是被逼近的函数本身是要连续光滑的,第三个点就是神经元的数目,神经元的数目决定了网络的复杂性,对于神经元的数据和网络的复杂程度的问题,只能在实验中去迭代发现,具体可以在一开始设置一个合理的数目,然后引入神经元数目的增减机制,这个增减机制在生物学上是有理可据的,其与生物的细胞凋亡与生长是完全吻合的。

3.4 控制器的设计

  经过引入滤波后的误差,可以进行PID控制器的设计,PID的建模设计如下:
u = ( k p + Δ k p ( ∙ ) ) z + ( k l + Δ k l ( ∙ ) ) ∫ 0 t z d τ + ( k D + Δ k D ( ∙ ) ) d z d t u=\left(k_p+\Delta k_p\left(\bullet\right)\right)z+\left(k_l+\Delta k_l\left(\bullet\right)\right)\int_{0}^{t}zd\tau+{(k}_D+\Delta k_D\left(\bullet\right))\frac{dz}{dt} u=(kp+Δkp())z+(kl+Δkl())0tzdτ+(kD+ΔkD())dtdz
  这样设计之后,原本的PID的参数由Kp(比例系数)、Ki(积分系数)、Kd(微分系数)三个变为了 k p k_p kp Δ k p Δkp Δkp∙、 k l kl kl Δ k l Δkl Δkl∙、 k D kD kD Δ k D ΔkD ΔkD∙六个参数,三个常量参数 k p k_p kp k l kl kl k D kD kD以及三个随时间变化的参数 Δ k p ( ∙ ) \Delta k_p\left(\bullet\right) Δkp() Δ k l Δkl Δkl∙、 Δ k D ΔkD ΔkD∙,但是经过实际的推演,其约束如下:
k p = ( α + β ) k D k l = α β k D k D = ? Δ k p ( ∙ ) = ( α + β ) Δ k D ( ∙ ) Δ k l ( ∙ ) = α β Δ k D ( ∙ ) Δ k D ( ∙ ) = a ^ φ 2 ( ∙ ) k_p=\left(\alpha+\beta\right)k_D k_l=\alpha\beta k_D k_D=? \Delta k_p\left(\bullet\right)=(\alpha+\beta)\Delta k_D\left(\bullet\right) \Delta k_l\left(\bullet\right)=\alpha\beta\Delta k_D\left(\bullet\right) \Delta k_D\left(\bullet\right)=\hat{a}\varphi^2(\bullet) kp=(α+β)kDkl=αβkDkD=?Δkp()=(α+β)ΔkD()Δkl()=αβΔkD()ΔkD()=a^φ2()
  上面约束中的 a l p h a > 0 alpha>0 alpha>0 β > 0 β>0 β>0和自适应的参数a的更新准则在后面会给出, φ \varphi φ是与神经网络中的激活函数有关的函数量,且将这几个参数作为已知量看待,通过对于上面的约束的观察,发现其实只要确定了 k D k_D kD,其他参数全部可以通过约束关系确定下来,所以,通过引入误差的滤波函数,控制器的建模参数其实简化了很多,控制系统变得更加的可靠。
对于一般化误差 E = 2 γ z + γ 2 ∫ 0 t z ( ∙ ) d τ + d z d t E=2\gamma z+\gamma^2\int_{0}^{t}z\left(\bullet\right)d\tau+\frac{dz}{dt} E=2γz+γ20tz()dτ+dtdz的可解释性问题,考虑设 y ( t ) = ∫ 0 t z d t y\left(t\right)=\int_{0}^{t}zdt y(t)=0tzdt,那么 E E E可以转换为 E = ( α + β ) y ˙ + α β y + y ¨ E=\left(\alpha+\beta\right)\dot{y}+\alpha\beta y+\ddot{y} E=(α+β)y˙+αβy+y¨,将 E E E通过拉普拉斯变换,转换成 E ( s ) = ( s + α ) ( s + β ) Y ( s ) E\left(s\right)=\left(s+\alpha\right)\left(s+\beta\right)Y\left(s\right) E(s)=(s+α)(s+β)Y(s),便于进行因式分解,将本式进行等价转换,得到 Y ( s ) = 1 ( s + α ) ( s + β ) E ( s ) Y\left(s\right)=\frac{1}{\left(s+\alpha\right)\left(s+\beta\right)}E\left(s\right) Y(s)=(s+α)(s+β)1E(s),这在控制系统中属于非常稳定的滤波器,其有两个极点,位于实轴的两侧,一个 α \alpha α一个 β \beta β,这样得到极值保证了 E E E最小,就可以保证 z z z最小,从而保证了 e e e(误差)最小。

3.5 对于方系统与非方系统的应用

  对于方系统的PID控制数学建模考虑加入可控的参数在神经网络中,根据上面章节的推论,可以得到方系统PID控制的数学模型:
u = ( k p + Δ k p ( ∙ ) ) Λ z + ( k l + Δ k l ) Λ ∫ 0 t z ( ∙ ) d τ + ( k D + Δ k D ) Δ d z d t u=\left(k_p+\Delta k_p\left(\bullet\right)\right)\Lambda z+\left(k_l+\Delta k_l\right)\Lambda\int_{0}^{t}z\left(\bullet\right)d\tau+\left(k_D+\Delta k_D\right)\Delta\frac{dz}{dt} u=(kp+Δkp())Λz+(kl+Δkl)Λ0tz()dτ+(kD+ΔkD)Δdtdz
  可见此处模型只是将上节推论的公式的各项添加了一个参数矩阵 Λ \Lambda Λ,在方系统中, Λ \Lambda Λ是一个单位矩阵,其约束与上节相同:
k p = ( α + β ) k D k l = α β k D k D = ? Δ k p ( ∙ ) = ( α + β ) Δ k D ( ∙ ) Δ k l ( ∙ ) = α β Δ k D ( ∙ ) Δ k D ( ∙ ) = a ^ φ 2 ( ∙ ) k_p=\left(\alpha+\beta\right)k_D k_l=\alpha\beta k_D k_D=? \Delta k_p\left(\bullet\right)=(\alpha+\beta)\Delta k_D\left(\bullet\right) \Delta k_l\left(\bullet\right)=\alpha\beta\Delta k_D\left(\bullet\right) \Delta k_D\left(\bullet\right)=\hat{a}\varphi^2(\bullet) kp=(α+β)kDkl=αβkDkD=?Δkp()=(α+β)ΔkD()Δkl()=αβΔkD()ΔkD()=a^φ2()
  在对自适应参数 a ^ \hat{a} a^在神经网络的更新策略中,遵循以下原则:
a ^ ˙ = − σ 0 a ^ + σ 1 φ 2 ( ∙ ) ∣ ∣ E ∣ ∣ 2 \dot{\hat{a}}=-\sigma_0\hat{a}+\sigma_1\varphi^2(\bullet){||E||}^2 a^˙=σ0a^+σ1φ2()∣∣E∣∣2
  其中, σ 0 \sigma_0 σ0 σ 1 \sigma_1 σ1为正数参数。经过下列引理证明,其具有可行性。
神经pid控制,科研,神经网络,人工智能
  对于非方系统的PID控制器设计模型,由于其输入信号与输出信号不同,所以其矩阵并非方阵,非方系统的矩阵设为 B ( ∙ ) = B 0 ( ∙ ) M ( ∙ ) B\left(\bullet\right)=B_0(\bullet)M(\bullet) B()=B0()M(),其中 B 0 ( ∙ ) ∈ R m × l B_0(\bullet)\in R^{m\times l} B0()Rm×l为行满秩的有界矩阵, M ( ∙ ) ∈ R l × l M(\bullet)\in R^{l\times l} M()Rl×l为严格正定或者负定的矩阵,关于非方系统的PID设计数学模型基本与方系统相同。
u = ( k p + Δ k p ( ∙ ) ) Λ z + ( k l + Δ k l ) Λ ∫ 0 t z ( ∙ ) d τ + ( k D + Δ k D ) Δ d z d t u=\left(k_p+\Delta k_p\left(\bullet\right)\right)\Lambda z+\left(k_l+\Delta k_l\right)\Lambda\int_{0}^{t}z\left(\bullet\right)d\tau+\left(k_D+\Delta k_D\right)\Delta\frac{dz}{dt} u=(kp+Δkp())Λz+(kl+Δkl)Λ0tz()dτ+(kD+ΔkD)Δdtdz
  对于 Λ \Lambda Λ,其与方系统中的单位阵不同,在非方系统的数学模型中, Λ = B 0 T ∣ ∣ B 0 ∣ ∣ \Lambda=\frac{B_0^T}{||B_0||} Λ=∣∣B0∣∣B0T,其余约束与方系统相同,分别为:
k p = ( α + β ) k D k l = α β k D k D = ? Δ k p ( ∙ ) = ( α + β ) Δ k D ( ∙ ) Δ k l ( ∙ ) = α β Δ k D ( ∙ ) Δ k D ( ∙ ) = a ^ φ 2 ( ∙ ) k_p=\left(\alpha+\beta\right)k_D k_l=\alpha\beta k_D k_D=? \Delta k_p\left(\bullet\right)=(\alpha+\beta)\Delta k_D\left(\bullet\right) \Delta k_l\left(\bullet\right)=\alpha\beta\Delta k_D\left(\bullet\right) \Delta k_D\left(\bullet\right)=\hat{a}\varphi^2(\bullet) kp=(α+β)kDkl=αβkDkD=?Δkp()=(α+β)ΔkD()Δkl()=αβΔkD()ΔkD()=a^φ2()
  自适应参数的更新过程仍然遵循 a ^ ˙ = − σ 0 a ^ + σ 1 φ 2 ( ∙ ) ∣ ∣ E ∣ ∣ 2 \dot{\hat{a}}=-\sigma_0\hat{a}+\sigma_1\varphi^2(\bullet){||E||}^2 a^˙=σ0a^+σ1φ2()∣∣E∣∣2,经过以下图示引理可以证明其在MIMO系统中的可行性:
神经pid控制,科研,神经网络,人工智能

4. 总体设计

4.1 参数更新总体设计

  神经网络自适应的PID控制器的参数更新设计框图如下图所示,将滤波后的误差 e e e映射成为 z 1 z_1 z1,通过乘积形式的 γ 2 \gamma^2 γ2参数 α β \alpha\beta αβ α \alpha α β \beta β为拉普拉斯变换再因式分解后的极点)和和形式的 γ \gamma γ参数 α + β \alpha+\beta α+β以及随时间变化的 d ( ∙ ) d(\bullet) d(),将PID的比例部分、积分部分、微分部分进行等价变换、因式分解和加权求和的形式得到一般化的误差 E E E,将 E E E与神经网络中的激活函数的运算乘参数 σ 1 \sigma_1 σ1,将累积的旧的 a ^ \hat{a} a^ − σ 0 -\sigma_0 σ0,将两部分求和去更新自适应参数 a ^ \hat{a} a^,最终的更新学习训练的过程并不是通过设置比例系数、积分系数、微分系数来逼近良好的结果,而是有单一的自适应参数 a ^ \hat{a} a^
神经pid控制,科研,神经网络,人工智能

4.2 系统总体设计

  从参数更新的角度去分析系统设计的框图,这一部分也是设计最核心、最重要的,本节是从总体设计的角度来分析总体设计的框图,总体设计框图如下图所示,系统输入通过误差滤波生成滤波后的误差,通过恒定的比例系数部分 k p k_p kp和随时间变化的比例系数 Δ k p \Delta k_p Δkp进行加权求和,从而生成比例部分的设计,恒定比例系数部分 k p k_p kp包括了 α + β \alpha+\beta α+β决定的 k D k_D kD,随时间变化部分的部分包含了 α + β \alpha+\beta α+β决定的自适应的环节,细节已经在上面的系统设计中阐释,不再赘述;通过恒定的积分系数部分 k l k_l kl和随时间变化的积分系数 Δ k l \Delta k_l Δkl进行加权求和,从而生成积分部分的设计,恒定积分系数部分 k l k_l kl包括了 α β \alpha\beta αβ决定的 k D k_D kD,随时间变化部分的部分包含了 α β \alpha\beta αβ决定的自适应的环节;通过恒定的微分系数部分 k D k_D kD和随时间变化的比例系数 Δ k D \Delta k_D ΔkD进行加权求和,从而生成微分部分的设计,恒定微分系数部分 k D k_D kD,随时间变化部分的部分属于自适应的环节;综上三个部分的设计,将输出信号给予执行器,在实际的闭环系统工作中得到反馈信号,将反馈信号再次作为输入计算误差输入误差滤波器,反复迭代,直到结果收敛到满意的程度。
神经pid控制,科研,神经网络,人工智能

5. 应用与扩展

5.1 机器人机械臂方面的应用

  在机器人的关节空间当中,关节空间是典型的方系统,而末端执行结构(抓取结构)的任务空间是非方系统,其n关节严格物理连接的机器人操作器的数学建模如下图所示:
神经pid控制,科研,神经网络,人工智能
  在方系统的关节空间轨迹中,执行器的建模如下图所示:
神经pid控制,科研,神经网络,人工智能
  设定 y = x 1 = q ∈ R n , z = e 1 = x 1 − y ∗ = q − q ∗ y=x_1=q\in R^n,z=e_1=x_1-y^\ast=q-q^\ast y=x1=qRn,z=e1=x1y=qq用于表征关节空间的角度误差,那么多关节机器人PID控制器的数学建模如下:
u = ( k p + Δ k p ( ∙ ) ) Λ z + ( k l + Δ k l ) Λ ∫ 0 t z ( ∙ ) d τ + ( k D + Δ k D ) Δ d z d t u=\left(k_p+\Delta k_p\left(\bullet\right)\right)\Lambda z+\left(k_l+\Delta k_l\right)\Lambda\int_{0}^{t}z\left(\bullet\right)d\tau+\left(k_D+\Delta k_D\right)\Delta\frac{dz}{dt} u=(kp+Δkp())Λz+(kl+Δkl)Λ0tz()dτ+(kD+ΔkD)Δdtdz
  约束与第三章的设计中所述一致,由于关节空间中是方系统,所以 Λ \Lambda Λ为单位阵,在自适应参数的更新原则 a ^ ˙ = − σ 0 a ^ + σ 1 φ 2 ( ∙ ) ∣ ∣ E ∣ ∣ 2 \dot{\hat{a}}=-\sigma_0\hat{a}+\sigma_1\varphi^2(\bullet){||E||}^2 a^˙=σ0a^+σ1φ2()∣∣E∣∣2 中, φ 2 ( ∙ ) \varphi^2(\bullet) φ2()是NN逼近或者说重构的核心函数。
  在任务空间的非方系统中,设定三维笛卡尔坐标系空间下的 X ∈ R 3 X\in R^3 XR3,动态映射 X ∗ = ε ( q ) X^\ast=\varepsilon(q) X=ε(q),设定 y ∗ = X ∗ ∈ R 3 , y = x 1 = X , z = e = X − X ∗ y^\ast=X^\ast\in R^3,y=x_1=X,z=e=X-X^\ast y=XR3,y=x1=X,z=e=XX(也即末端操作空间的位置误差),误差滤波函数如下:
z 1 ¨ = J ( ∙ ) q ¨ − y ∗ ¨ = B ( ∙ ) u + F ( ∙ ) \ddot{z_1}=J\left(\bullet\right)\ddot{q}-\ddot{y^\ast}=B\left(\bullet\right)u+F(\bullet) z1¨=J()q¨y¨=B()u+F()
  其约束 J ( ∙ ) = ∂ ε ( q ) ∂ q ∈ R 3 × n J\left(\bullet\right)=\frac{\partial\varepsilon(q)}{\partial q}\in R^{3\times n} J()=qε(q)R3×n为雅可比矩阵,同时F与B满足下图的要求:
神经pid控制,科研,神经网络,人工智能
  多关节机器人任务空间PID控制器的数学建模如下:
u = ( k p + Δ k p ( ∙ ) ) Λ z + ( k l + Δ k l ) Λ ∫ 0 t z ( ∙ ) d τ + ( k D + δ k D ) Δ d z d t u=\left(k_p+\Delta k_p\left(\bullet\right)\right)\Lambda z+\left(k_l+\Delta k_l\right)\Lambda\int_{0}^{t}z\left(\bullet\right)d\tau+\left(k_D+\delta k_D\right)\Delta\frac{dz}{dt} u=(kp+Δkp())Λz+(kl+Δkl)Λ0tz()dτ+(kD+δkD)Δdtdz
  其约束不再赘述,其误差 z = e = X − X ∗ z=e=X-X^\ast z=e=XX(末端操作空间位置误差),由于是非方系统,那么 Λ = J T ∣ ∣ J ∣ ∣ \Lambda=\frac{J^T}{||J||} Λ=∣∣J∣∣JT,在自适应参数的更新原则 a ^ ˙ = − σ 0 a ^ + σ 1 φ 2 ( ∙ ) ∣ ∣ E ∣ ∣ 2 \dot{\hat{a}}=-\sigma_0\hat{a}+\sigma_1\varphi^2(\bullet){||E||}^2 a^˙=σ0a^+σ1φ2()∣∣E∣∣2中, φ 2 ( ∙ ) \varphi^2(\bullet) φ2()是NN逼近或者说重构的核心函数。

6. 总结

  神经网络自适应的PID具有极强的现实意义,因为PID作为影响力和应用面极大的经典控制算法,对于其优化能够带来工业界、控制工程领域的极大便利,在实际的应用场景中,对于PID的使用,往往通过手动调参的方式去实验,在一些损失影响不大的系统中,往往耗费时间,在损失影响较大的系统中,往往会造成一些不可估量的成本耗费,而引入神经网络自适应的PID能够完成无需人工试错的环节,节省大量的人力和资源成本;同时,经典控制理论与人工智能神经网络的结合,将会给控制工程带来很强扩展性,能够实现PID控制算法的参数关联自动调整-解析算法,通过自动编程的方式实现实时自适应调整;由于PID控制系统有了自适应的参数,其容错率将大大提高,鲁棒性也大大提高;通过学术前辈的工作,将神经网络自适应的PID的数学建模建立出来,优化参数量,通过神经网络的方式去逼近,易于实现且使得成本可控,当然在神经网络的调优上,仍然需要做一些工作,目前关于PID的学术论文在LTI系统和UNS系统两个领域里近年来出现了很多可行性高的新思维的碰撞,在可解释性、自适应性和容错性上也各不相同,足以证明PID在控制领域的重要地位,也足以证明PID和神经网络结合的必要性和可扩展性。文章来源地址https://www.toymoban.com/news/detail-812812.html

到了这里,关于神经网络自适应PID控制及其应用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 自适应PID算法学习(01)——单神经元PID控制

      单神经元含有n个输入,仅1个输出,每个输入端可记作 x i ( i = 1 , 2 , . . . n ) x_i (i=1,2,...n) x i ​ ( i = 1 , 2 , ... n ) ,若该神经元为多元组成网络中某一层(输入层/输出层/隐含层)其中的一个单元,记该神经元输出为 o j ( j = 1 , 2 , . . . ) o_j(j=1,2,...) o j ​ ( j = 1 , 2 , ... ) ;不

    2024年02月16日
    浏览(32)
  • 常规PID、模糊PID和神经网络PID

    常规PID、模糊PID和神经网络PID是三种常见的PID控制器变种,它们在控制算法和性能方面有所不同。 常规PID控制器是最常用的PID控制器,它根据系统的误差、误差变化率和误差积分值计算控制器输出,并使用比例、积分和微分系数来调整控制器的响应速度和稳定性。 模糊PID控

    2024年02月13日
    浏览(36)
  • 【MATLAB数据处理实用案例详解(22)】——基于BP神经网络的PID参数整定

    基于BP神经网络的PID控制的系统结构如下图所示: 考虑仿真对象,输入为r(k)=1.0,输入层为4,隐藏层为5,输出层为3,仿真输出满足 a ( k ) = 1.2 ( 1 − 0.8 e x p ( − 0.1 k ) ) , y ( k ) = a ( k ) y − 1 1 + ( y − 1 ) 2 + u − 1 a(k)=1.2(1-0.8exp(-0.1k)),y(k)=a(k) frac{y-1}{1+(y-1)^2}+u-1 a ( k ) = 1.2 ( 1 −

    2024年02月07日
    浏览(52)
  • 神经网络的主要应用领域,神经网络技术及其应用

    神经网络原理及应用 1. 什么是神经网络? 神经网络是一种模拟动物神经网络行为特征,进行分布式并行信息处理的算法。这种网络依靠系统的复杂程度,通过调整内部大量节点之间相互连接的关系,从而达到处理信息的目的。 人类的神经网络 2. 神经网络基础知识 构成:大

    2024年02月09日
    浏览(43)
  • 【PID控制原理及其算法】

    本文以自己的学习过程总结而来,将自己的经验写出来以供大家一起学习,如有错误请多指教 PID就是比例、积分、微分,PID算法可以说是在自动控制原理中比较经典的一套算法,在现实生活中应用比较广泛。 常规的模拟 PID 控制系统原理框图如下图所示: 那么使用PID的目的

    2023年04月24日
    浏览(22)
  • 基于适应度相关算法优化的BP神经网络(预测应用) - 附代码

    摘要:本文主要介绍如何用适应度相关算法优化BP神经网络并应用于预测。 本案例数据一共2000组,其中1900组用于训练,100组用于测试。数据的输入为2维数据,预测的输出为1维数据 2.1 BP神经网络参数设置 神经网络参数如下: 2.2 适应度相关算法应用 适应度相关算法原理请参

    2024年02月11日
    浏览(29)
  • 可逆神经网络的研究及其在图像中应用

    一、摘要 可逆神经网络(INN)自被提出以来,就受到了广泛关注。由于其双射构造和高效可逆性,INN被用于各种推理任务,如图像隐藏、图像重缩放、图像着色、图像压缩和视频超分辨率等等。本文针对最新关于INN在图像方面应用的文献进行介绍,包括每篇文献的基本原理和个

    2024年02月06日
    浏览(28)
  • 【复习】人工智能 第 8 章 人工神经网络及其应用

    因为计算牵扯到导数,所以这章难的部分不会考太难。 人工神经网络是对人脑或生物神经网络若干基本特性的抽象和模拟。 深度学习是神经网络的发展。 人工智能曾经历过很长一段时间的停滞不前。 浩瀚的宇宙中,也许只有包含数千忆颗星球的银河系的复杂性能够与大脑相

    2024年01月19日
    浏览(41)
  • 基于Matlab自抗扰控制器及其PID控制(附上完整源码+数据)

    自抗扰控制器(Active Disturbance Rejection Control, ADRC)是一种新型的控制策略,它具有强大的抗干扰能力和良好的控制性能。与传统的PID控制器相比,ADRC能够更好地抑制系统的干扰,提高控制系统的稳定性和鲁棒性。 在ADRC中,核心思想是引入一个扰动观测器(Disturbance Observer,

    2024年02月16日
    浏览(37)
  • 矩阵及其运算在卷积神经网络(CNN)中的应用与启发

    简介 👨‍💻个人主页:@云边牧风 👨‍🎓小编介绍:欢迎来到云边牧风破烂的小星球🌝 📋专栏:Python课程 🔑本章内容:CNN卷积神经网络 记得 评论📝 +点赞👍 +收藏😽 +关注💞哦~ 摘要 1. 引言 1.1 研究背景和意义 1.2 报告结构 2. 卷积神经网络(CNN)简介 2.1 CNN基本原理

    2024年02月04日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包