STM32 F207的PWM输入捕获频率和占空比(2)
- UID
- 1029342
- 性别
- 男
|
STM32 F207的PWM输入捕获频率和占空比(2)
//中断处理,这里看到用全局变量tim_cnt对一自然数取余,就可以随意调整占空比了,例如tim_cnt累加到4的倍数才拉高,其余全为低电平,那高电平占空比就是1/4=25%
void TIM3_IRQHandler(void)
{
//int i;
if (TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET) //检查指定的TIM中断发生与否:TIM 中断源
{
if((tim_cnt%4) == 0)
GPIO_SetBits(GPIOD, GPIO_Pin_0);
else
GPIO_ResetBits(GPIOD, GPIO_Pin_0);
tim_cnt++;
TIM_ClearITPendingBit(TIM3, TIM_IT_Update);
}
}
//这个定时器就是计算PWM信号的频率和占空比了
void TIM2_IRQHandler(void)
{
RCC_ClocksTypeDef RCC_Clocks;
RCC_GetClocksFreq(&RCC_Clocks);
/* Clear TIM2 Capture compare interrupt pending bit */
TIM_ClearITPendingBit(TIM2, TIM_IT_CC2);
/* Get the Input Capture value */
IC2Value = TIM_GetCapture2(TIM2);
//printf("IC2Value:%d!!!\r\n",IC2Value);
if (IC2Value != 0)
{
/* Duty cycle computation */
IC1Value = TIM_GetCapture1(TIM2);
DutyCycle = (IC1Value * 100) / IC2Value;
/* Frequency computation */
Frequency = (RCC_Clocks.HCLK_Frequency) / 2 / IC2Value;
//Frequency = 30000000 / IC2Value;
//printf("clk:%d!!!\r\n",RCC_Clocks.HCLK_Frequency);
}
else
{
DutyCycle = 0;
Frequency = 0;
}
}
对于这个函数的理解,引用博文http://blog.sina.com.cn/s/blog_63d525fd0100u9o3.html的片段的解释
PWM输入捕获模式是输入捕获模式的特例,自己理解如下
1. 每个定时器有四个输入捕获通道IC1、IC2、IC3、IC4。且IC1 IC2一组,IC3 IC4一组。并且可是设置管脚和寄存器的对应关系。
2. 同一个TIx输入映射了两个ICx信号。
3. 这两个ICx信号分别在相反的极性边沿有效。
4. 两个边沿信号中的一个被选为触发信号,并且从模式控制器被设置成复位模式。
5. 当触发信号来临时,被设置成触发输入信号的捕获寄存器,捕获“一个PWM周期(即连续的两个上升沿或下降沿)”,它等于包含TIM时钟周期的个数(即捕获寄存器中捕获的为TIM的计数个数n)。
6. 同样另一个捕获通道捕获触发信号和下一个相反极性的边沿信号的计数个数m,即(即高电平的周期或低电平的周期)
7. 由此可以计算出PWM的时钟周期和占空比了
frequency=f(TIM时钟频率)/n。
duty cycle=(高电平计数个数/n),
若m为高电平计数个数,则duty cycle=m/n
若m为低电平计数个数,则duty cycle=(n-m)/n
注:因为计数器为16位,所以一个周期最多计数65535个,所以测得的 最小频率= TIM时钟频率/65535。
根据计算器是65535,可想而知,PWM的频率范围大致是1k~1M之间,所以定时器3的周期时间要根据D0的占空比来调整,保证整的周期时间在1K和1M之间.如果要将占空比调整为10,那么TIM3的定时只能小于0.1mS了,当然这个办法有点傻,完全可以不用这么做
打印出来的结果是 DutyCycle:24, Frequency:980
根据上面的设置算一下是正确的,因为每个PWM信号4次TIM3的时间即1mS,高电平占四分之一即25%,有点误差 |
|
|
|
|
|