PWM笔记

PWM输入捕获和死区

PWM的周期计算:F=TIM_CLK/{(ARR+1)(PSC+1)}
为什么我们在配置周期的时候要减一是因为ARR的值是从0开始的,PSC的值在寄存器中会+1
在这里插入图片描述
ARR的值由TIM_TimeBaseStructure.TIM_Period 确定,PWM一个周期包括很多个CNT,具体多少个由ARR值确定。
PSC的值由TIM_TimeBaseStructure.TIM_Prescaler确定,TIM_CLK/(PSC+1) 得到CNT的周期。
TIM_SetCompare1(TIM_TypeDef
TIMx, uint16_t Compare1),通过这个函数配置比较值,控制输出的占空比Compare1/ARR。
死区时间配置,TIM_TimeBaseStructure.TIM_ClockDivision=TIM_CKD_DIV1; 代表一分频
周期=TIM_CLK/TIM_CKD_DIV1;
TIM_BDTRInitStructure.TIM_DeadTime = 11; 配置需要等待多少个周期

在这里插入图片描述
PWM的输入捕获:
配置输入捕获的频率一定要小于,输出的PWM波的频率。(且最好不要使用映射引脚)只有通道1和2可以进行输入捕获。
在这里插入图片描述
在这里插入图片描述
TIM_SelectInputTrigger(ADVANCE_TIM, TIM_TS_TI1FP1); 通过这个函数选择输入捕获的模式,采用周期捕获
TIM_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; 采用直连的方式即IC2的值代表高电平的宽度并把值锁存在CCR2寄存器中,IC1代表整个周期的宽度并把值锁存在CCR1寄存器中。
在中断服务函数中获取到的CCR1,CCR2的值也应该+1.

void ADVANCE_TIM_IRQHandler(void)
{
  /* 清除中断标志位 */
  TIM_ClearITPendingBit(ADVANCE_TIM, TIM_IT_CC1);

  /* 获取输入捕获值 */
  IC1Value = TIM_GetCapture1(ADVANCE_TIM);
  IC2Value = TIM_GetCapture2(ADVANCE_TIM);
	
  // 注意:捕获寄存器CCR1和CCR2的值在计算占空比和频率的时候必须加1
	if (IC1Value != 0)
  {
    /* 占空比计算 */
    DutyCycle = (float)((IC2Value+1) * 100) / (IC1Value+1);

    /* 频率计算 */
    Frequency = (72000000/(ADVANCE_TIM_PSC+1))/(float)(IC1Value+1);
		printf("占空比:%0.2f%%   频率:%0.2fHz\n",DutyCycle,Frequency);
  }
  else
  {
    DutyCycle = 0;
    Frequency = 0;
  }
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值