



版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、/ TI File $Revision: /main/8 $/ Checkin $Date: April 21, 200815:41:53 $/#/ FILE: Example_2833xEPwmUpDownAQ.c/ TITLE:空間電壓矢量產(chǎn)生程序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 on GPI
2、O1-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 found wi
3、thin this file. void InitEPwm1Example ( void );void InitEPwm2Example ( void ); void InitEPwm3Example ( void );voidsvpwmGen( void );interruptvoidsvpwm_isr( void );volatilefloatUalpha,Ubeta;volatilefloatA,B,C;volatilefloatT0,T1,T2,T3,T4,T5,T6;volatilefloatTaon,Tbon,Tcon;floatUa,Ub,Uc;floatTs;inta,b,c;
4、intN= 0,sector= 0;#defineTPRD 800#defineUdc 800voidmain ( void )/ Step 1. Initialize System Control:/ PLL, WatchDog, enable Peripheral Clocks/ This example function is found in the DSP2833x_SysCtrl.c file. InitSysCtrl();/ Step 2. Initalize GPIO:/ This example function is found in the DSP2833x_Gpio.c
5、 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, ePWM2, ePWM3/ These functions are in the DSP2833x_EPwm.c file InitEPwm1Gpio();InitEPwm2Gpio();InitEPwm3Gpio();/ Step 3. Clear all interrupts and init
6、ialize PIE vector table:/ Disable CPU interrupts DINT;/ Initialize the PIE control registers to their default state./ The default state is all PIE interrupts disabled and flags/ are cleared./ This function is found in the DSP2833x_PieCtrl.c file. InitPieCtrl();/ Disable CPU interrupts and clear all
7、CPU interrupt flags: IER = 0x0000;IFR = 0x0000;/ 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 foun
8、d in DSP2833x_DefaultIsr.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 registersPieVectTable.EPWM1_INT = &svpwm_isr;/PieVectTa
9、ble.EPWM2_INT = &epwm2_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 exa
10、mple, only initialize the ePWMInitEPwm1Example();InitEPwm2Example();InitEPwm3Example();/ Step 5. User specific code, enable interrupts:/ Enable CPU INT3 which is connected to EPWM1-3 INT: IER |= M_INT3;/ Enable global Interrupts and higher priority real-time debug events:EINT;/ Enable Global interru
11、pt INTMERTM;/ Enable Global realtime interrupt DBGM/ Step 6. IDLE loop. Just sit and loop forever (optional): for (;)asm( NOP); /main結(jié)束/=interruptvoidsvpwm_isr( void )svpwmGen();/ adjust duty for output EPWM1A/ adjust duty for output EPWM2A/ adjust duty for output EPWM3A/voidInitEPwm1Example()/ Setu
12、p TBCLKEPwm1Regs.TBPRD = TPRD;/ TPRD=800,Period = 1600 TBCLK countsEPwm1Regs.TBPHS.half.TBPHS = 0;/ Set Phase register to zeroEPwm1Regs.TBCTR = 0x0000;/ Clear counter/ Setup counter modeEPwm1Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN;/ Symmetrical modeEPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE;/Master mod
13、uleEPwm1Regs.TBCTL.bit.PRDLD = TB_SHADOW;EPwm1Regs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO;/ Syncdown-stream module/ Setup TpwmEPwm1Regs.TBCTL.bit.HSPCLKDIV = TB_DIV2;/ Clock ratio to SYSCLKOUTEPwm1Regs.TBCTL.bit.CLKDIV = 5;/ 原為 TB_DIV1 , 對(duì)于上下計(jì)數(shù): Tpwm = 2 xTBPRD x TTBCLK Fpwm = 1 / (Tpwm)/Setup shadowingEP
14、wm1Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;EPwm1Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;EPwm1Regs.CMPCTL.bit.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.bi
15、t.CAD = AQ_CLEAR;/ Set Dead-bandEPwm1Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;/ enable Dead-band moduleEPwm1Regs.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 ValuesEPwm
16、1Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO;/ Select INT on Zero eventEPwm1Regs.ETSEL.bit.INTEN = 1;/ Enable INTEPwm1Regs.ETPS.bit.INTPRD = ET_3RD;/ Generate INT on 3rd event/*/*/voidInitEPwm2Example()/ Setup TBCLKEPwm2Regs.TBPRD = TPRD;/ TPRD=800,Period = 1600 TBCLK counts/ Set Phase register to zeroEPwm2
17、Regs.TBCTR = 0x0000;/ Clear counter/ Setup counter mode/ Symmetrical mode/ Slavemodule/ syncflow-through/ Setup Tpwm/ Clock ratio to SYSCLKOUT= 5;/For Up and Down Count-Tpwm= 2 x TBPRDx TTBCLK; Fpwm = 1 / (Tpwm)/EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;/ load on CTR=ZeroEPwm2Regs.CMPCTL.bit.LOAD
18、BMODE = 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;/ Active Hi complementaryEPw
19、m2Regs.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;/ Generate INT on 3rd event/ Set
20、 Compare valuesvoidInitEPwm3Example()/ Setup TBCLKEPwm3Regs.TBPRD = TPRD;/ TPRD=800,Period = 1600 TBCLK counts/ Set Phase register to zeroEPwm1Regs.TBCTR = 0x0000;/ Clear counter/ Setup counter mode/ Symmetrical mode/ Slavemodule/ syncflow-through/ Setup Tpwm/ Clock ratio to SYSCLKOUT= 5;/ForUp and
21、Down Count:Tpwm= 2 x TBPRDx TTBCLK; Fpwm = 1 / (Tpwm)/EPwm3Regs.CMPCTL.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-ba
22、ndEPwm3Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;/ enable Dead-band 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_CT
23、R_ZERO;/ Select INT on Zero eventEPwm3Regs.ETSEL.bit.INTEN = 1;/ Enable INTEPwm3Regs.ETPS.bit.INTPRD = ET_3RD;/ Generate INT on 3rd event/ Set Compare valuesvoidsvpwmGen( void )/clarkeUalpha= 0.6666667*(Ua-0.5*Ub-0.5*Uc);/ 0.8660254 = sqrt(3)/2Ubeta = 0.6666667*(0.8660254*Ub-0.8660254*Uc );/0.666666
24、7=2/3/sectorA= Ubeta;B= 1.7320508*Ualpha-Ubeta;C= -1.7320508*Ualpha-Ubeta;if(A= 0) a= 1;elsea= 0;if(B= 0) b= 1;elseb= 0;if(C= 0) c= 1;elsec= 0;N=a+2*b+4*c;switch(N)case 1: sector = 2;break ;case 2: sector = 6;break ;case 3: sector = 1;break ;case 4: sector = 4;break ;case 5: sector = 3;break ;case 6
25、: sector = 5;break ;default:break ;/TimeTs=2*TPRD; /Ts 為開關(guān)周期與載波周期(計(jì)數(shù)周期)相等 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*Ts/(T1+T2);T2= T2*Ts/(T1+T2);T0= Ts-T1-T2;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/(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= T
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 高效救援演練的應(yīng)急處置與快速響應(yīng)能力提升
- 貴州省六盤水市第二十中學(xué)2024年化學(xué)九年級(jí)第一學(xué)期期末監(jiān)測(cè)模擬試題含解析
- 2025至2030肝硬化治療行業(yè)產(chǎn)業(yè)運(yùn)行態(tài)勢(shì)及投資規(guī)劃深度研究報(bào)告
- 四川省成都市天府第七中學(xué)2024-2025學(xué)年八年級(jí)數(shù)學(xué)第一學(xué)期期末調(diào)研試題含解析
- 常州勞動(dòng)合同試用期管理規(guī)范
- 交通事故理賠催告函模板定制合同
- 網(wǎng)絡(luò)直播產(chǎn)業(yè)發(fā)展計(jì)劃及盈利模式探索報(bào)告
- 中國(guó)汽車拆解行業(yè)自動(dòng)化改造的市場(chǎng)趨勢(shì)預(yù)測(cè)報(bào)告
- 環(huán)保創(chuàng)意大賽組織流程
- 2025至2030中國(guó)自動(dòng)紙箱封口機(jī)行業(yè)市場(chǎng)深度研究及發(fā)展前景投資可行性分析報(bào)告
- 中醫(yī)院人才引進(jìn)績(jī)效考核方案
- 高速公路施工安全培訓(xùn)課件
- 2024年中級(jí)經(jīng)濟(jì)師考試經(jīng)濟(jì)基礎(chǔ)知識(shí)必考重點(diǎn)總結(jié)全覆蓋
- 轉(zhuǎn)崗人員安全知識(shí)培訓(xùn)
- 寧夏石嘴山市礦業(yè)(集團(tuán))有限責(zé)任公司招聘筆試題庫(kù)2024
- 網(wǎng)絡(luò)設(shè)備安裝調(diào)試作業(yè)指導(dǎo)書
- 鐵嶺三支一扶真題2023
- 2024年省石棉縣人力資源和社會(huì)保障局關(guān)于公開考核招考綜合類事業(yè)單位工作人員高頻考題難、易錯(cuò)點(diǎn)模擬試題(共500題)附帶答案詳解
- 人工智能數(shù)據(jù)標(biāo)注 課件
- 骨折病的中醫(yī)分型及治療
- (高清版)TDT 1068-2022 國(guó)土空間生態(tài)保護(hù)修復(fù)工程實(shí)施方案編制規(guī)程
評(píng)論
0/150
提交評(píng)論