
节精度比较差
下面是双定时器产生PWM主要语句:
TMOD=0X11
TH0=(65536-20000)/256//
定时20ms
TL0=(65536-20000)%256
TH1=(65536-b)/256//定时要小于20ms,改变b的值即改变占空比
TL1=(65536-b)%256
ET0=1
EA=1
TR0=1
PWM=1
b=2000
while(1)
void
timer0()interrupt
1
{
TH0=(65536-20000)/256
TL0=(65536-20000)%256
PWM=1
TR1=1
ET1=1
}
void
timer1()interrupt
3
{
TH1=(65536-b)/256
TL1=(65536-b)%256
PWM=0
TR1=0
ET1=0
}
定时器0中断负责每
20ms将管脚置
1,定时1负责在20ms之内的某一时间将该管脚清0
当然也可以采用自动重装方式,中断可以更频繁一些,产生的PWM频率要高一些
也可以只用一个定时器,这时产生PWM波要么频率低,要么调节精度差,因中断一次至少10US,你就不用指望一次调节步距10us以下了
用定时器产生程序如下:unsigned
int
a=0
,b=10
void
main()
{
tmod=0x01
th0=(65536-50000)/256
tl0=(65536-50000)%256
ea=1
et0=1
tr0=1
}
void
pwm()
interrupt
1
{
th0=(65536-50000)/256
tl0=(65536-50000)%256
a++
p1^1=0
if(a=20)
{
a=0
}
if(a=b)
{
p1^1=1
}
}
调节a
,b的值即可调节占空比,程序框架就是这样,具体自己改吧
#include"at89x51.h"unsigned char PWM=0
#define PWMOUT P1_0
#define KEYUP P1_1
#define KEYDOWN P1_2
void TunPWM()
void key()
void delayms(unsigned char time)
void main()
{
P1=0xff
while(1)
{
key()
TunPWM
}
}
void TunPWM()
{
unsigned char i
for(i=0i<PWMi++)
PWMOUT=1
for(i=0i<100-PWMi++)
PWMOUT=0
}
void key()
{
if(KEYUP==0)
{
delayms(10)
if(KEYUP==0)
{
PWM++
if(PWM==100)
PWM=100
while(KEYUP==0)
}
}
if(KEYDOWN==0)
{
delayms(10)
if(KEYDOWN==0)
{
PWM++
if(PWM==100)
PWM=100
while(KEYDOWN==0)
}
}
}
void delayms(unsigned char time)
{
.........
}
延时自己写。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)