QQ登录

只需一步,快速开始

登录 | 注册 | 找回密码

三维网

 找回密码
 注册

QQ登录

只需一步,快速开始

展开

通知     

查看: 2206|回复: 1
收起左侧

[推荐] 稳定CO2焊焊接电流模糊控制器的设计与仿真

 关闭 [复制链接]
发表于 2010-10-8 10:11:33 | 显示全部楼层 |阅读模式 来自: 中国江苏常州

马上注册,结识高手,享用更多资源,轻松玩转三维网社区。

您需要 登录 才可以下载或查看,没有帐号?注册

x
稳定CO2焊焊接电流模糊控制器的设计与仿真(一)
1 前言 ) {5 z% D6 _: Y. I/ O# Y
  焊接电流是影响焊丝熔化和焊缝熔深的主要焊接参数,一般在焊接过程控制中常作为恒定的设定参数来考虑。通常焊接电流是由送丝特性曲线与焊接电源外特性交点所决定的,在调节外特性曲线位置而调整电弧电压时,焊接电流就会随电压值的变化而偏离原来的设定值。焊接电路和电弧电压这两个主要的规范参数之间的关系是一种非线形的耦合关系,利用人工想很快使焊接电流回复到原设定值是很困难的。另外,由于网络电压的波动、保护气体纯度、流量以及焊炬高度的变化等都引起焊接电流的波动。虽然焊机本身具有的自身调节作用,但都会给焊接电流带来一定的误差。针对以上情况,本文研制了一种以可编程控制器(PLC)为核心器件并自主开发的软件,实现稳定行CO2焊焊接电流的模糊控制器。
6 Y% B# i, I. v) R+ S+ m  模糊控制器具有良好控制效果的关键是具有一个完善的控制规则。但对于高阶、非线性、大时滞、时变以及随机干扰严重的复杂被控过程,仅靠对操作者实践经验的总结或模糊控制信息的归纳,很难设计出适合被控过程不同运行状态的控制规则。
7 v7 ?7 p1 O% w1 r2 i5 z  为此,本文不采用Mamdani规则表,而是在基本模糊控制器的设计基础上,设计了一种带修正函数自寻优模糊控制器(如图1), . J, N  L+ w" l: D
它是一种自组织的模糊控制器[2];并对所设计的模糊控制器使用MATLAB(含SIMULINK)软件进行仿真。 / k4 _1 `$ {; d3 T! F2 w
  2 模糊控制器的设计 7 Q$ G8 B* N' D% X" n
  2.1 ei,ei/dt和ui基本论域的确定# n& i3 e$ h  Y6 N/ L' ]2 H1 f
  由送丝特性曲线可知,当焊接电流在短路与过渡(小规范)范围内,电压每秒变化一伏,电流变化在几安培之内,当进行中规范焊接时,电弧电压变化一伏,电流变化最大可达十几安培。: E  o7 O1 k7 k3 J( s; }2 g0 c
  本程序把ei在小规范论域设定为[-10~+10A];ei在中规范论域设定为[-30~+30A];ei在大规范论域设定为[-60~+60A]。2 P+ v% c. S! `! v" N' b
  在PLC系统中ei/dt可以写为[e(k)-e(k-1)]/Δt。Δt是指扫描时间,对于某一个确定的程序而言,扫描一次的时间是相同的,因此可以把它设为一个常数,用[e(k)-e(k-1)]的大小近似地代表dei/dt.[e(k)-e(k-1)]的范围可估计为:0≤|[e(k)-e(k-1)]|≤2max[|e(k)|-|e(k-1)|],所以可以取dei/dt的基本论域分别为:[-20A/s+20A/s];[-60A/s+60A/s];[-120A/s+120A/s]。1 ]3 ~/ G. i  F+ P9 p/ d% }
  为了便于编写程序,对小、中、大的ei和ei/dt的论域分别给上一个合适的比例因子k1、k2、k3。取:k1=3 k2=1 k3=1/2;得到ei和ei/dt的统一的格式为[-30,+30],[-60,+60]。
$ a) s( D+ u4 h  ei是每次采集得到的u(k)与给定值之差,所以ui的论域可取与ei的相似论域,即为[-30,+30]。 6 O6 |  a' H( G% D+ B8 j
  2.2 输入输出的语言变量
4 o2 ~  o; D( T0 @, h& {  在工程实际中,语言变量权m一般取为5~10档,结合本系统的具体的性能,本控制器取为5档。离散的语言变量论域中元素个数n与m的关系为:n=(1.5-2)m,因此n可取为9,从而ei,ei/dt和ui的语言变量论域E,Ec,U分别为:
* S! N$ Y, ^( V* D  [-4,-3,-2,-1,0,+1,+2,+3,+4]
+ t% y) E5 e% ?+ S/ f3 r  Q  与此对应偏差量化因子为0.1;偏差变化率量化因子为0.05;输出量化因子为0.1。
$ I9 \. {4 @; j  2.3 模糊控制器的规则
- G0 W' @: }' a; V  假设被控对象的实际动态过程可用下式描述:' ]+ ?, V& K4 i9 `. W0 w0 m
  Y(K)+a1Y(K-1)+…+anY(K-n)=b1U(K-m-1)+…bnU(K-m-n)+e(K)+c1e(K-1)+…+cne(K-n) (1)2 U( G6 Z5 d$ h: P9 E
  式中U(K),Y(K)分别为被控对象的输入和输出;e(K)为噪声干扰率明表示被控对象的传输延时;ai,bi,ci(i=1,2,…n)为各项系数。2 h4 M3 b5 L2 y5 Q3 }( m
  设计一个预报模型,即根据K时以前的数据Y(K),Y(K-1),…和U(K),U(K-1),…来预报Y(K+m+1),其中m=0,1,2,…。根据自适应控制理论,预报模型的方程为:
4 @+ k' n- i" x* ^  Y(K+m+1)+α1Y(K)+…αpY(K-p-1)=β0U(K)+β1(K-1)+…+βUL(K-L)+∈(K+m+1) (2)
$ |4 R$ p) j2 L  式中∈(K+m+1)为预报模型的偏差,令向量XT(K)=[-Y(K),-Y(K-1),]…-Y(K-p+1),U(K-1),…,U(K-L);
! p$ n+ Q  G2 {. p$ T& u    定义参数向量θT=[α1,α2,…,αp,β1,…,βL],则式(2)2 C0 E' K0 R% u9 x% g& x; }$ W$ v
可简化为:Y(K)=β0U(K-m-1)+XT(K-m-1)θ+∈(K) (3)
) @8 g5 J+ ?5 s: q" I  对于参数向量θ的估计,可以采用简单的最小二乘递推法,其递推形式为:
7 J* J$ b$ D2 g) X  θ(K+1)=θ(K)+R(K)[Y(K)-β0U(K-m-1)-X(K-m-1)θ(K)]
# C* @9 {6 m- e6 _# l+ r5 X1 u  R(K)=P(K)X(K-m-1)[1-X(K-m-1—)P(K)X(K-m-1)]-1?
1 ?+ Q( D; }( m  P(K+1)=P(K)-P(K)[1+XT(K-m-1)P(K)X(K-m-1)RT(K)] (4): S3 k) Z. B+ R$ x( [% W
  式中,θ(K)和θ(K+1)表示在K和(K+1)采样时刻的参数向量θ的估计量
1 f% @' |. Y; t/ i;P(K)是m×m阶矩阵,它的维数取决于未知参数的数目,而与测量次数无关。
# m1 W2 y1 {3 v  l8 G# ?  因此,可由式(4)求出Y(K)的预报值,从而求出预测误差e和误差的变化率ec。若给定值为R,则:  d% R0 n; I' d9 B. T
  e=Y(K)-R,ec=Y(K-1)-Y(K) (5)
% Z* g- P+ R" H) m" e* i' h; o+ y6 v  将e和ec整量化及模糊化后,可得带有调整因子的规则可调的Fuzzy控制规则:
5 B; `" I, S9 m, Y' G" m6 Q: u  U=-[αe+(1-α)ec] (6)
- g. u& l3 ~" q- g  式中,U为控制量U的整量值;α为调整因子,又称加权系数,α∈(0,1)。! y  T! U* T/ ?: B. i
  α值的大小,直接反映了对偏差e和偏差变化率Δe的加权程度。因此,上式通过调整单一因子的值,就可以很方便地修改控制规则,以改善系统的控制效果。但这种规则的单因子自调整方法存在一些不足,就是其控制规则只依赖一个α参数;一旦确定α,则偏差e和偏差变化率Δe的权重就确定了。在实际中控制系统处于不同工作状态时,要求e和Δe的权重不同;当e的绝对值较大时,控制系统的主要矛盾是消除e,故此时应增大α值,使e在控制规则中占较大的权重,以改善系统的动态特性;当e的绝对值较小时,控制系统的主要矛盾是抑制系统超调,使系统尽快达到稳态,故此时应减小α值,而1-α值则相应增大,使Δe在控制规则中占较大的权重。用单因子调整控制规则显然无法实现系统状态变化的需要。
9 Q5 P1 b( d. C9 Y  `1 T/ \
% T: f% Q, @& I% g  w2 F
 楼主| 发表于 2010-10-8 10:14:02 | 显示全部楼层 来自: 中国江苏常州
本帖最后由 zpc64 于 2010-10-8 10:18 编辑 + K* ?/ V/ e8 m+ |4 x& e! _
$ s2 ^* \0 R7 G& }8 R$ ^
稳定CO2焊焊接电流模糊控制器的设计与仿真 (二)
为了克服单因子自调整的不足,根据偏差的量化值的大小,提出了一个多因子自调整控制规则的算式:
2 l2 c8 C& Q* L% g9 N8 I& F  采用带修正因子的控制规则,即使是采用五因子修正算式,α(i=1-5)值选取仍有较大的盲目性,往往是先凭经验预定出α的若干个不同的取值,再逐一对它们进行实验仿真,以选择最优值。这种方法既耗时又繁琐,而且往往选不到真正最优的α值。因此还需要设计一种修正因子自寻优的模糊控制器,它能在系统控制过程中对α进行实时自寻优,以实现控制规则的自调整和自完善,达到提高控制系统品质的目的。
! @/ k' ^% R# D& E( y  带修正因子自寻优的模糊控制系统结构如图1所示,其中通常是取:J=∫∞0t|e|dt为目标函数,并以目标函数的值为最小作为系统的性能指标,而且用修正因子α为寻优参数。寻优过程是针对被控过程的运行状况,根据目标函数值的大小不断地对因子α进行修正,使目标函数值逐步减小,直到系统的控制性能达到要求为止。若运行状况发生新的变化,则需重新执行寻优过程,直到调整出适合新运行状态设为修正因子。' ?7 `+ W8 X' R1 ^0 t. \
  在对给定的输入响应求目标函数值时,由于用计算机组成的模糊控制系统是一个离散系统,故应把目标函数J化为离散算式:* C6 f6 q6 I  p( D
  J=Σ〖DD(〗n〖〗i=1〖DD)〗iT|e(i)|T=Σ〖DD(〗?n〖〗i=1〖DD)〗iT2|e(i)|〖JZ)〗〖JY〗(8): E* I! b6 M+ X6 g" Q
  其中:T是采样周期,i是采样序号。
  {0 b# l1 ~* o  如果把采样周期T看成单位时间,则可取T=1。式(8)可写为:& X. I5 ]1 Q+ z  Z- R; \$ A5 a! J
  J=Σ〖DD(〗N〖〗I=1〖DD)〗i|e(i)|〖JZ)〗〖JY〗(9)
& F* N! i' w( P7 x8 T% H! j; K  这样,只要先凭经验选择一组初始修正因子α={α?1,α?2,α?3,α?4,α5},得出一组初始的控制规则来对被控对象进行控制,然后对系统响应的过度过程进行采样,即可用式(9)求出目标函数J的值。
! p1 a& F& x+ ], |# m( _  在求得系统的目标函数值后,在应用寻优算法进行修正因子α的在线自寻优,使目标函数值J?=min或达到给定值为止。此时的α={α1,α2,α3,α4,α5}为最优修正因子,系统的特性也达到了最优,其中的寻优算法可采用单纯算法(其方法在自动控制理论相关的书籍上都有介绍)。
! Z. [3 K9 Z0 e8 `7 [# v  2.4 模糊控制表的完成
1 I4 |" k$ i. ]$ x; A6 |8 b' u- L  当选用不同的修正因子时,根据公式(7)就会得到不同的模糊控制规则而形成不同的模糊控制表。对于弧焊电源这样一个典型的被控对象,其传递函数假定为:G(s)=1/s(s+1)。设给定的输入为单位阶跃输入信号,现采用修正因子自寻优方法对以上对象进行控制。为了得到最优的α值,首先凭经验预定出5个不同的取值α?1=0.3,α?2=0.4,α?3=0.5,α?4=0.6和α?5=0.7;再以式(9)表示的J为寻优目标,采用单纯形法作为寻优方法,经过多次调整最终找到J=min的最优修正因子为:α1=0.28,α2=0.50,α3=0.66,α4=0.79,α5=0.93。) W: ?0 i3 V3 q& C  I7 [
  2.5 模糊控制输出量的反模糊化$ w6 Q. y( X) x# l) [9 _
  将上面得到的控制量的论域乘以比例因子,便可得到实际的控制增量,加上原来的控制量,输出去控制被控对象。若在(4)的基础上,不对输入输出量进行量化,而对所得到的一组优化修正因子进行曲线拟合,得到修正因子的连续表达式,则可获得连续的输出量。对修正因子进行拟合运算的模糊控制系统见图1。这样可消除量化误差和调节死区。
* W# `" K! b4 _+ h2 p  综上所述,带修正因子的自组织模糊控制器可以抛开控制表,把模糊控制规则综合成一个简单算式,直接求取控制量,并可以根据系统的运行状态,通过调整α值,很方便地进行在线调整控制规则,以改善系统的控制性能。因此这是一种既方便又有效的自组织模糊控制器,特别适合于工程上应用。 5 p% A5 v8 P5 @0 x5 ~& m( s8 W
  3 模糊控制器的仿真和分析* \, a1 r5 Q# S! ?$ P4 n
  由于模糊控制器的设计思想是模拟人脑的思考过程,在模糊控制器的设计过程中,对实际经验的依赖性很大,要求设计者结合实际经验,选取控制量,设计控制规则。选取的某些控制量和控制规则的效果如何,必须编制大量的程序进行仿真分析,或者是等到控制器完成以后通过实际来观察、验证。显然,这两种方法都费时费力,而且都必须通过大量实验才能确定,实际设计过程中,类似的工作往往占总工作量的大部分。针对上面的情况,本文使用MATLAB(含SIMULINK)软件进行仿真。 / [9 a' y! Q2 I: ]
  3.1 SIMULINK中的模型的创建方法2 ?. R# s, C$ d6 b" L1 ?- s( v
  一般模型元件的创建,关键在S函数的正确编制及调用。S函数实质上是具有特殊调用格式的MATLAB函数,表征系统动态特性,能使SIMULINK有能力构造一般的仿真方框图,灵活方便的设计出用户的特殊环节。
1 R' b+ G" W! I2 @+ c& d& ?/ M5 o  实际上,SIMULINK的每一个模型都可以用输入、输出、状态三个要素进行描述:/ N( p; U/ R+ e) [! H
  function[sys,x0]=sfunc(t,x,u,flag,参数1,参数2,…)
0 X. n2 i8 `  S% c. _+ |  其中,sfunc是用户定义的系统,t是当前时刻,x是当前状态值,x0是初始状态值,u是当前系统输出值,变量flag的值返回变量sys的信息。
: M) I# n9 ?1 ]# J9 T2 s  模糊控制原理如图1所示。其中具有调整因子的模糊控制环节,用S函数描述如下:
( a/ K% e7 y& h' P) C  zt fuzzy.m5 o5 c5 ]) @$ a) ^
  function[sys,x0]=zt fuzzy(t,x,u,flag,ke,kc,ku,a)2 U$ J$ h! ?; W- r- D) \
  if abs(flag)=3
4 k5 @1 V& ?* W" j  E=round(ke*u(1));
8 b" ~& P( H3 b+ y  C=round(ke*u(2));, S& w& o4 {4 \& P1 Y7 j- |
  Sys=ku*(a*E (1-a)*c);9 u; s; z6 o/ G7 o4 u
  Else if flag=0
9 F  Y9 B0 Q) e  y( Y  Sys=[0;0;1;2;0;0];. [% l" q" O5 [3 s" a
  Elae
+ ^0 i7 K) `9 x. A  Sys=[];) J  w' H9 u* X
  End( ?3 r, S% x7 C) N$ D
  将上述S函数进行成组(Group)和封装(Mask)处理,就得到用户创建的SIMULINK模块。在系统仿真中新模块与SIMULINK提供的标准模块功能完全一样,具有相同的仿真效率及可信度。 8 J" h( k/ {% G! H- z7 o
  3.2 模糊控制器的仿真及分析, g$ G" z% l$ d' D* D
  将上述S函数经过封装处理后,在SIMULINK模型库中找出与设计的系统相对应的模块,把它们拖到新模型窗口中,用线连接起来就可以创建一个如图2示的模糊系统模型图。 0 a& Z  O$ W, G! M( T9 U8 s

9 ?, U( k1 L; T, D0 @& X# X  利用该模型就可以对所设计模糊控制系统进行仿真研究。图中ZTFUZZY模块是自建的
  P9 r5 ^/ K7 t$ P  K* G  模糊调节器模型,图中step是仿真时输入的阶跃信号,焊接电流的传递函数假设为:G(s)=1/s(s+1),图中的示波器scope的作用是实时的画出控制系统的输出结果曲线,也可以将数据存储到MATLAB的工作空间中,再利用绘图plot命令将输出曲线在单独窗口画出来。: a9 h# I( S0 K
  采用多修正因子的自调整规则进行控制仿真的结果如图3所示。其中曲线3对应于五个修正因子α?1=0.3,α2=0.4,α3=0.5,α4=0.6和α5=0.7时控制系统的单位阶跃相应,曲线2应于五修正因子α1=0.28,α2?=0.50,α3=0.66,α4=0.79,α5=?0.93时控制系统的单位阶跃相应,而曲线1是系统在线调整修正因子时控制系统的相应曲线。由图可见,离线优化的因子(曲线2)的控制较未优化(曲线3)的控制效果要好,而在线调整因子(曲线1)控制效果最好,超调最小,相应时间最短。但由于在线优化给控制器增加了负担,使实时效果降低。* d, r. G" E; ]
  4 结论
4 L! Y/ _7 }8 ?0 y  1)所设计的稳定CO?2焊焊接电流模糊控制器不仅可以有效的消除电弧电压调节过程中所引起的焊接电流的偏差,而且也可以消除网络电压波动、保护气体纯度或流量以及焊炬高度变化所引起的偏差。
; `- O$ I8 m6 \" z9 o# U  b  2)设计焊接电流的带修正函数自寻优模糊控制器的稳定性好,阶跃响应的超调小,动态响应快。
发表回复
您需要登录后才可以回帖 登录 | 注册

本版积分规则


Licensed Copyright © 2016-2020 http://www.3dportal.cn/ All Rights Reserved 京 ICP备13008828号

小黑屋|手机版|Archiver|三维网 ( 京ICP备2023026364号-1 )

快速回复 返回顶部 返回列表