2022年svpwm源程序 .pdf

上传人:Che****ry 文档编号:24178202 上传时间:2022-07-03 格式:PDF 页数:11 大小:54.43KB
返回 下载 相关 举报
2022年svpwm源程序 .pdf_第1页
第1页 / 共11页
2022年svpwm源程序 .pdf_第2页
第2页 / 共11页
点击查看更多>>
资源描述

《2022年svpwm源程序 .pdf》由会员分享,可在线阅读,更多相关《2022年svpwm源程序 .pdf(11页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、/ TI File $Revision: /main/8 $/ Checkin $Date: April 21, 2008 15:41:53 $/#/ FILE: Example_2833xEPwmUpDownAQ.c/ TITLE: 空间电压矢量产生程序SVPWM/ ASSUMPTIONS:/ This program requires the DSP2833x header files. / Monitor ePWM1-ePWM3 pins on an oscilloscope as described/ below./ EPWM1A is on GPIO0-5脚/ EPWM1B is o

2、n GPIO1-6脚/ EPWM2A is on GPIO2-7脚/ EPWM2B is on GPIO3-10脚/ EPWM3A is on GPIO4-11脚/ EPWM3B is on GPIO5-12脚/#/ $TI Release: DSP2833x/DSP2823x Header Files V1.20 $/ $Release Date: August 1, 2008 $/#includeDSP28x_Project.h/ Device Headerfile and Examples Include File/ Prototype statements for functions

3、found within this file.voidInitEPwm1Example( void ); voidInitEPwm2Example( void ); voidInitEPwm3Example( void ); voidsvpwmGen( void ); interruptvoidsvpwm_isr( void ); volatilefloat Ualpha,Ubeta; volatilefloat A,B,C; 名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - -

4、 - 第 1 页,共 11 页 - - - - - - - - - volatilefloat T0,T1,T2,T3,T4,T5,T6; volatilefloat Taon,Tbon,Tcon; float Ua,Ub,Uc; float Ts; int a,b,c; int N= 0,sector= 0; #define TPRD 800 #define Udc 800 voidmain ( void ) / Step 1. Initialize System Control:/ PLL, WatchDog, enable Peripheral Clocks/ This example

5、function is found in the DSP2833x_SysCtrl.c file. InitSysCtrl(); / Step 2. Initalize GPIO: / This example function is found in the DSP2833x_Gpio.c file and/ illustrates how to set the GPIO to its default state./ InitGpio(); / Skipped for this example / For this case just init GPIO pins for ePWM1, eP

6、WM2, ePWM3/ These functions are in the DSP2833x_EPwm.c file InitEPwm1Gpio(); InitEPwm2Gpio(); InitEPwm3Gpio(); / Step 3. Clear all interrupts and initialize PIE vector table:/ Disable CPU interrupts DINT; / Initialize the PIE control registers to their default state./ The default state is all PIE in

7、terrupts disabled and flags/ are cleared. / This function is found in the DSP2833x_PieCtrl.c file. InitPieCtrl(); / Disable CPU interrupts and clear all CPU interrupt flags: IER = 0 x0000; 名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 2 页,共 11 页 - - - - - -

8、 - - - IFR = 0 x0000; / Initialize the PIE vector table with pointers to the shell Interrupt / Service Routines (ISR). / This will populate the entire table, even if the interrupt/ is not used in this example. This is useful for debug purposes./ The shell ISR routines are found in DSP2833x_DefaultIs

9、r.c./ This function is found in DSP2833x_PieVect.c. InitPieVectTable(); / Interrupts that are used in this example are re-mapped to/ ISR functions found within this file. EALLOW; / This is needed to write to EALLOW protected registers PieVectTable.EPWM1_INT = &svpwm_isr; /PieVectTable.EPWM2_INT = &e

10、pwm2_isr;/PieVectTable.EPWM3_INT = &epwm3_isr; EDIS; / This is needed to disable write to EALLOW protected registers/ Step 4. Initialize all the Device Peripherals:/ This function is found in DSP2833x_InitPeripherals.c/ InitPeripherals(); / Not required for this example/ For this example, only initi

11、alize the ePWM EALLOW; SysCtrlRegs.PCLKCR0.bit.TBCLKSYNC = 0; EDIS; InitEPwm1Example(); InitEPwm2Example(); InitEPwm3Example(); EALLOW; SysCtrlRegs.PCLKCR0.bit.TBCLKSYNC = 1; EDIS; / Step 5. User specific code, enable interrupts:/ Enable CPU INT3 which is connected to EPWM1-3 INT: IER |= M_INT3; / E

12、nable EPWM INTn in the PIE: Group 3 interrupt 1-3 PieCtrlRegs.PIEIER3.bit.INTx1 = 1; 名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 3 页,共 11 页 - - - - - - - - - /PieCtrlRegs.PIEIER3.bit.INTx2 = 1;/PieCtrlRegs.PIEIER3.bit.INTx3 = 1;/ Enable global Interrupts

13、and higher priority real-time debug events: EINT; / Enable Global interrupt INTM ERTM; / Enable Global realtime interrupt DBGM / Step 6. IDLE loop. Just sit and loop forever (optional):for (;) asm( NOP); /main结束/=interruptvoidsvpwm_isr( void ) svpwmGen(); / Set Compare valuesEPwm1Regs.CMPA.half.CMPA

14、 = Taon; / adjust duty for output EPWM1AEPwm2Regs.CMPA.half.CMPA = Tbon; / adjust duty for output EPWM2AEPwm3Regs.CMPA.half.CMPA = Tcon; / adjust duty for output EPWM3A/ Clear INT flag for this timerEPwm1Regs.ETCLR.bit.INT = 1; / Acknowledge this interrupt to receive more interrupts from group 3PieC

15、trlRegs.PIEACK.all = PIEACK_GROUP3; voidInitEPwm1Example() 名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 4 页,共 11 页 - - - - - - - - - / Setup TBCLKEPwm1Regs.TBPRD = TPRD; / TPRD=800,Period = 1600 TBCLK countsEPwm1Regs.TBPHS.half.TBPHS = 0; / Set Phase regis

16、ter to zeroEPwm1Regs.TBCTR = 0 x0000; / Clear counter/ Setup counter modeEPwm1Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN;/ Symmetrical modeEPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE; /Master moduleEPwm1Regs.TBCTL.bit.PRDLD = TB_SHADOW; EPwm1Regs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO; / Sync down-stream module/

17、 Setup TpwmEPwm1Regs.TBCTL.bit.HSPCLKDIV = TB_DIV2; / Clock ratio to SYSCLKOUTEPwm1Regs.TBCTL.bit.CLKDIV = 5; / 原为 TB_DIV1 , 对于上下计数:Tpwm = 2 x TBPRD x TTBCLK Fpwm = 1 / (Tpwm)/Setup shadowingEPwm1Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW; EPwm1Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW; EPwm1Regs.CMPCTL.bit.

18、LOADAMODE = CC_CTR_ZERO; / load on CTR=ZeroEPwm1Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; / load on CTR=Zero/ Set actionsEPwm1Regs.AQCTLA.bit.CAU = AQ_SET; / set actions for EPWM1AEPwm1Regs.AQCTLA.bit.CAD = AQ_CLEAR; / Set Dead-bandEPwm1Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE; / enable Dead-band mod

19、uleEPwm1Regs.DBCTL.bit.POLSEL = DB_ACTV_HIC; / Active Hi complementaryEPwm1Regs.DBFED = 50; / FED = 50 TBCLKsEPwm1Regs.DBRED = 50; / RED = 50 TBCLKs/ Interrupt where we will change the Compare ValuesEPwm1Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO; / Select INT on Zero eventEPwm1Regs.ETSEL.bit.INTEN = 1; /

20、Enable INTEPwm1Regs.ETPS.bit.INTPRD = ET_3RD; / Generate INT on 3rd event /*/ Set Compare values/=EPwm1Regs.CMPA.half.CMPA = 500; / adjust duty for output EPWM1AEPwm2Regs.CMPA.half.CMPA = 600; / adjust duty for output EPWM2AEPwm3Regs.CMPA.half.CMPA = 700; / adjust duty for output EPWM3A*/名师归纳总结 精品学习

21、资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 5 页,共 11 页 - - - - - - - - - voidInitEPwm2Example() / Setup TBCLKEPwm2Regs.TBPRD = TPRD; / TPRD=800,Period = 1600 TBCLK countsEPwm2Regs.TBPHS.half.TBPHS = 0; / Set Phase register to zeroEPwm2Regs.TBCTR = 0 x0000; / Clear c

22、ounter/ Setup counter modeEPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN;/ Symmetrical modeEPwm2Regs.TBCTL.bit.PHSEN = TB_ENABLE; / Slave moduleEPwm2Regs.TBCTL.bit.PRDLD = TB_SHADOW; EPwm2Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN; / sync flow-through/ Setup TpwmEPwm2Regs.TBCTL.bit.HSPCLKDIV = TB_DIV2; / C

23、lock ratio to SYSCLKOUTEPwm2Regs.TBCTL.bit.CLKDIV = 5; / For Up and Down Count-Tpwm = 2 x TBPRD x TTBCLK; Fpwm = 1 / (Tpwm)/ Setup shadowingEPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW; EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW; EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; / load on CTR=ZeroEPwm2Reg

24、s.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; / load on CTR=Zero/ Set actionsEPwm2Regs.AQCTLA.bit.CAU = AQ_SET; / set actions for EPWM2AEPwm2Regs.AQCTLA.bit.CAD = AQ_CLEAR; / Set Dead-bandEPwm2Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE; / enable Dead-band moduleEPwm2Regs.DBCTL.bit.POLSEL = DB_ACTV_HIC; / Acti

25、ve Hi complementaryEPwm2Regs.DBFED = 50; / FED = 50 TBCLKsEPwm2Regs.DBRED = 50; / RED = 50 TBCLKs/ Interrupt where we will change the Compare ValuesEPwm2Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO; / Select INT on Zero eventEPwm2Regs.ETSEL.bit.INTEN = 1; / Enable INTEPwm2Regs.ETPS.bit.INTPRD = ET_3RD; / Gen

26、erate INT on 3rd event / Set Compare values 名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 6 页,共 11 页 - - - - - - - - - voidInitEPwm3Example() / Setup TBCLKEPwm3Regs.TBPRD = TPRD; / TPRD=800,Period = 1600 TBCLK countsEPwm3Regs.TBPHS.half.TBPHS = 0; / Set Pha

27、se register to zeroEPwm1Regs.TBCTR = 0 x0000; / Clear counter/ Setup counter modeEPwm3Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN;/ Symmetrical modeEPwm3Regs.TBCTL.bit.PHSEN = TB_ENABLE; / Slave moduleEPwm3Regs.TBCTL.bit.PRDLD = TB_SHADOW; EPwm3Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN; / sync flow-through/

28、 Setup TpwmEPwm3Regs.TBCTL.bit.HSPCLKDIV = TB_DIV2; / Clock ratio to SYSCLKOUTEPwm3Regs.TBCTL.bit.CLKDIV = 5; / For Up and Down Count:Tpwm = 2 x TBPRD x TTBCLK; Fpwm = 1 / (Tpwm)/ Setup shadowingEPwm3Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW; EPwm3Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW; EPwm3Regs.CMPCTL.

29、bit.LOADAMODE = CC_CTR_ZERO; / load on CTR=ZeroEPwm3Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; / load on CTR=Zero/ Set actionsEPwm3Regs.AQCTLA.bit.CAU = AQ_SET; / set actions for EPWM3AEPwm3Regs.AQCTLA.bit.CAD = AQ_CLEAR; / Set Dead-bandEPwm3Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE; / enable Dead-band

30、 moduleEPwm3Regs.DBCTL.bit.POLSEL = DB_ACTV_HIC; / Active Hi complementaryEPwm3Regs.DBFED = 50; / FED = 50 TBCLKsEPwm3Regs.DBRED = 50; / RED = 50 TBCLKs/ Interrupt where we will change the Compare ValuesEPwm3Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO; / Select INT on Zero eventEPwm3Regs.ETSEL.bit.INTEN = 1

31、; / Enable INTEPwm3Regs.ETPS.bit.INTPRD = ET_3RD; / Generate INT on 3rd event / Set Compare values 名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 7 页,共 11 页 - - - - - - - - - voidsvpwmGen( void ) /clarke Ualpha= 0.6666667*(Ua-0.5*Ub-0.5*Uc);/ 0.8660254 = sqr

32、t(3)/2 Ubeta = 0.6666667*(0.8660254*Ub-0.8660254*Uc );/0.6666667=2/3/sector A= Ubeta; B= 1.7320508*Ualpha-Ubeta; C= -1.7320508*Ualpha-Ubeta; if(A= 0) a= 1; else a= 0; if(B= 0) b= 1; else b= 0; if(C= 0) c= 1; else c= 0; N=a+2*b+4*c; switch(N) case 1: sector = 2; break ; case 2: sector = 6; break ; ca

33、se 3: sector = 1; break ; case 4: sector = 4; break ; case 5: sector = 3; break ; case 6: sector = 5; break ; default: break ; /Time Ts=2*TPRD;/Ts为开关周期与载波周期(计数周期)相等if (sector= 1) T1= 1.5*Ts*(Ualpha-0.5773503*Ubeta)/Udc;/0.5773503=1/sqrt(3) T2= 1.7320508*Ts*Ubeta/Udc; T0= Ts-T1-T2; if(T1+T2Ts) T1= T1

34、*Ts/(T1+T2); T2= T2*Ts/(T1+T2); T0= Ts-T1-T2; 名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 8 页,共 11 页 - - - - - - - - - elseif (sector= 2) T2= 1.5*Ts*(Ualpha+0.5773503*Ubeta)/Udc; T3= 1.5*Ts*(0.5773503*Ubeta-Ualpha)/Udc; T0= Ts-T2-T3; if(T2+T3Ts) T2= T2*Ts

35、/(T2+T3); T3= T3*Ts/(T2+T3); T0= Ts-T2-T3; elseif (sector= 3) T3= 1.7320508*Ts*Ubeta/Udc; T4= 1.5*Ts*(Ualpha+0.5773503*Ubeta)/Udc; T0= Ts-T3-T4; if(T3+T4Ts) T3= T3*Ts/(T3+T4); T4= T4*Ts/(T3+T4); T0= Ts-T3-T4; elseif (sector= 4) T4= 1.5*Ts*(0.5773503*Ubeta-Ualpha)/Udc;/0.5773503=1/sqrt(3) T5= 1.73205

36、08*Ts*Ubeta/Udc; T0= Ts-T4-T5; if(T4+T5Ts) T4= T4*Ts/(T4+T5); T5= T5*Ts/(T4+T5); T0= Ts-T4-T5; 名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 9 页,共 11 页 - - - - - - - - - elseif (sector= 5) T5= -1.5*Ts*(Ualpha+0.5773503*Ubeta)/Udc; T6= -1.5*Ts*(0.5773503*Ube

37、ta-Ualpha)/Udc; T0= Ts-T5-T6; if(T5+T6Ts) T5= T5*Ts/(T5+T6); T6= T6*Ts/(T5+T6); T0= Ts-T5-T6; elseif (sector= 6) T6= -1.7320508*Ts*Ubeta/Udc; T1= 1.5*Ts*(Ualpha+0.5773503*Ubeta)/Udc; T0= Ts-T6-T1; if(T6+T1Ts) T6= T6*Ts/(T6+T1); T1= T1*Ts/(T6+T1); T0= Ts-T6-T1; /Switch Timeswitch(sector) case 1: Taon

38、= T0/4+T1/2+T2/2; Tbon= T0/4+T2/2; Tcon= T0/4; break ; case 2: 名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 10 页,共 11 页 - - - - - - - - - Taon= T0/4+T3/2; Tbon= T0/4+T2/2+T3/2; Tcon= T0/4; break ; case 3: Taon= T0/4; Tbon= T0/4+T3/2+T4/2; Tcon= T0/4+T4/2;

39、break ; case 4: Taon= T0/4; Tbon= T0/4+T5/2; Tcon= T0/4+T4/2+T5/2; break ; case 5: Taon= T0/4+T6/2; Tbon= T0/4; Tcon= T0/4+T5/2+T6/2; break ; case 6: Taon= T0/4+T6/2+T1/2; Tbon= T0/4; Tcon= T0/4+T1/2; break ; default: break ; /svpwmGen(void)结束名师归纳总结 精品学习资料 - - - - - - - - - - - - - - -精心整理归纳 精选学习资料 - - - - - - - - - - - - - - - 第 11 页,共 11 页 - - - - - - - - -

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 高考资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com