完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我正在使用 Nucleo F446ZE 来测试定时器功能以制作峰值保持 PWM 驱动器。我已经拥有核心功能,其中 tiM1 使用 DMA 以较高频率(例如 5 kHz)为高端 mosfet 运行可变占空比缓冲区。TIM2 由 TIM1 触发,为低侧 mosfet 产生低频(例如 1 Hz)同步信号。 我现在遇到的问题是制作与前两个同步但具有可编程相移的第三个定时器输出。事实上,我确实有代码可以生成如图所示的同步相移信号,但存在一个问题。 图片图例:TIM1 高频(黄色)、TIM2 低频(青色)、TIM2 相移下降沿触发(品红色)和 TIM3 相移信号(蓝色)。 应该发生的是蓝线在品红色线的下降沿处变高,如示波器图像的第二半部分所示。这种方法确实有效,除了示波器图像的第一半部分中看到的第一个输出周期;蓝线与所有其他定时器输出一起变高,而不是被延迟。 我的制作方法是(代码如下):
我知道这里还有其他线程显示使用一种脉冲模式来执行此操作。我试过了,但问题是一个脉冲有一个最小的非零延迟。我将它与高速相机一起使用,大部分时间我都不需要延迟,所以它不会起作用。该解决方案在编程时没有延迟,第一个脉冲除外。 启动定时器的代码
|
|
相关推荐
1个回答
|
|
我不了解 Cube/HAL gobbledygook,如果你想做一些不同于平常的事情,你也许也应该求助于注册编程,完全控制你正在做的事情。
造成差异的不是单脉冲模式,而是使用另一个极性 PWM(即在周期的第二部分产生高输出)。这里的问题是,一旦启用 PWM 输出,它就会开始比较 CNT - 处于 0,等待触发 - 与 CCRx,输出相应的电平,在你的情况下,第一部分为高电平时期。 在 'F446 上可能很难实现您想要的(在较新的 STM32 上,可能会使用组合的 Reset+Trigger 模式,并适当预加载 CCRx)。您可能需要设置 TIMx_CR2.CCPC 以启用 CCxE 预加载,只有在设置 TIMx_CCER.CCxE 之后才能使启用进入预加载寄存器;通过设置 TIMx_CR2.CCUS,TRGI 触发器不仅会启动定时器,还会将 CCxE 位从预加载加载到“活动”。 |
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2558 浏览 1 评论
3186 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1753 浏览 1 评论
3583 浏览 6 评论
5960 浏览 21 评论
918浏览 4评论
1296浏览 4评论
在Linux上安装Atollic TRUEStudio的步骤有哪些呢?
560浏览 3评论
使用DMA激活某些外设会以导致外设无法工作的方式生成代码是怎么回事
1282浏览 3评论
1334浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-10-31 20:02 , Processed in 1.044186 second(s), Total 79, Slave 62 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号