使用T0,方式2,在P1.0输出周期为400µs,占空比为4:1的矩形脉冲,要求在P1.0引脚接有虚拟示波器,观察P1.0引脚输出的矩形脉冲波形

简介: 使用T0,方式2,在P1.0输出周期为400µs,占空比为4:1的矩形脉冲,要求在P1.0引脚接有虚拟示波器,观察P1.0引脚输出的矩形脉冲波形

大家学过一段时间的单片机了,今天我们来说说单片机里的定时器,又叫计数器。首先,我们通过案例来了解一下什么是定时器。


【例】使用T0,方式2,在P1.0输出周期为400µs,占空比为4:1的矩形脉冲,要求在P1.0引脚接有虚拟示波器,观察P1.0引脚输出的矩形脉冲波形。

作业要求

要求使用T0,采用方式2定时,在P1.0输出周期为400µs,占空比为4:1的矩形脉冲。


分析过程

从P1.0输出的矩形脉冲的高低电平的时间为4:1,则高低电平的时间分别为320μs和80μs。采用12MHz晶振,高低电平输出取整,则约为320μs和80μs。(这里刚好是个整数,可以不用取整)。


我们在这里拓展一下,单片机定时器T0和T1的区别:

1、工作方式选择的不同。定时器T1没有方式3 ,方式3只适合定时器T0,使其增加一个8位定时器。若定时器T1选择方式3,T1将停止工作,相当于TR1=0的情况。


2、工作方式控制位的不同。在工作方式寄存器TMOD中,高4位控制定时器T1,低4位控制定时器T0。


3、运行状态的不同。定时器T0可分成2个独立的8位定时器,而定时器T1则不能;定时器T1可作为串口的波特率发生器,而定时器T0则不能。


我们打开仿真软件,画出电路板图,如图所示:


0.png

图中P1.0引脚就是虚拟的示波器,接下来就是代码编程,我给了注释如下。


代码如下:

1.png


#include<reg51.h>
sbit OSC = P1^0;
void main()
{
  TMOD=0x02;     //设置T0的方式2
    TH0=256 - 80;   //每次80us
    TL0=TH0;  
    EA=1;      //总中断允许
    TR0=1;        //启动T0定时器
    ET0=1;       //允许外部中断0中断
    while(1);
}
void ET0_ISR(void) interrupt 1     //定时中断
{  
   unsigned int i;
   i++;
   if(i ==4)
  {       
      OSC = 0;    
  }
    else if (i == 5)       
  {
      OSC = 1;   //320us的低电平时间到,电平变高
    i=0;     //计数清零
  }     
}

特别注意:引脚在代码中和仿真软件中要一致,不然无法显示结果,就像我一样,半天也不知道哪里错了。

来看看仿真图吧‘


2.png

如果大家遇到了单片机时钟为6MHZ,则高电平需要除2去计算,本文是单片机时钟为12MHZ.

今天就介绍到这里,下期见。

相关文章
|
7月前
|
C语言
输出4种波形的函数信号发生器
设计了一款基于MCS-51单片机的函数信号发生器,能生成四种波形(正弦、方、三角、锯齿),频率范围10-100Hz,步进值0.1-10Hz。系统包括5V电源、AT89C51单片机、DAC0832、LM358、LCD1602、键盘和LED电路。通过按键切换波形、设定频率和步进值,LCD实时显示信息,LED指示波形类型。Proteus和Altium仿真验证了设计功能。
145 10
|
7月前
|
存储 算法 异构计算
m基于FPGA的多功能信号发生器verilog实现,包含testbench,可以调整波形类型,幅度,频率,初始相位等
使用Vivado 2019.2仿真的DDS信号发生器展示了正弦、方波、锯齿波和三角波的输出,并能调整幅度和频率。DDS技术基于高速累加器、查找表和DAC,通过频率控制字和初始相位调整产生各种波形。Verilog程序提供了一个TEST模块,包含时钟、复位、信号选择、幅度和频率控制输入,以生成不同波形。
210 18
|
7月前
|
芯片
灌电流与拉电流的含义及电路解析
上拉电阻是用来解决总线驱动能力不足时提供电流的,一般说法是拉电流。下拉电阻是用来吸收电流的,也就是灌电流。在数字电路中,拉电流和灌电流是衡量电路输出驱动能力(注意:拉、灌都是对输出端而言的,所以是驱动能力)的参数。 在集成电路中,拉电流输出和灌电流输出是一个很重要的概念。 一、什么是拉电流 由于数字电路的输出只有高、低(0,1)两种电平值,高电平输出时,一般是输出端对负载提供电流,其提供电流的数值叫“拉电流”。例如在使用反向器作输出显示时,当输出端为高电平时才符合发光二极管正向连接的要求,但这种拉电流输出对于反向器只能输出零点几毫安的电流用这种方法想驱动二极管发光是不合理的(因发光二极管
145 2
【单片机期中测试】2.独立按键控制LED移位
【单片机期中测试】2.独立按键控制LED移位
108 0
OpenMV输出PWM,实现对舵机控制
OpenMV输出PWM,实现对舵机控制
1715 0
|
编解码 内存技术
HIMA EABT3 DAC设计再现的可能输出电平数
HIMA EABT3 DAC设计再现的可能输出电平数
HIMA EABT3 DAC设计再现的可能输出电平数
|
编解码 机器人 芯片
STM32:PWM硬件部分知识点讲解(内含:1.PWM简介+2.PWM波形简介(重点)+参数计算+输出比较模式/通道+3.PWM输出控制舵机+直流电机介绍)
STM32:PWM硬件部分知识点讲解(内含:1.PWM简介+2.PWM波形简介(重点)+参数计算+输出比较模式/通道+3.PWM输出控制舵机+直流电机介绍)
2102 0
STM32:PWM硬件部分知识点讲解(内含:1.PWM简介+2.PWM波形简介(重点)+参数计算+输出比较模式/通道+3.PWM输出控制舵机+直流电机介绍)
|
存储 监控
369-HI-0-0-0-0 包含所有电流和电压通道
369-HI-0-0-0-0 包含所有电流和电压通道
93 0
|
监控
PLC 控制三相异步电动机正反转实验
PLC 控制三相异步电动机正反转实验
921 0
PLC 控制三相异步电动机正反转实验
|
异构计算
实验二 基于FPGA的分频器的设计(基本任务:设计一个分频器,输入信号50MHz,输出信号频率分别为1KHz、500Hz及1Hz。拓展任务1:用按键或开关控制蜂鸣器的响与不响。拓展任务2:用按键或开)
实验二 基于FPGA的分频器的设计(基本任务:设计一个分频器,输入信号50MHz,输出信号频率分别为1KHz、500Hz及1Hz。拓展任务1:用按键或开关控制蜂鸣器的响与不响。拓展任务2:用按键或开)
1310 0
实验二 基于FPGA的分频器的设计(基本任务:设计一个分频器,输入信号50MHz,输出信号频率分别为1KHz、500Hz及1Hz。拓展任务1:用按键或开关控制蜂鸣器的响与不响。拓展任务2:用按键或开)

热门文章

最新文章