使用定时器触发ADC采样PWM正脉冲时刻的负载电压电流,触发ADC的定时器用的就是产生PWM的定时器,设置为上升沿触发,测试发现每个PWM周期内ADC被触发了两次,一次是PWM上升沿的时候,另一次是PWM低电平的时候,不知道为什么每个PWM周期内会触发第二次采样? 此外,如何确保ADC采样到PWM正脉冲的中间时刻呢? 测试波形 CH1: 定时器产生的其中一路PWM波形(两路PWM交替开启) CH2: ADC采样完成DMA中断函数-连续反转GPIO输出的波形 配置如下: 定时器4:产生两路PWM信号驱动负载,同时将输出触发设置为 Update Event触发ADC采样 ADC: 三个通道连续采样,由定时器4的上升沿触发,DMA循环模式搬运采样结果到内存-开启DMA中断 DMA中断:连续反转GPIO,便于用示波器观测采样时机 |
H7系列无法配置MPU
stmL5系列,HAL库如何设置Lpuart APB clock domain
求助:PMSM电机编码器线数(分辨率)为80000线,超过MCSDK5.4.8软件所能设置的最大线数65535,请问如何解决
invalid installation directord ,directord is not a previous STm32CubeMX installation and is not empy
为什么STM32L496RG第一次烧写程序后需要重新上下电才能正常执行程序?
STM32CubeMX 图标设计问题
6.12.1升级到6.13老是闪退
STM32CubeMX如何设置成中文界面?
为什么ETH配置中没有Advanced Parameters?
有关STM32CubeMX的问题
通常比较合适的做法是将代码放在完成中断的回调函数里。
所以放在 IRQhandler 里面很可能执行了两次。
不妨调试看看是不是这个原因。
你到底是基于PWM的比较事件触发ADC 还是基于ADC的周期性更新事件触发ADC;
你提到的上沿是模糊的说法,PWM输出可以自由配置,即使相同CCR和ARR值不同的输出模式,上下沿的位置会不同;
你现在到底是连续采样还是基于定时器触发才采样,基于你现在的配置,就是每次定时器更新事件触发3次采样。
你用到DMA完成中断,这个中断跟你一轮完成的数据个数有关,假设你现在传输3个数据为一轮,即发生三次采样后发生完成中断;
您好,
我的目的是每次定时器触发3个通道的ADC采样(每次触发每个通道都要采样一次),预期的采样时间是PWM输出为正的那段时间里(最好是正中间)。
谢谢!确实是这个原因导致的。
你好,我这里请教几个稍有偏离的问题,希望不会太麻烦你:
传输一半中断,是有什么用处?
是否可以关闭这个传输一半中断?
谢谢~