本帖最后由 zpc64 于 2010-10-8 10:18 编辑
2 f" G: O# B! }7 H' x2 F( g6 \. @3 [( l. n
稳定CO2焊焊接电流模糊控制器的设计与仿真 (二) 为了克服单因子自调整的不足,根据偏差的量化值的大小,提出了一个多因子自调整控制规则的算式:
" Z$ H: ?, I! x6 {3 [- o 采用带修正因子的控制规则,即使是采用五因子修正算式,α(i=1-5)值选取仍有较大的盲目性,往往是先凭经验预定出α的若干个不同的取值,再逐一对它们进行实验仿真,以选择最优值。这种方法既耗时又繁琐,而且往往选不到真正最优的α值。因此还需要设计一种修正因子自寻优的模糊控制器,它能在系统控制过程中对α进行实时自寻优,以实现控制规则的自调整和自完善,达到提高控制系统品质的目的。7 S b, o# y! R* v0 H8 d; T1 T R
带修正因子自寻优的模糊控制系统结构如图1所示,其中通常是取:J=∫∞0t|e|dt为目标函数,并以目标函数的值为最小作为系统的性能指标,而且用修正因子α为寻优参数。寻优过程是针对被控过程的运行状况,根据目标函数值的大小不断地对因子α进行修正,使目标函数值逐步减小,直到系统的控制性能达到要求为止。若运行状况发生新的变化,则需重新执行寻优过程,直到调整出适合新运行状态设为修正因子。
" ]8 t- ~: i3 a" R) ` 在对给定的输入响应求目标函数值时,由于用计算机组成的模糊控制系统是一个离散系统,故应把目标函数J化为离散算式:* C3 L; R h/ O" ]: O
J=Σ〖DD(〗n〖〗i=1〖DD)〗iT|e(i)|T=Σ〖DD(〗?n〖〗i=1〖DD)〗iT2|e(i)|〖JZ)〗〖JY〗(8)5 L' R) R0 ~1 m8 p
其中:T是采样周期,i是采样序号。
0 r5 a/ c6 y: ~4 M" |" H 如果把采样周期T看成单位时间,则可取T=1。式(8)可写为:
; H% E5 _, Z% } J=Σ〖DD(〗N〖〗I=1〖DD)〗i|e(i)|〖JZ)〗〖JY〗(9)2 I" v/ n9 {! H2 E0 M3 P
这样,只要先凭经验选择一组初始修正因子α={α?1,α?2,α?3,α?4,α5},得出一组初始的控制规则来对被控对象进行控制,然后对系统响应的过度过程进行采样,即可用式(9)求出目标函数J的值。
0 Q: h6 d4 d. `2 I( T. [$ u! f 在求得系统的目标函数值后,在应用寻优算法进行修正因子α的在线自寻优,使目标函数值J?=min或达到给定值为止。此时的α={α1,α2,α3,α4,α5}为最优修正因子,系统的特性也达到了最优,其中的寻优算法可采用单纯算法(其方法在自动控制理论相关的书籍上都有介绍)。
& }6 s! C- P8 J 2.4 模糊控制表的完成
0 t, i7 B9 ]' ~. N* J s6 z) N: { 当选用不同的修正因子时,根据公式(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。2 C8 l: H# C% X4 l6 X
2.5 模糊控制输出量的反模糊化* ]6 G# {+ o4 x; K0 ]
将上面得到的控制量的论域乘以比例因子,便可得到实际的控制增量,加上原来的控制量,输出去控制被控对象。若在(4)的基础上,不对输入输出量进行量化,而对所得到的一组优化修正因子进行曲线拟合,得到修正因子的连续表达式,则可获得连续的输出量。对修正因子进行拟合运算的模糊控制系统见图1。这样可消除量化误差和调节死区。
" p u, V; c* R% W6 D! Q3 C 综上所述,带修正因子的自组织模糊控制器可以抛开控制表,把模糊控制规则综合成一个简单算式,直接求取控制量,并可以根据系统的运行状态,通过调整α值,很方便地进行在线调整控制规则,以改善系统的控制性能。因此这是一种既方便又有效的自组织模糊控制器,特别适合于工程上应用。
; G8 f4 ?9 _, t7 I 3 模糊控制器的仿真和分析4 [% l1 p" G& @7 L2 v2 H* u
由于模糊控制器的设计思想是模拟人脑的思考过程,在模糊控制器的设计过程中,对实际经验的依赖性很大,要求设计者结合实际经验,选取控制量,设计控制规则。选取的某些控制量和控制规则的效果如何,必须编制大量的程序进行仿真分析,或者是等到控制器完成以后通过实际来观察、验证。显然,这两种方法都费时费力,而且都必须通过大量实验才能确定,实际设计过程中,类似的工作往往占总工作量的大部分。针对上面的情况,本文使用MATLAB(含SIMULINK)软件进行仿真。
" Q# [' T7 j; S% c9 S1 z# V3 q 3.1 SIMULINK中的模型的创建方法
9 s4 e% M- k1 \$ b [0 Q 一般模型元件的创建,关键在S函数的正确编制及调用。S函数实质上是具有特殊调用格式的MATLAB函数,表征系统动态特性,能使SIMULINK有能力构造一般的仿真方框图,灵活方便的设计出用户的特殊环节。
' u) S3 _; N0 x+ r% A 实际上,SIMULINK的每一个模型都可以用输入、输出、状态三个要素进行描述:2 K( f8 P5 `4 { n- I9 B1 T
function[sys,x0]=sfunc(t,x,u,flag,参数1,参数2,…)
: w! Y9 N( ?/ r2 C 其中,sfunc是用户定义的系统,t是当前时刻,x是当前状态值,x0是初始状态值,u是当前系统输出值,变量flag的值返回变量sys的信息。
" x: K1 \. O! b/ I( ^2 {7 J 模糊控制原理如图1所示。其中具有调整因子的模糊控制环节,用S函数描述如下:% g( u% |) b4 r2 g7 O
zt fuzzy.m
* w: t) P$ k& O9 e0 c5 w2 v function[sys,x0]=zt fuzzy(t,x,u,flag,ke,kc,ku,a)' J- J" b* t9 R! l0 \6 t& {
if abs(flag)=3
, O" d) b- c) R8 U4 N& C E=round(ke*u(1));
! O$ ?( X; R) s; C3 I7 K C=round(ke*u(2)); [& P& f( l; c# d1 U1 L9 B5 ]0 l
Sys=ku*(a*E (1-a)*c);" B- Z/ d" X$ _% N9 H g& W
Else if flag=04 K! a9 W: e( `. @2 d
Sys=[0;0;1;2;0;0];
% I4 ^0 h! `& v) B1 ^ Elae
" B; U4 P3 d+ d$ h3 R Sys=[];
! Z# q6 |& R! k" C% K! ~! z End' y9 R! E: b U
将上述S函数进行成组(Group)和封装(Mask)处理,就得到用户创建的SIMULINK模块。在系统仿真中新模块与SIMULINK提供的标准模块功能完全一样,具有相同的仿真效率及可信度。
' _+ L4 o3 i9 y 3.2 模糊控制器的仿真及分析
9 A3 m9 L( t0 r 将上述S函数经过封装处理后,在SIMULINK模型库中找出与设计的系统相对应的模块,把它们拖到新模型窗口中,用线连接起来就可以创建一个如图2示的模糊系统模型图。 & S! i, Z& T1 b7 e
5 g0 z j% {$ T; j( f* B 利用该模型就可以对所设计模糊控制系统进行仿真研究。图中ZTFUZZY模块是自建的& w, {6 E1 x( a2 U4 M4 }
模糊调节器模型,图中step是仿真时输入的阶跃信号,焊接电流的传递函数假设为:G(s)=1/s(s+1),图中的示波器scope的作用是实时的画出控制系统的输出结果曲线,也可以将数据存储到MATLAB的工作空间中,再利用绘图plot命令将输出曲线在单独窗口画出来。* d% c; m; d$ Q6 M
采用多修正因子的自调整规则进行控制仿真的结果如图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)控制效果最好,超调最小,相应时间最短。但由于在线优化给控制器增加了负担,使实时效果降低。
0 E, ?2 M" \2 G3 h4 [& S/ V5 Y9 { 4 结论
. Y$ ^; |5 [; v0 O* `, L) s 1)所设计的稳定CO?2焊焊接电流模糊控制器不仅可以有效的消除电弧电压调节过程中所引起的焊接电流的偏差,而且也可以消除网络电压波动、保护气体纯度或流量以及焊炬高度变化所引起的偏差。3 ~ x% f$ @: ?& D
2)设计焊接电流的带修正函数自寻优模糊控制器的稳定性好,阶跃响应的超调小,动态响应快。 |