你好,我想质询在BLPFC中若想改变开关频率,那么下面代码中的period、period_instr_pwm 、TBPRD这几个周期之间有什么关系,若想改变开关频率,怎么修改?
#define period 300
#define period_instr_pwm 120
// Configure PWM1 for 200Khz switching Frequency
PWM_1ch_UpDwnCnt_CNF(1, period, 1, 0);
// Configure PWM2 for 200Khz switching Frequency
PWM_1ch_UpDwnCnt_CNF(2, period, 0, 0);
// Configure PWM4 for Instrumentation; 1Mhz switching Frequency
PWM_1ch_UpDwnCnt_CNF(4, period_instr_pwm, 0, 0);
EALLOW;
SysCtrlRegs.PCLKCR1.bit.EPWM7ENCLK = 1; // ePWM7
// Setup TBCLK
EPwm7Regs.TBPRD = 3000; // Set timer period 3000 TBCLKs
EPwm7Regs.TBPHS.half.TBPHS = 0x0000; // Phase is 0
EPwm7Regs.TBCTR = 0x0000; // Clear counter
// Setup counter mode
EPwm7Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Count up
EPwm7Regs.TBCTL.bit.PHSEN = TB_DISABLE; // Disable phase loading
EPwm7Regs.TBCTL.bit.HSPCLKDIV = TB_DIV1; // Clock ratio to SYSCLKOUT
EPwm7Regs.TBCTL.bit.CLKDIV = TB_DIV1;
EPwm7Regs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO;
// Configure the Start of Conversion for the ADC.
EPwm7Regs.ETSEL.bit.INTEN = 1; //
EPwm7Regs.ETSEL.bit.INTSEL = ET_CTR_PRD; // Select Int from counter = PRD
EPwm7Regs.ETPS.bit.INTPRD = ET_1ST; // Generate pulse on 1st event
PieVectTable.EPWM7_INT = &SECONDARY_ISR;
IER |= M_INT3; // Enable CPU INT3 for capture interrupt
PieCtrlRegs.PIEIER3.bit.INTx7 = 1; // Enable EPWM7 int in PIE group 3
EDIS;
//sine analyzer initialization
sine_mainsV.Vin=0;
sine_mainsV.SampleFreq=_IQ15(10000.0);
sine_mainsV.Threshold=_IQ15(0.1);//(0.02);
// End sine analyzer initialization
#define IpfcR AdcResult.ADCRESULT1 //Q12
#define VbusR AdcResult.ADCRESULT2 //Q12
#define VL_fbR AdcResult.ADCRESULT3 //Q12
#define VN_fbR AdcResult.ADCRESULT4 //Q12
// ADC Channel Selection for C2000EVM
ChSel[0] = 2; // Dummy read for first
ChSel[1] = 2; // A2 - IpfcA
ChSel[2] = 6; // A6 - Vbus
ChSel[3] = 1; // A1 - VL_fb
ChSel[4] = 0; // A0 - VN_fb
// ADC Trigger Selection
TrigSel[0] = ADCTRIG_EPWM1_SOCA; // ePWM1, ADCSOCA
TrigSel[1] = ADCTRIG_EPWM1_SOCA; // ePWM1, ADCSOCA
TrigSel[2] = ADCTRIG_EPWM1_SOCA; // ePWM1, ADCSOCA
TrigSel[3] = ADCTRIG_EPWM1_SOCA; // ePWM1, ADCSOCA
TrigSel[4] = ADCTRIG_EPWM1_SOCA; // ePWM1, ADCSOCA
// Configure ADC
ADC_SOC_CNF(ChSel, TrigSel, ACQPS, 17, 0);
// Configure ePWMs to generate ADC SOC pulses
EPwm1Regs.ETSEL.bit.SOCAEN = 1; // Enable ePWM1 SOCA pulse
EPwm1Regs.ETSEL.bit.SOCASEL = ET_CTR_ZERO; // SOCA from ePWM1 Zero event
EPwm1Regs.ETPS.bit.SOCAPRD = ET_1ST; // Trigger ePWM1 SOCA on every event
DPL_Init();