PWM输出控制LED的亮暗程度原理?

PWM输出控制LED的亮暗程度原理?,第1张

pwm控制led灯亮度原理:

旋转电阻就是可调电阻,单片机不能直接得到电阻量。所以得将电阻的变化转换为模拟信号或数字信号,可搭建一个简单的分压电路。单片机转换成数字量,通过程序判断后,调节PWM参数,进使LED亮度变化。

PWM是一种对模拟信号进行数字编码的方法。通过高分辨率计数器的使用,方波的占空比被调制用来对一个具体模拟信号的电平进行编码。

PWM信号仍然是数字的,因为在给定的任何时刻,满幅值的直流供电要么完全有(ON),要么完全无(OFF)。

电压或电流源是以一种通(ON)或断(OFF)的重复脉冲序列被加到模拟负载上去的。通的时候即是直流供电被加到负载上的时候,断的时候即是供电被断开的时候。只要带宽足够,任何模拟值都可以使用PWM进行编码。

而应用到led灯具的控制上就要根据led在电压与电流变化时的具体情况,进行控制了。

其中的“宽度”,就是脉冲的高电平的时间。PWM信号调节LED亮度时,信号频率是不变的,改变的是脉冲的高电平的时间,即LED的导通时间。这种信号调节亮度相当于调节LED的平均电流,所以电流会变化。

扩展资料:

把每一脉冲宽度均相等的脉冲列作为PWM波形,通过改变脉冲列的周期可以调频,改敏蔽变伍野脉冲的宽度或占空比可以调压,采用适当控制方法即可使电压与频率协调变化。

可以通过调整PWM的周期、PWM的占空比而达到控制充电电流的目的。

模拟信号的值可以连续变化,其时间和幅度的分辨率都没有限制。9V电池就是一种模拟器件,因为它的输出电压并不精确地等于9V,而是随时间发生变化,并可取任何实数值。

与此类似,从电池吸收的电流也不限定在一组可能的取值范围之内。模拟信号与数字信号的区别在于后者的取值通常只能属于预先确定的可能取值集桥橘州合之内,例如在{0V,5V}这一集合中取值。

参考资料:百度百科-PWN

#include<reg52.h>

#include<intrins.h>

#define uchar unsigned char

#define uint unsigned int

#define LED P1//8个发光二级管

sbit key1=P3^5

sbit key2=P3^6

#define LED_ON() LED=0x00 //所宽庆族有灯亮

#define LED_OFF() LED=0xff //灭

#define LED_PWM_MAX 99

#define LED_PWM_MIN 0

uchar LED_Direction=0 //LED方向控制 0:变亮 1:差源变暗

uchar LED_PWM_Counter=0 //LED占空比

uchar count=0 //中断计数

bit flag=0//按键扫描标志位

void main()

{

P3=0xff //做输入口先写1

TMOD=0x01

TH0=0xff

TL0=0x47

EA=1

ET0=1

TR0=1

while(1)

{

if(flag)

{

if(key1==0)

{

if((LED_PWM_Count<=LED_PWM_MAX)&&(LED_Direction==0))

{

LED_PWM_Count++

if(LED_PWM_Count>LED_PWM_MAX)

{

LED_PWM_Count=LED_PWM_MAX

LED_Direction=1

}

}

}

if(key2==0)

{

if((LED_PWM_Count>=LED_PWM_MIN)&&(LED_Direction==1))

{

LED_PWM_Count--

if(LED_PWM_count<LED_PWM_MIN)

{

LED_PWM_Count=LED_PWM_MIN

LED_Direction=0

}

}

}

if(LED_PWM_Count>0)

{

LED_ON()

LED_PWM_Count--

}

else

{

LED_OFF()

}

}

}

}

void timer0() interrupt 1

{

TH0=0xff

TL0=0x47

if(++count>慎弊=10)//2ms扫描一次按键(不行可以把时间改小)

{

count=0

flag=1

}

}

大概就这个思路,如果不行你自己改改吧!

MCU通过PWM调节LED亮度程序如下:

// PWM 控制 LED 灯渐亮渐灭程序

// 晶振为12M

// 利用定时器控制产生占空比可变的 PWM 波

// 按K1,PWM值增加,则占空比减小,LED 灯渐暗。

// 按K2,PWM值减小,则占空比增加,LED 灯渐亮。

// 当PWM值增加到最大值或减小到最小值时,蜂鸣器将报警。轮知返

#include <reg51.h >

sbit K1 =P3^0//增加键

sbit K2 =P3^1

sbit P10=P1^0 //减少键

sbit BEEP =P3^7//蜂鸣器

unsigned char PWM=0x7f //赋初值

void Beep()

void delayms(unsigned char ms)

void delay(unsigned char t)

void main()

{

初始化:

K1=1

K2=1

TMOD=0x21

TH0=0xfc//1ms延时常数

TL0=0x18 //频率调节

TH1=PWM //脉宽调节

TL1=0

EA=1

ET0=1

ET1=1

TR0=1

主循环:

while(1)

{

if(K1==0)//递增按键考虑消抖..

{

delayms(20)

if(K1==0)

{

if(PWM==255)

{

PWM=255

Beep()

}

else PWM++

}

}

if(K2==0)//递减按键

{

delayms(20)

if(K2==0)

{

if(PWM==0)

{

PWM=0

Beep()

}

else PWM--

}

}

}

}

// 定时器0中断服务程序.

void timer0() interrupt 1

{

TH0=0xfc

TL0=0x18

TH1=PWM //定时器自动重装值由PWM提供

TR1=1

P10=0 //启动输出

}

// 定时器1中断服务程序

void timer1() interrupt 3

{

TR1=0

P10=1//结束输猛芹出

}

//蜂鸣器子程序

void Beep()

{

unsigned char i

for (i=0 i<100 i++)

{

delay(200)

BEEP=!BEEP//Beep取反

}

BEEP=1//关闭蜂鸣器

delayms(200)

}

// 延时腊饥子程序

void delay(unsigned char t)

{

while(t--)

}

// 延时子程序

void delayms(unsigned char ms)

{

unsigned char i

while(ms--)

{

for(i = 0 i <120 i++)

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12310229.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-22
下一篇2023-05-22

发表评论

登录后才能评论

评论列表(0条)

    保存