2、/*采用6MHz晶振,在P1.0脚上输出周期为2.5s,占空比为20%的脉冲信号*/
/*定时100ms,周期2.5s需25次中断,高电平0.5s需5次中断*/
#include <reg51.h>
typedef unsigned char uchar
sbit P1_0=P1^0
uchar time=0
uchar period=25
uchar high=5
void timer0() interrupt 1 using 1
{
TH0=0x3c/*定时器初值重装载*/
TL0=0xb0
time++
if(time==high) /*高电平持续时间结束,变低*/
{ P1_0=0}
else if(time==period) /*周期时间到,变高*/
{ time=0
P1_0=1
}
}
void main()
{
TMOD=0x01/*定时器0方式1*/
TH0=0x3c/*定时器装载初值*/
TL0=0xb0
EA=1/*开CPU中断*/
ET0=1/*开定时器0中断*/
TR0=1/*启动定时器0*/
while(1) /*等待中断*/
{}
}
3、说明:本程序主要采用了51单片机(具体型号STC89C52RC)的定时器,工作在方式3,来产生规定时间内的方波,制造SPWM.
看来你还不理解定时器的工作原理, 向上计数模式工作时,CNT(定时器计数)从0开始计数时钟源脉冲数,达到ARR时开始下一个0开始计数周期,这就是三角波(频率由时钟源和ARR决定)。通道工作在比较模式时 ,CCR(比较寄存器)数值和CNT进行比较,比较结果直接回输出在对应通道的引脚上。每个周期结束时更新比较寄存器的数据(参考正玄波数据点按照载波频率采样的交点数值,事先就计算好的),就可以输出相应SPWM了
用定时器定时10ms,中断程序里将两个IO管脚状态取反即可。但两个管脚的原始状态是相反的。大致 程序如下:
主程序里
TMOD=0X01;
TH0=.......
TL0=......
EA=1
ET0=1
PWM1=0//一个管脚置低
PWM2=1//另一个管脚置高
TR0=1
中断程序中:
TH0=.......
TL0=......
PWM1=!PWM1;
PWM2=!PWM2;
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)