Simulink仿真---SVPWM算法

一、理论

SVPWM算法的具体讲解在这里:https://blog.csdn.net/qlexcel/article/details/74787619

1、判断扇区

根据下面3个式子:


    再定义,若U1 > 0 ,则 A=1,否则 A=0; 

                  若U2 > 0 ,则B=1,否则 B=0;

                  若U3 > 0 ,则 C=1,否则 C=0。

    可以看出 A,B,C 之间共有八种组合,但由判断扇区的公式可知 A,B,C 不会同时为 1 或同时为 0,所以实际的组合是六种,A,B,C 组合取不同的值对应着不同的扇区,并且是一一对应的,因此完全可以由 A,B,C 的组合判断所在的扇区。为区别六种状态,令 N=4*C+2*B+A,则可以通过下表计算参考电压矢量Uref所在的扇区。

2、计算各矢量作用时间

Simulink仿真---SVPWM算法_第1张图片

        同理可求得Uref在其它扇区中各矢量的作用时间,结果如表2-4所示。表中两个非零矢量作用时间的比例系数为K =√3Ts/Udc 。

Simulink仿真---SVPWM算法_第2张图片

各扇区作用时间:

Simulink仿真---SVPWM算法_第3张图片

Simulink仿真---SVPWM算法_第4张图片

3、确定扇区矢量切换点(如扇区1中,矢量0到矢量4的切换点,矢量4到矢量6的切换点)

Simulink仿真---SVPWM算法_第5张图片

二、建模

1、添加扇区判断的子系统(根据输入的Ualpha和Ubeta判断电压矢量所在扇区):

Simulink仿真---SVPWM算法_第6张图片

switch模块设置为:(条件为u2>=0,如果满足u1通过,如果不满足,u3通过)

Simulink仿真---SVPWM算法_第7张图片

2、计算X、Y、Z,用于计算扇区矢量作用时间(输入Ualpha、Ubeta、母线电压Udc、载波周期时间Ts,计算X、Y、Z)。

Simulink仿真---SVPWM算法_第8张图片

3、根据N值和X、Y、Z来计算扇区中矢量的作用时间(输入XYZ、N值、载波周期Ts,计算扇区中矢量作用时间)

Simulink仿真---SVPWM算法_第9张图片

Mutiport Switch模块根据最上面输入的N值选择下面的那个端口通过。配置如下:

Simulink仿真---SVPWM算法_第10张图片

如:N=1,则Mutiport Switch模块输出为T1=Z、T2=Y,再根据Ts-Z-Y是否大于零来判断是否过调制。如果过调制,还要用上面给的比例公式,把Z和Y矫正一下再输出。

4、扇区矢量切换点的确定

Simulink仿真---SVPWM算法_第11张图片

实现上是计算3个PWM通道输出电平的改变点。我们知道SVPWM中定时器是配置为中央对齐模式:

Simulink仿真---SVPWM算法_第12张图片

要在每个载波周期中改变输出通道的比较值,而计算出的Tcm1、Tcm2、Tcm3分别就是3个通道的比较值。

Simulink仿真---SVPWM算法_第13张图片

5、计算出了每个载波周期3个通道的比较值,再引入定时器的中央对齐模式,就可以输出逆变桥的控制信号了。(此处用三角波模拟定时器中央对齐模式)

Simulink仿真---SVPWM算法_第14张图片

输入一个三角波模拟定时器中央对齐模式,用三角波当前值和通道比较值做对比,如果三角波的值大于通道比较值就输出高电平,如果小于就输出低电平。

Simulink仿真---SVPWM算法_第15张图片

6、使用3个通道的PWM控制逆变桥,计算相电压

Simulink仿真---SVPWM算法_第16张图片

以其中一种开关组合为例分析,假设Sx(x=a、b、c)=(100),此时等效电路如图:

因此相电压可以表示为:(相电压是每相相对于电机中间连接点的电压)

从电阻分压的原理,可以知道相电压共有4种输出:1/3Udc、-1/3Udc、2/3Udc、-2/3Udc。因此上面的模型中,根据3个通道的电平状态来判断相电压输出这4中电压中的哪一个。如Sa、Sb、Sc都输入1,则经过逻辑运算后,到了Product模块,从上到下依次为:0,0,0,0,因此输出0.

7、最后总模型为:

Simulink仿真---SVPWM算法_第17张图片

1)、正弦波信号源配置:

Simulink仿真---SVPWM算法_第18张图片Simulink仿真---SVPWM算法_第19张图片

输入角速度为100π,幅值为200,相位互差90度的正弦波。角速度为100π,则周期为0.02,频率为50Hz,这个是电压矢量的旋转速度,即3000RPM。如果是一对极电机,转速就为3000RPM。

2)、Tpwm模块输入载波周期,此处载波为5KHz,所以值为0.0002秒。

3)、三角波信号源配置:(即载波为5KHz)

Simulink仿真---SVPWM算法_第20张图片

8、仿真结果

N值变化的波形:

Simulink仿真---SVPWM算法_第21张图片

定时器通道比较值的波形,3个通道,波形呈马鞍形

Simulink仿真---SVPWM算法_第22张图片

定时器通道比较值的波形、三角载波、PWM控制波形:

Simulink仿真---SVPWM算法_第23张图片

放大:

Simulink仿真---SVPWM算法_第24张图片

扇区N和3个通道PWM控制波形:

Simulink仿真---SVPWM算法_第25张图片

相电压波形:

Simulink仿真---SVPWM算法_第26张图片

放大:

Simulink仿真---SVPWM算法_第27张图片

最后从下面位置加入powergui模块做FFT分析

Simulink仿真---SVPWM算法_第28张图片

仿真完后,双击powergui模块,打开FFT Analysis:

Simulink仿真---SVPWM算法_第29张图片

配置如下,分析Ua的基波幅值:

Simulink仿真---SVPWM算法_第30张图片

可以看到50Hz的基波幅值为199.9V,与实际值200V相符。此仿真结果验证了模型的正确性。

 

模型文件下载:https://download.csdn.net/download/qlexcel/11516270

注:模型来自《现代永磁同步电机控制原理及MATLAB仿真》__袁雷编著

你可能感兴趣的:(工具,Simulink仿真教程)