1、1直接转矩控制的基本原理及特点与规律直接转矩控制系统简称DTC(Direct Torque Control)系统,是继矢量控制系统之后发展起来的另外一种高动态性能的交流电动机变压变频调速系统。在它的转速环里面利用转矩反馈直接控制电机的电磁转矩,因此而得名为直接转矩控制。1.1直接转矩控制系统原理与特点如图1-1为直接转矩控制的原理框图,和VC系统一样,它也是分别控制异步电动机的转速和磁链,转速调节器ASR的输出作为电磁转矩的给定信号,在后面设置转矩控制内环,它可以抑制磁链变化对于转矩的影响,从而使得转速和磁链系统实现解耦。因此,从整体控制结构上来看,直接转矩控制(DTC)系统和矢量控制系统(V
2、C)系统是一致的都获得了较高质量的动态性能以及静态性能。 图1-1直接转矩控制系统图从图中中可以看出,直接转矩控制系统,就是通过使定转子磁链的幅值保持恒定,然后选择合理的零矢量的作用次序和作用时宽,以调节定子磁链矢量的运动速度,从而改变磁通角的大小,以实现对电机转矩的控制。在直接转矩控制技术中,其基本控制方法就是通过电压空间矢量来控制定子磁链的旋转速度,控制定子磁链走走停停,以改变定子磁链的平均旋转速度 的大小,从而改变磁通角的大小,以达到控制电动机转矩的目的。直接转矩控制作为一种交流调速的控制技术具有以下特点:直接转矩控制直接在定子坐标系下分析交流电动机的数学模型,直接控制电机的磁链和转矩。
3、它不需要将交流电动机和直流电动机做比较等效简化,不需要模仿直流电动机的控制,也不需要为解耦而简化交流电动机的数学模型,它省掉了矢量旋转变换等复杂的变换与计算。因此,它所需要的信号处理工作特别简单,所用的信号使观察者对于交流电动机的物理过程能够做出直接和明确的判断。直接转矩以定子磁场定向,只要知道定子参数就可以把它观测出来。而矢量控制磁场定向所用的是转子磁链,观测转子磁链需要知道电动机的转子电阻和电感。因此,直接转矩控制大大减少了矢量控制技术中控制性能易受参数变化影响的问题。直接转矩控制采用空间电压矢量和六边形磁链轨迹,直接控制转矩。转矩和磁链都采用两点式调节,把误差限制在容许的范围内,控制直接
4、又简化。控制信号的物理概念明确,转矩响应快,具有较高的静、动态性能。由于以上的优点所以直接转矩控制技术在现代控制理论中得到广泛的运用。1.2直接转矩系统的控制规律和反馈系统在DTC系统中采用的是两相静止坐标(坐标),为了简化数学模型,由三相坐标变换成两相是非常重要的,所以可以避开旋转变换。由式(1-1)和式(1-2)可得 (1-1) (1-2)移项并积分后得 (1-3) (1-4)式(1-3)和式(1-4)就是图1-1中所采用的定子磁链模型,其结构框图如图1-2所示。它适合于中低速时切换到电流模型,这是上述能提高鲁棒性的优点就不得不丢弃。 图1-2 定子磁链模型结构框图 在两相静止坐标系上的电
5、磁转矩表达式为 (1-5) 整理可得 (1-6)2系统建模与仿真2.1模块模型实现建立如图2-1所示的直接转矩控制系统仿真模型,其中电动机采用基于坐标系的数学模型,转速采用积分和输出限幅的PI调节器,定子磁链和转矩调节器采用带有滞环的双位式控制器,电压矢量选择环节采用simulink中的s函数编写。2-1直接转矩控制系统仿真模型2.1.1电机模型在进行异步电机的仿真时,没有必要对四种状态方程逐一进行,只要以一种为内核,在外围加上坐标变换和状态变换,就可得到在不同的坐标下、不同状态量的仿真结果。因此在此处建立以定子磁链、转速和电流为状态变量的状态结构为核心,构建异步电机仿真模型,如图2-2.其中
6、Rt=(Rs*Lr*Lr*Rr*Lm*Lm)/(Lr*Lr)。 (2-1)1.定子磁链计算定子磁链的模拟和离散计算式为 (2-2) (2-3)式中,和为两相坐标系上的钉子电压和电流,K为积分系数,为采样时间。磁链计算采用离散梯形积分,模块给出磁链,并由Complex to Magnitude-Angle计算磁链的幅值和转角。2.转矩计算电动机转矩计算式为 (2-4)为电动积极对数。图2-2异步电机仿真模型2.1.2磁通和转矩滞环控制器电动机的转矩和磁链都采用滞环控制,其控制器结构如图2-3所示。转矩控制是三位滞环控制方式,在转矩滞环宽度设为时,当转矩偏差大于和小于时,滞环模块分别输出“1”和“
7、3”,当滞环模块输出为“2”时,经或非门NOR输出状态“2”。磁链控制是二位滞环控制,分别输出“1”和“2”。图2-3转矩滞环控制器模块2.1.3电压矢量选择电压矢量环节采用s_function模块,如图2-6所示,s函数见附录。图2-4电压矢量选择环节2.1.5其他模块仿真模型其他模块结构如下图所示。图2-5两相坐标变换图2-6K/P变换图2-7电流环图2-8 3/2变换附录function sys,x0,str,ts,simStateCompliance=caotian(t,x,u,flag,u1,u2,u3,u4,k)switch flag case 0 sys,x0,str,ts,si
8、mStateCompliance=mdlInitializeSizes(k); case 1 sys = mdlDerivatives(t,x,u,k); case 2,9 sys = ; case 3 sys = mdlOutputs(t,x,u); otherwise DAStudio.error(Simulink:blocks:unhandledFlag, num2str(flag);endfunction sys,x0,str,ts,simStateCompliance = mdlInitializeSizes(k)sizes = simsizes;sizes.NumContState
9、s = 1;sizes.NumDiscStates = 0;sizes.NumOutputs = 1;sizes.NumInputs = 1;sizes.DirFeedthrough = 0;sizes.NumSampleTimes = 1;sys = simsizes(sizes);str = ;x0 = ;ts = 0 0;simStateCompliance = DefaultSimState;function sys = mdlDerivatives(t,x,u,k)if(u(1)=1&u(2)=1&u(3)=1) k=1;elseif(u(1)=1&u(3)=0) k=2;u(2)=0& k=3; k=4;elseif(u(1)=0& k=5; k=6; k=7; k=8;switch u(4) if(k=1) SA=1; SB=1; SC=0; else if(k=2) SB=0; else if(k=3) SA=0; else if(k=4) SC=1; else if(k=5) else if(k=6) else if(k=7) else if(k=8) end case 2 elseif(k=7) case 4 elseif(k=5) case 5 elseif(k=6)
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1