基于MCS-51单片机的频率可调的方波发生器设计

合集下载

一种基于MCS-51单片机的数字可调脉冲发生器的设计实现

一种基于MCS-51单片机的数字可调脉冲发生器的设计实现

2系统需求分析与总体设计
以及显示灯 。 本文所设计的系统主要 是利用单片机控制脉冲发生器 分有限 , 输 出电流值 的大小也十分 有效 , 因而一般 采用连接运 算放 产生脉冲 , 利用可调 式的数字 电位器 的控制实现对脉冲的幅值 、 频 大 电路的形式, 来对 脉冲信号进行放大 。 本系统 所选 择的运算 放大 率 以及宽度的控制。 本 文利用5 1 单片机 以及A D C 模数转换器来实现 器为L M2 9 0 4 通过计算能够在满足输 出电压幅值 的情况下不失真 。 产生数字 脉冲信 号, 并 由L E D液晶显示。 3 . 3 A/ D转 换 模 块 选 型
设计 开发
I数 目啦 术
I与 应 用
种基于 MC S 一 5 1 单片机 的数字可调脉冲发生器的设计实现

高 敏
( 江苏商贸职业学院 江苏南通 2 2 6 0 1 1 )
摘要 : 脉 冲发生 器在 自 动 化控制领域 有着非 常广泛 的应用, 而传 统的脉冲发 生器操 作复杂且 造价较 高, 并且精确 度不能 够保证, 本 ̄ 1 7 J , MC S 一 5 1 单 片机 为基础 设计 出了一种 可调 式的数 字脉 冲发 生器, 对幅值 、 频 率和输 出宽度进行 调整且输 出精度 高, 不需要人 工调节 自动化程度 较 高。 可 以应 用在 很 多 实用到 脉冲发 生 器的场合 , 并且造 价较 为低 廉 。 为可调 式脉 冲发 生器的设计 与应 用提供 可具体 实践 的技术 解决 方案 。 关键 词: 可调式数 字脉 冲发 生器 MC S 一 5 1 A D C 0 8 0 9 L E D 显 示器 中图分 类号: T N 7 8 2 文献标识 码: A 文章编 号: 1 0 0 7 — 9 4 1 6 ( 2 0 1 6 ) 0 8 — 0 2 0 4 — 0 1

基于51单片机的波形发生器设计

基于51单片机的波形发生器设计

课题要求:目录:1、系统总体设计方案规划与选定…………………………………2、硬件设计…………………………………………………………3、软件设计………………………………………………………….4、调试……………………………………………………………….5、新增功能及实现方法……………………………………………6、总结与体会………………………………………………………7、参考文献…………………………………………………………8、附录(源程序代码、电路图等)………………………………一. 系统总体设计方案规划与选定本次设计采用AT89C51单片机为核心,通过与8279芯片和38译码器、锁存器的配合实现对键盘状态的检测和LED 显示的控制,通过D/A 转换器和运算放大器以及示波器实现对波形的输出,并且在8位LED 显示器上显示波形类型的代号、幅值、频率。

键盘为4*8键盘,通过键盘摁键实现对波形种类、幅值、频率等的调节。

图1. 总体方案结构框图二.硬件设计硬件的选择对于功能的实现非常重要,我们要了解芯片的功能、性能,根据题目要求选择合适的芯片。

(一)硬件介绍1.单片机选择AT89C51。

AT89C51 提供以下标准功能:4k 字节Flash 闪速存储器,128字节内部RAM ,32 个I/O 口线,两个16位定时/计数器,一个5向量两级中断结构,一个全双工串行通信口,片内振荡器及时钟电路。

同时,AT89C51可降至0Hz的静态逻辑操作,并支持两种软件可选的节电工作模式。

空闲方式停止CPU的工作,但允许RAM ,定时/计数器,串行通信口及中断系统继续工作。

掉电方式保存RAM中的内容,但振荡器停止工作并禁止其它所有部件工作直到下一个硬件复位。

AT89C51具有优良的性能,符合题目的要求。

图2. AT89C51引脚图引脚说明:P0口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。

当P0口的管脚第一次写1时,被定义为高阻输入。

基于51单片机的波形发生器的设计讲解

基于51单片机的波形发生器的设计讲解

目录1 引言 (1)1.1 题目要求及分析 (1)1.1.1 示意图 (1)1.2 设计要求 (1)2 波形发生器系统设计方案 (2)2.1 方案的设计思路 (2)2.2 设计框图及系统介绍 (2)2.3 选择合适的设计方案 (2)3 主要硬件电路及器件介绍 (4)3.1 80C51单片机 (4)3.2 DAC0832 (5)3.3 数码显示管 (6)4 系统的硬件设计 (8)4.1 硬件原理框图 (8)4.2 89C51系统设计 (8)4.3 时钟电路 (9)4.4 复位电路 (9)4.5 键盘接口电路 (10)4.7 数模转换器 (11)5 系统软件设计 (12)5.1 流程图: (12)5.2 产生波形图 (12)5.2.1 正弦波 (12)5.2.2 三角波 (13)5.2.3 方波 (14)6 结论 (16)主要参考文献 (17)致谢....................................................... 错误!未定义书签。

1引言1.1题目要求及分析题目:基于51单片机的波形发生器设计,即由51单片机控制产生正弦波、方波、三角波等的多种波形。

1.1.1示意图图1:系统流程示意图1.2设计要求(1) 系统具有产生正弦波、三角波、方波三种周期性波形的功能。

(2) 用键盘控制上述三种波形(同周期)的生成,以及由基波和它的谐波(5次以下)线性组合的波形。

(3) 系统具有存储波形功能。

(4) 系统输出波形的频率范围为1Hz~1MHz,重复频率可调,频率步进间隔≤100Hz,非正弦波的频率按照10次谐波来计算。

(5) 系统输出波形幅度范围0~5V。

(6) 系统具有显示输出波形的类型、重复频率和幅度的功能。

2波形发生器系统设计方案设计并制作一个波形信号发生器,能够产生正弦波、方波、三角波的波形,其中不使用DDS和一些专用的波形产生芯片。

并让系统的频率范围在1Hz~1MHZ可调节,在频率范围在1HZ~10KHz时,步进小于或等于10Hz,在频率范围在10KHz~1MHz时,步进小于或等于100Hz,并且电压在0~5V范围,能够实时的显示波形的类型、频率和幅值。

基于51单片机的波形发生器的设计

基于51单片机的波形发生器的设计

基于51单片机的波形发生器的设计引言:波形发生器是一种可以生成特定频率、特定波形的电子设备。

它广泛应用于科研、教学和产业生产等领域,可以用于信号发生、信号测试、信号仿真等各种任务。

本文将介绍一个基于51单片机的波形发生器的设计方案。

一、系统硬件设计1.系统框架该波形发生器系统采用51单片机作为主控芯片,主要包括三个部分:信号生成模块、显示模块和控制模块。

其中,信号生成模块负责产生各种特定频率、特定波形的信号;显示模块用于展示信号参数等相关信息;控制模块负责接收用户输入并对波形发生器进行控制。

2.硬件连接信号生成模块与主控芯片之间通过I/O接口相连,用于传输数据和控制信号。

显示模块通过串口与主控芯片相连,用于显示相关信息。

控制模块通过按键、旋钮等输入设备与主控芯片相连,用于接收用户输入。

二、系统软件设计1.系统初始化在系统初始化阶段,主控芯片需要完成引脚、定时器、串口等相关资源的初始化工作。

同时,还需要设置一些全局变量和参数的初始值。

2.信号生成模块信号生成模块通过定时器产生特定频率的时钟信号,并根据用户输入的参数生成相应的信号波形。

主控芯片利用定时器中断函数进行波形生成,并将生成的信号数据存放在缓冲区中。

3.显示模块显示模块负责将信号波形显示在液晶屏上,并显示相关参数,如频率、幅度等。

主控芯片将信号数据从缓冲区中读取,并通过串口发送给显示模块进行显示。

4.控制模块控制模块负责接收用户输入的控制指令,并通过按键、旋钮等输入设备完成用户交互。

主控芯片通过中断函数实时读取用户输入并进行相应的控制操作。

三、系统功能设计1.频率设置功能用户可以通过控制模块设置波形发生器的频率,可以选择固定频率或者可调频率。

利用定时器时钟频率与定时器中断的时间间隔来控制波形的频率。

2.波形选择功能用户可以通过控制模块选择不同的波形类型,如正弦波、方波、三角波、脉冲波等。

主控芯片根据用户指令设置波形参数,并生成相应的波形信号。

基于51单片机的波形发生器设计报告

基于51单片机的波形发生器设计报告

基于51单片机的波形发生器设计报告波形发生器是一种电子设备,用于产生各种不同类型和频率的电信号波形。

基于51单片机的波形发生器设计是一种常用的工程设计。

下面是一个关于基于51单片机的波形发生器设计的报告,详细介绍了设计的原理、步骤、电路、程序和性能。

一、设计原理:二、设计步骤:1.确定波形发生器的输出频率范围和分辨率要求。

2.选择适当的定时器/计数器模块来实现频率的计时和控制。

3.设计电路,包括定时器/计数器模块、晶振、滤波电路和输出接口等。

4.编写程序,配置定时器/计数器模块的工作模式、计数值和中断服务程序。

5.调试和测试电路和程序,确保波形发生器正常工作并满足设计要求。

三、电路设计:1.定时器/计数器模块:选择一个合适的定时器/计数器模块,如51单片机的定时器/计数器T0或T1、根据设计要求,设置工作模式、计数器模式和计数值。

2.晶振:选择适当的晶振频率,一般为11.0592MHz,将晶振连接到单片机的晶振引脚。

3.滤波电路:根据需要,设计一个滤波电路来滤除不需要的高频噪声和杂散信号。

4.输出接口:设计一个输出接口电路来连接单片机和外部电路,使用电平转换电路将单片机的低电平(0V)输出转换为所需的电平电压。

四、程序设计:1.配置定时器/计数器模块的工作模式和计数值,设置中断服务程序。

2.在中断服务程序中,根据设计要求生成矩形波信号,并将信号输出到输出端口。

3.在主程序中,初始化单片机和定时器/计数器模块,使波形发生器开始工作。

4.在主循环中,可以设置按键输入来改变输出频率,通过调整计数值来实现不同的频率输出。

五、性能评估:1.输出频率范围:根据设计要求,测试波形发生器的最低和最高输出频率是否在设计范围内。

2.分辨率:对于指定频率范围,测试波形发生器的输出频率的分辨率,即最小可调节的频率。

3.稳定性:测试波形发生器的输出信号的稳定性和准确度,是否有漂移和偏差。

4.噪声:测试波形发生器的输出信号是否有杂散噪声和幅度波动。

基于51单片机的波形发生器的设计讲解

基于51单片机的波形发生器的设计讲解

基于51单片机的波形发生器的设计讲解波形发生器是电子设备中常见的一种电子设备,它可以产生各种不同形状的波形信号。

在这篇文章中,我们将会详细介绍基于51单片机的波形发生器的设计。

一、波形发生器的原理及分类波形发生器的原理是利用电子元件、电路以及控制信号源,将一定幅度的电压信号变化成为需要的各种形状的波形信号。

根据波形的形状分类,可以将波形发生器分为以下几种类型:1.正弦波发生器:产生正弦波信号的发生器,常用于音频设备中。

2.方波发生器:产生方波信号的发生器,常用于数字电路中,也可用于频率测量和脉冲调制等应用。

3.三角波发生器:产生三角波信号的发生器,常用于音频设备以及频率测试等领域。

4.锯齿波发生器:产生锯齿波信号的发生器,常用于音频设备、测试仪器以及数据采集和测量等领域。

二、基于51单片机的波形发生器设计下面我们将详细介绍基于51单片机的波形发生器的设计步骤。

1.硬件设计:在基于51单片机的波形发生器设计中,我们需要准备的硬件元件有:-51单片机控制芯片-芯片烧录器-液晶显示屏-按键开关-电源模块-杜邦线等电子连接线2.硬件连接:根据电路原理图进行将电子元件进行正确的电路连接。

其中,51单片机作为核心控制芯片,负责生成波形信号,液晶显示屏用于显示波形信号,按键开关用于控制波形发生器的启动、停止以及参数调整等操作。

3.软件设计:利用Keil C编译软件进行51单片机的软件设计,根据控制芯片的指令集编写相应的程序代码,实现以下几个功能:-波形信号的产生:根据选择的波形类型(正弦波、方波、三角波或锯齿波),利用特定的算法生成相应形状的波形信号。

-参数调节:通过按键开关控制波形的频率、幅度以及相位等参数的调节,使波形发生器能够产生不同特性的波形信号。

-波形信号显示:通过LCD显示屏将生成的波形信号进行实时显示,以方便观察和调试。

4.软硬件的调试与优化:三、波形发生器的应用1.音频设备:波形发生器可以生成不同频率的正弦波信号,用于音频信号的发生和测试等应用。

基于MCS-51单片机的可调频率方波发生器课程设计报告

基于MCS-51单片机的可调频率方波发生器课程设计报告

单片机课程设计报告设计题目:频率可调方波发生器专业班级:生物医学工程09班组长:李建华组员:梁国锋,赖水兵,郭万劲,李建华2010 年 06 月 16日摘要本实验是基于PHILIPS AT89C51 单片机所设计的,可以实现键位与数字动态显示的一种频率可调方波发生器。

通过键盘键入(10HZ-9999HZ)随机频率,使用七段数码管显示,每一个数码管对应一个键位。

单片机对各个键位进行扫描,确定键位的输入,然后数码管显示输入的数值,方波发生器输出以数码管显示的数值为频率的方波。

关键词:单片机七段数码管键盘电路频率可调方波发生器一、目的和功能1.1 目的:设计一种频率范围限定且可调的方波发生器,志在产生特定频率的方波。

1.2功能:假设键盘是4*4的键盘,当键盘输入范围在10hz-9999hz的数字,单片机控制数码管显示该数值,并把该数值当做方波发生器的输入频率,单片机控制该方波发生器以该数值作为频率显示方波,从而得到我们想要频率的方波。

二、硬件设计2.1 硬件设计思想键盘的数字和键位关系固定,通过键盘输入产生频率,通过LED数码管显示出来,每一个数码管对应一个键位。

基本设备是基于PHILIPS AT89C51单片机,外围设备采用的是4个七段数码管,PHILIPS A T89C51单片机,1个OSCILLOSCOPE 方波发生器,16个Button,若干电阻,电源电池。

2.2 部分硬件方案论述2.2.1 七段数码管扫描显示方式的方案比较方案一:静态显示方式:静态显示方式是指当显示器显示某一字符时,七段数码管的每段发光二极管的位选始终被选中。

在这种显示方式下,每一个LED数码管显示器都需要一个8位的输出口进行控制。

静态显示主要的优点是显示稳定,在发光二极管导通电流一定的情况下显示器的亮度大,系统运行过程中,在需要更新显示内容时,CPU才去执行显示更新子程序,这样既节约了CPU的时间,又提高了CPU的工作效率。

基于51单片机的波形发生器的设计汇总

基于51单片机的波形发生器的设计汇总

基于51单片机的波形发生器的设计汇总波形发生器是电子领域中常用的一种设备,用于产生各种不同形式的波形信号。

本文将基于51单片机的波形发生器的设计进行汇总。

设计思路如下:一、基本原理波形发生器的基本原理是通过控制数字信号的高低电平来产生不同的波形。

在这个设计中,我们将使用51单片机作为控制器来产生波形信号。

二、硬件部分1.时钟电路:使用一个晶体振荡器作为时钟源,提供稳定的时钟脉冲给51单片机。

2.电源电路:使用稳压电源提供稳定的电压给51单片机和其他电路。

3.单片机电路:将51单片机与其他电路进行连接,包括输入输出端口和相应的外部电路。

4.波形输出电路:根据需要产生不同的波形,设计相应的输出电路,包括滤波器、电阻、电容等元器件。

三、软件部分1.系统初始化:在系统上电后,进行相应的初始化工作,包括设置引脚功能、中断,设置计时器等。

2.波形生成算法:根据用户的选择,使用合适的算法生成相应的波形信号。

常见的波形有正弦波、方波、三角波等。

3.输出控制:根据生成的波形信号,通过设置相应的输出引脚,将波形信号输出到波形输出电路中。

4.用户界面:设计一个简单的用户界面,让用户可以选择不同的波形、调整频率、幅度等参数。

5.中断处理:使用中断功能来处理波形输出频率的控制,实现较高的输出稳定性。

四、设计考虑1.精度要求:根据具体应用场景,确定波形发生器的精度要求。

如果需要较高的精度,可能需要采用更复杂的算法和更精密的输出电路。

2.输出负载:考虑波形发生器的输出负载情况,选择合适的输出电路,以确保波形信号的准确性和稳定性。

3.电源稳定性:电源的稳定性对波形发生器的性能也有影响,需要注意电源供电的稳定性。

五、测试与优化完成波形发生器设计后,进行相应的测试与优化。

包括波形信号的频率、幅度等测试,以及对输出电路、算法等进行优化。

最后,通过以上的设计思路,我们可以完成基于51单片机的波形发生器的设计。

根据具体的应用需求,可能需要对硬件和软件进行相应的调整和优化。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

基于MC51单片机的频率可调的方波信号发生器用单片机产生频率可调的方波信号。

输出方波的频率范围为1Hz-200Hz,频率误差比小于0.5%。

要求用“增加”、“减小”2 个按钮改变方波给定频率,按钮每按下一次,给定频率改变的步进步长为1Hz,当按钮持续按下的时间超过2 秒后,给定频率以10 次/秒的速度连续增加(减少),输出方波的频率要求在数码管上显示。

用输出方波控制一个发光二极管的显示,用示波器观察方波波形。

开机默认输出频率为5Hz。

1:系统设计(1)分析任务要求,写出系统整体设计思路任务分析:方波信号的产生实质上就是在定时器溢出中断次数达到规定次数时,将输出I/O 管脚的状态取反。

由于频率范围最高为200Hz,即每个周期为5ms(占空比1:1,即高电平2.5ms,低电平2.5 ms),因此,定时器可以工作在8 位自动装载的工作模式。

涉及以下几个方面的问题:按键的扫描、功能键的处理、计时功能以及数码管动态扫描显示等。

问题的难点在按键连续按下超过2S 的计时问题,如何实现计时功能。

系统的整体思路:主程序在初始化变量和寄存器之后,扫描按键,根据按键的情况执行相应的功能,然后在数码显示频率的值,显示完成后再回到按键扫描,如此反复执行。

中断程序负责方波的产生、按键连续按下超过2S 后频率值以10Hz/s 递增(递减)。

(2)选择单片机型号和所需外围器件型号,设计单片机硬件电路原理图采用MCS51 系列单片机At89S51 作为主控制器,外围电路器件包括数码管驱动、独立式键盘、方波脉冲输出以及发光二极管的显示等。

数码管驱动采用2 个四联共阴极数码管显示,由于单片机驱动能力有限,采用74HC244 作为数码管的驱动。

在74HC244 的7 段码输出线上串联100 欧姆电阻起限流作用。

独立式按键使用上提拉电路与电源连接,在没有键按下时,输出高电平。

发光二极管串联500欧姆电阻再接到电源上,当输入为低电平时,发光二极管导通发光。

图1 方波信号发生器的硬件电路原理图(3)分析软件任务要求,写出程序设计思路,分配单片机内部资源,画出程序流程图软件任务要求包括按键扫描、定时器的控制、按键连续按下的判断和计时、数码管的动态显示。

程序设计思路:根据定时器溢出的时间,将频率值换算为定时器溢出的次数(T1_over_num)。

使用变量(T1_cnt)暂存定时器T1 的溢出次数,当达到规定的次数(T1_over_num)时,将输出管脚的状态取反达到方波的产生。

主程序采用查询的方式实现按键的扫描和数码管的显示,中断服务程序实现方波的产生和连续按键的计时功能。

单片机内部资源分配:定时器T1 用来实现方波的产生和连续按键的计时功能,内部变量的定义: hz_shu:设定的频率数;T1_over_num: 根据设定频率计算后的定时器溢出的次数值;T1_cnt:定时器溢出次数;sec_over_num: 计时1s 的定时器溢出的次数;second:连续按键的计时;state_val:连续按下的标志0=按键已经弹起;1=按键一直按下led_seg_code:0-9 数字的数码管7 段码。

主程序和中断服务程序如图2,3 所示。

图2 主程序的流程图图3 中断程序的流程图(4)设计系统软件调试方案、硬件调试方案及软硬件联合调试方案软件调试方案:伟福软件中,在“文件\新建文件”中,新建C 语言源程序文件,编写相应的程序。

在“文件\新建项目”的菜单中,新建项目并将C 语言源程序文件包括在项目文件中。

在“项目\编译”菜单中将C 源文件编译,检查语法错误及逻辑错误。

在编译成功后,产生以“*.hex”和“*.bin”后缀的目标文件。

硬件调试方案:在设计平台中,将单片机的P1.0-P1.1 分别与2 个独立式键盘通过插线连接起来,将P3.0 与脉冲输出连接起来。

在伟福中将程序文件编译成目标文件后,将下载线安装在实验平台上,运行“MCU 下载程序”,选择相应的flash 数据文件,点击“编程”按钮,将程序文件下载到单片机的Flash 中。

然后,上电重新启动单片机,检查所编写的程序是否达到题目的要求,是否全面完整地完成试题的内容。

2:程序设计//晶振:12M T1-计时250 微秒溢出中断一次;P1.0 P1.1 为增加、减少键P3.0 输出方波/*变量的定义:hz_shu: 设定的频率数T1_over_num: 根据设定频率计算后的,定时器溢的出次数值T1_cnt: 定时器计数溢出数sec_over_num: 计算1s 内的计数second: 连续按键的计时state_val: 连续按下的标志0=按键已经弹起;1=按键一直按下去led_seg_code:数码管7 段码*/#include "reg51.h"#include "math.h"sbit pulse_out=P3^0;//-------------------unsigned char data hz_shu,second,key_val,key_val_old;unsigned int data sec_over_num;unsigned int data T1_cnt,T1_over_num;unsigned char data state_val;char code led_seg_code[10]={0x3f,0x06,0x05b,0x04f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//led_seg_code[0-9]代表0-9 的7 段码//------------------------void delay(unsigned int i)//延时{ while(--i);}//------------------------unsigned char scan_key(){ unsigned char i,k;i=P1;if (i==0xff){ k=255; } //无键按下else //有键按下{ delay(10); //延时去抖动if(i!=P1){k=255;}else{ switch (i){ case 0xfe: k=0; break; //case 0xfd: k=1; break;}}}return k;}//----------------void led_show(){unsigned char i;i=hz_shu%10; //显示个位P0=led_seg_code[i];P2=0xfe;delay(10);i=hz_shu%100/10; //显示十位P0=led_seg_code[i];P2=0xfd;delay(10);i=hz_shu%1000/100; //显示百位P0=led_seg_code[i];P2=0xfb;delay(10);}//--------------------------unsigned int get_T1_over_num(unsigned char p) //p 为频率数{unsigned int *k,h;double f;f=(double)p; //转化为浮点数f=0.5/f; //半个周期的时间f=f/0.00025; //中断溢出数=f/0.00025;h=f; //取整//四舍五入if (modf(f,k)>=0.5){ h=h+1; }return h;}/* C51 有专门的库文件MATH.H,里面有个函数它是这样定义的extern float modf(float x, float *ip);调用它之后,整数部分被放入*ip, 小数部分作为返回值。

*///------------------------------------void timer1() interrupt 3 //T1 中断{ T1_cnt++;if(T1_cnt>T1_over_num) //半周期的计数到达{ T1_cnt=0;pulse_out=!pulse_out; //反复取反,产生方波}if(state_val==1)//连续按键{ if (sec_over_num<4000) //计时未到1s{ sec_over_num++; }else //计时到1s 时,执行else 的代码{ sec_over_num=0;if(second<2) //当超过2 秒,second 一直为2,直到松开按键{second++;} //连续按下键少于2 秒时,second 继续增1。

else //连续按下键2 秒,以10 次/秒的速度连续增加{ TR1=0;switch (key_val){ case 0: if(hz_shu<190){ hz_shu=hz_shu+10;} //增10Hz/秒else{ hz_shu=200; }T1_over_num=get_T1_over_num(hz_shu);break;case 1: if(hz_shu>10){ hz_shu=hz_shu-10; } //减10/秒else{ hz_shu=1;}T1_over_num=get_T1_over_num(hz_shu);break;}TR1=1;}}}}//-------------------------main(){pulse_out=0; //初始化各变量hz_shu=5;T1_cnt=0;state_val=0;second=0;sec_over_num=0;T1_over_num=get_T1_over_num(hz_shu);//初始化51 的寄存器TMOD=0x20;//用T1 计时8 位自动装载定时模式,T0 计数p3.4 的脉冲数TH1=0x6; //250 微秒溢出一次; 250(256-x)*12/12 -> x=6TL1=0x6; //200Hz 的半周期为2.5 毫秒,要溢出中断10 次EA=1; //开中断ET1=1;TR1=1; //定时器T1while(1){ key_val=scan_key(); //扫描按键if (key_val!=key_val_old){ //说明有键按下或弹起key_val_old=key_val;if (key_val!=255){ //说明键按下state_val=0; //清除连续按键标志sec_over_num=0;switch (key_val){ case 0: //增1 键hz_shu++;T1_over_num=get_T1_over_num(hz_shu);break;case 1: //减1 键if(hz_shu>=2){hz_shu--;}else{hz_shu=1;}T1_over_num=get_T1_over_num(hz_shu);break;}}else //说明键弹起{ state_val=0; second=0;}}else //一直按下或弹起{ if (key_val!=255){ state_val=1; //连续按键}else{state_val=0;} //没有按键按下,一直处于弹起状态}led_show(); //数码管显示,动态扫描}}//----方波发生器-----------------。

相关文档
最新文档