编码器学习STM32资料.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编码器学习STM32资料.doc

在输入捕获模式下,当检测到ICx信号上升/下降边沿时,计数器的当前值被存储在捕获比较寄存器TIMx_CCRx中。 当捕获事件发生时,相应的CCxIF 标志(TIMx_SR 寄存器) 被置1。如果中断或者DMA功能被使能,就会产生中断或者DMA请求。如果捕获发生时,CCxIF标志已经被置位,这时过采样标志CCxOF就会被置位。向CCxIF写0或者读去TIM_CCRx中的数据,将清除捕获标志。CCxOF位只能通过手动写入0进行清除。 假如我设置为上升沿捕获,那么当一个上升沿到来的时候,定时器当前的计数值(TIMx_CNT)就会写入TIMx_CCRx中。我们读取这个数据。等到下一个上升沿到了时,就会有另一个计数器值TIMx_CNT记录。根据这两个数据值差,我们能算出来输入数据的周期。当然,我们还有处理定时器溢出这个问题,定时器溢出了就不准了。 如果要测占空比,就需要同时捕获上升沿和下降沿。相邻两个上升沿之间的计数是输入的周期,相邻两次捕获(一个上升沿一个下降沿)之间的时间是占或者空的时间。根据这个可以计算占空比或者PPM之类的东西。 【实验内容】 本次实验,使用TIM4产生一个1K的频率输出,用TIM1进行捕获。并测出频率计算 TIM1 的时基单元配置:关于TIM1的时基设置问题前文已经讨论过了。这里只有一点需要明确的,就是为了尽量减少更新事件,将TIM_Period设置到最大即0xFFFF。定时器时钟设置成2M,这样定时器的更新频率就是30Hz,不会造成两次捕获之间产生多次更新。 TIM1的完整配置代码如下: void TIM1_ICConfig(void) { ? RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1,ENABLE); //?? //时基初始化 ? TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1; //死区控制用。 ? TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up;? //计数器方向 ? TIM_TimeBaseInitStructure.TIM_Prescaler = 84-1;?? //Timer clock = sysclock /(TIM_Prescaler+1) = 2M ? TIM_TimeBaseInitStructure.TIM_RepetitionCounter = 0; ? TIM_TimeBaseInitStructure.TIM_Period = 0xFFFF;??? //Period = (TIM counter clock / TIM output clock) - 1 = 40Hz?? ? TIM_TimeBaseInit(TIM1,TIM_TimeBaseInitStructure); ? TIM_ICInitStructure.TIM_Channel = TIM_Channel_1; ? TIM_ICInitStructure.TIM_ICFilter = 0; ? TIM_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising; ? TIM_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1; ? TIM_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; ? TIM_ICInit(TIM1,TIM_ICInitStructure); ? TIM_Cmd(TIM1,ENABLE); } TIM4的配置就是基本的输出配置,没什么可说的。代码如下: void TIM4_OCConfig(void) { ? RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4,ENABLE); ? TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1; ? TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up; ? TIM_TimeBaseInitStructure.TIM_Prescaler =? 0; ? TIM_TimeBaseInitStructure.TIM_RepetitionCounter =0; ? TIM_TimeBaseInitStructure.TIM_Period = 42000-1;?? //周期:42M/(42000)= 1K ?? ? TIM_TimeBase

文档评论(0)

love + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档