pwm一个时间单位_天哪!原来PWM这么简单

本文详细介绍了PWM(脉冲宽度调制)的基本原理,包括占空比的概念及其对波形平均值的影响。通过比较载波(锯齿波或三角波)与调制波,解释了PWM的生成机制,并探讨了不同类型的PWM波形,如中央对齐PWM。此外,还展示了基于STM32的PWM程序实现,用于创建呼吸灯效果。
摘要由CSDN通过智能技术生成

目录

  • 基本原理

  • PWM是如何实现?

  • 分类

  • 程序实现

  • 总结

基本原理

PWM的全称是脉冲宽度调制(Pulse-width modulation),是通过将有效的电信号分散成离散形式从而来降低电信号所传递的平均功率的一种方式;

所以根据面积等效法则,可以通过对改变脉冲的时间宽度,来等效的获得所需要合成的相应幅值频率的波形;

具体如下图所示;

3ccb86894db3d530897b54f06ff7fd32.png

由上图可知,脉冲宽度调制使用一个脉冲宽度会被调制的方波,并且波型的平均值会有所变化。

如果我们考虑一个周期为 的脉冲波 ,低值 ,高值为 ,跟占空比(duty cycle),此波的平均值为:

当 是一个脉冲波,它的值在 是 而在 是

上式的描述可以变为:

以上公式可以在很多状况下被简化,当 及 。

从这里可以看出,波型的平均值非常明显地直接与占空比 有关。

占空比

图中存在三种占空比状态,25%50%75%占空比状态,不难发现,假设占空比为D,则满足:

其中是PWM的周期,通常和载波的周期相同;

PWM是如何实现?

PWM实现的原理是通过锯齿波/三角波(载波)所需要合成的波形(调制波)进行比较,然后确定PWM所需要输出的极性,通常是ON或者是OFF,因为一般都是作用到开关元器件上;如下图所示;

a4ddc57cbf39bac492009e1fe4b18393.png
振荡器和比较器

振荡器输出的锯齿波和参考值 进行比较,然后就可以输出PWM波形了;

matlabsimulink中搭建了一下仿真,具体如下图所示;

8446b77273975fe14147b7bca74bebec.png
simulink

最终输出波形如下:

244836c447e57f551d9db5d1c962bc66.png
50%占空比

这里简单说明一下:

  • 锯齿波(图中橙色波形)最大为10,然后我希望输出平均为5的波形(图1中红色的水平直线);
  • 那么通过比较,当锯齿波小于5时;PWM输出低电平,即为OFF
  • 当锯齿波大于5时,PWM输出高电平,即为ON

所以再换一个思路,如果我希望输出一个电压逐渐升高的波形呢,该如何设计呢?

其实很简单,只要把需要调制的波形设置为斜坡输出的波形就可以了,具体如下图所示;

69fbda8f783eb304ade7bb300c0cc88b.png
占空比逐渐增大

可以看到,最终占空比逐渐从0%增大到100%

然后我们继续想,能不能调制出其他的波形,比如调制一个正弦波sin wave,那也就是我们常说的SPWM,其实是可以的,具体如下图所示;

e2072700616debaac4715a5576bc77aa.png
SPWM

分类

参考STM32中PWM的配置,根据载波波形的形状,假设三角波最大值是10,那么它的变化过程可能存在以下两种情况:

  • 完整周期包括两个过程,先递增,再递减:增加增加减少减少,这种也叫中央对齐PWM;
  • 完整周期只有递增过程:增加增加;

中央对齐PWM

脉冲波的中心将会被固定在时间窗格的中心,同时脉冲波的两边可以移动,使得波的宽度被延伸或压缩,具体如下图所示;

9e6f72128f61c32e1abefd00a8334c8d.png
中央对齐PWM

另一种类型的PWM脉冲波形如下图所示;

0a401301da90528f7a329e81673afb19.png

程序实现

现在的MCU大部分都自带硬件PWM发生器,即配置好相应的寄存器,就能直接产生PWM,下面的例子基于NUCLEO-F767ZI,通过cubemx配置了三路PWM输出,然后实现了呼吸灯的效果;

int main(void){

 HAL_Init();

 MX_GPIO_Init();
 MX_TIM4_Init();
 MX_TIM3_Init();
 MX_TIM12_Init();

 int32_t time_stamp = 0;
 int32_t time_stamp_old = 0;
 int32_t ccr_val = 0;
 uint8_t add_flag = 1;
 HAL_TIM_PWM_Start(&htim4, TIM_CHANNEL_2);
 HAL_TIM_PWM_Start(&htim12, TIM_CHANNEL_1);
 HAL_TIM_PWM_Start(&htim3, TIM_CHANNEL_3); 
 while (1)
 {
   time_stamp = HAL_GetTick();
   if(time_stamp - time_stamp_old > 5){
   time_stamp_old = time_stamp;
   if(add_flag){
    ccr_val+=25;
    if(ccr_val >= 0xFFFF){
    ccr_val = 0xFFFF;
    add_flag = 0;
   }
   }else{
    ccr_val-=25;
    if(ccr_val <= 0){
     add_flag = 1;
     ccr_val = 0;
    }
   }
   TIM4->CCR2 = ccr_val;
   TIM12->CCR1 = ccr_val;
   TIM3->CCR3 = ccr_val;
   }
 }
}

整体效果如下:

656287ec3f78474dd2d9e68a525e9bb6.gif
呼吸灯

通过示波器看其中的一路PWM输出的占空比也是随时间变化;

88989e009d394580412d5728844fbf66.gif
PWM变化情况

总结

本文简单介绍了PWM的原理,以及如何产生PWM,可以通过锯齿波作为载波和调制波经过比较强,产生相应的PWM输出波形,最后结合STM32实现了一个呼吸灯的简单程序。

—— The End — — 推荐好文   点击蓝色字体即可跳转 ☞ 太难了,炸机后才去注意PWM的死区时间 ☞ 当心!别再被大小端的问题坑了bdb1aed9ca17b1451c2af4f1a2c1c3ee.gif ☞ PID微分器与滤波器的爱恨情仇 ☞ 简易PID算法的快速扫盲 ☞ 增量式PID到底是什么? ☞ 三面大疆惨败,因为不懂PID的积分抗饱和

原创不易,欢迎转发、留言、点赞、分享给你的朋友,感谢您的支持!

b97974dbd66adbaae6c8c4d673ae027e.png

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值