斯害也己_由百世之後_目彻为明_川宁侯|北京军海癫痫医院
北京军海癫痫医院

您现在的位置: 首页 > 环境自净 > 正文内容

基于AT89C51PWM信号发生器设计报告课程设计

来源:斯害也己网   时间: 2021-07-24

基于AT89C51的PWM信号发生器设计 摘 要 单片机集成度高,功能强,可靠性高,体积小,功耗低,使用方便,价格低廉等一系列优点,目前已经渗入到人们工作和生活的方方面面,几乎无处不在,无所不为。单片机的应用领域已经从面向工业控制,通讯,交通,智能仪表等迅速发展到家用消费产品,办公自动化,汽车电子,PC机外围以及网络通讯等广大领域。

单片机有两种基本结构形式:一种是在通用微型计算机中广泛采用的,将程序存储器和数据存储器合用一个存储器空间的结构,成为普林斯机构。另一种是将程序存储器和数据存储器截然分开,分别寻址的结构,一般需要较大的程序存储器,目前单片机以采用程序存储器截然分开的结构多。本课题讨论的占空比与周期可调的信号发生器的核心是目前应用极为广泛的51系列单片机。

基于单片机的信号发生器的设计,该课题的设计目的是充分运用大学期间所学的专业知识,考察现在正在使用的信号发生器的基本功能,完成一个基本的实际系统的设计全过程。关键是这个实际系统设计的过程,在整个过程中我可以充分发挥自动化的专业知识。特别是这个信号发生器的设计中涉及到一个典型的控制过程。通过单片机控制一个有特殊功能的信号发生芯片,可以产生一系列有规律的周期和占空比可调的波形。这样一个信号发生器装置在控制领域有相当广泛的应用范围。因为产生一系列的可调波形可以作为其他一些设备的数值输入,还可以应用与设备检测,仪器调试等场合。高频稳定的波形信号也可以用于无线电波的调频,解调。这些都是现代生活中必不可少的一些应用。

关键词:PWM 信号发生器 目 录 1.简介 3 1.1 proteus 3 1.2 Keil 4 1.3 PWM 5 1.4 AT89C51 6 2.设计原理和方法 9 2.1单片机的基本组成 9 2.2方案的设计与选择 9 2.3定时器、的工作原理 10 2.3.1工作方式寄存器TMOD 11 2.3.2定时/计数器控制寄存器TCON 12 2.4定时/计数器的工作方式 12 2.5设计方法 13 3.系统硬件电路设计图 14 4.程序框图 16 4.1主程序框图:

16 4.2系统初始化:

16 4.3定时器中断程序框图:

16 4.4键盘扫描程序框图:

17 5.性能分析 18 5.1定时器中断分析 18 5.2系统性能分析 18 6.源程序 18 7. 仿真效果图 22 总 结 24 致 谢 25 参考文献 25 1.简介 1.1 proteus Proteus ISIS是英国Labcenter公司开发的电路分析与实物仿真软件。它运行于Windows操作系统上,可以仿真、分析(SPICE)各种模拟器件和集成电路,该软件的特点是:

(1)实现了单片机仿真和SPICE电路仿真相结合。具有模拟电路仿真、数字电路仿真、单片机及其外围电路组成的系统的仿真、RS232动态仿真、I2C调试器、SPI调试器、键盘和LCD系统仿真的功能;

有各种虚拟仪器,如示波器、逻辑分析仪、信号发生器等。

(2)支持主流单片机系统的仿真。目前支持的单片机类型有:68000系列、8051系列、AVR系列、PIC12系列、PIC16系列、PIC18系列、Z80系列、HC11系列以及各种外围芯片。

(3) 提供软件调试功能。在硬件仿真系统中具有全速、单步、设置断点等调试功能,同时可以观察各个变量、寄存器等的当前状态,因此在该软件仿真系统中,也必须具有这些功能;

同时支持第三方的软件编译和调试环境,如Keil C51 uVision2等软件。

(4) 具有强大的原理图绘制功能。总之,该软件是一款集单片机和SPICE分析于一身的仿真软件,功能极其强大。本章介绍Proteus ISIS软件的工作环境和一些基本操作。

特点:支持ARM7,PIC ,AVR,HC11以及8051系列的微处理器CPU模型,更多模型正在开发中:

交互外设模型有LCD显示、RS232终端、通用键盘、开关、按钮、LED等;

强大的调试功能,如访问寄存器与内存,设置断点和单步运行模式;

支持如IAR、Keil和Hitech等开发工具的源码C和汇编的调试;

一键“make”特性:一个键完成编译与仿真操作;

内置超过6000标准SPICE模型,完全兼容制造商提供的SPICE模型;

DLL界面为应用提供特定的模式;

基于工业标准的SPICE3F5混合模型电路仿真器 14种虚拟仪器:示波器、逻辑分析仪、信号发生器、规程分析仪等;

高级仿真包含强大的基于图形的分析功能:模拟、数字和混合瞬时图形;

频率;

转 换;

噪声;

失真;

付立叶;

交流、直流和音频曲线;

模拟信号发生器包括直流、正旋、脉冲、分段线性、音频、指数、单频FM;

数字信号发生器包括尖脉冲、脉冲、时钟和码流;

集成PROTEUS PCB设计形成完整的电子设计系统。

1.2 Keil Keil C51是美国Keil Software公司出品的51系列兼容单片机C语言软件开发系统,与汇编相比,C语言在功能上、结构性、可读性、可维护性上有明显的优势,因而易学易用。Keil提供了包括C编译器、宏汇编、连接器、库管理和一个功能强大的仿真调试器等在内的完整开发方案,通过一个集成开发环境(uVision)将这些部分组合在一起。运行Keil软件需要WIN98、NT、WIN2000、WINXP等操作系统。如果你使用C语言编程,那么Keil几乎就是你的不二之选,即使不使用C语言而仅用汇编语言编程,其方便易用的集成环境、强大的软件仿真调试工具也会令你事半功倍。

(1)系统概述

Keil C51软件提供丰富的库函数和功能强大的集成开发调试工具,全Windows界面。另外重要的一点,只要看一下编译后生成的汇编代码,就能体会到Keil C51生成的目标代码效率非常之高,多数语句生成的汇编代码很紧凑,容易理解。在开发大型软件时更能体现高级语言的优势。下面详细介绍Keil C51开发系统各部分功能和使用。

(2)Keil C51单片机软件开发系统的整体结构

C51工具包的整体结构,uVision与Ishell分别是C武汉癫痫病医院有那些51 for Windows和for Dos的集成开发环境(IDE),可以完成编辑、编译、连接、调试、仿真等整个开发流程。开发人员可用IDE本身或其它编辑器编辑C或汇编源文件。然后分别由C51及C51编译器编译生成目标文件(.OBJ)。目标文件可由LIB51创建生成库文件,也可以与库文件一起经L51连接定位生成绝对目标文件(.ABS)。ABS文件由OH51转换成标准的Hex文件,以供调试器dScope51或tScope51使用进行源代码级调试,也可由仿真器使用直接对目标板进行调试,也可以直接写入程序存贮器如EPROM中。

1.3 PWM (1)简介 脉冲宽度调制(PWM),是英文“Pulse Width Modulation”的缩写,简称脉宽调制,是一种模拟控制方式,其根据相应载荷的变化来调制晶体管栅极或基极的偏置,来实现开关稳压电源输出晶体管或晶体管导通时间的改变,这种方式能使电源的输出电压在工作条件变化时保持恒定,是利用微处理器的数字信号对模拟电路进行控制的一种非常有效的技术。

PWM控制技术以其控制简单,灵活和动态响应好的优点而成为电力电子技术最广泛应用的控制方式,也是人们研究的热点。由于当今科学技术的发展已经没有了学科之间的界限,结合现代控制理论思想或实现无谐振软开关技术将会成为PWM控制技术发展的主要方向之一。

(2)基本原理 随着电子技术的发展,出现了多种PWM技术,其中包括:相电压控制PWM、脉宽PWM法、随机PWM、SPWM法、线电压控制PWM等,而在镍氢电池智能充电器中采用的脉宽PWM法,它是把每一脉冲宽度均相等的脉冲列作为PWM波形,通过改变脉冲列的周期可以调频,改变脉冲的宽度或占空比可以调压,采用适当控制方法即可使电压与频率协调变化。可以通过调整PWM的周期、PWM的占空比而达到控制充电电流的目的。

尽管模拟控制看起来可能直观而简单,但它并不总是非常经济或可行的。其中一点就是,模拟电路容易随时间漂移,因而难以调节。能够解决这个问题的精密模拟电路可能非常庞大、笨重(如老式的家庭立体声设备)和昂贵。模拟电路还有可能严重发热,其功耗相对于工作元件两端电压与电流的乘积成正比。模拟电路还可能对噪声很敏感,任何扰动或噪声都肯定会改变电流值的大小。

通过以数字方式控制模拟电路,可以大幅度降低系统的成本和功耗。此外,许多微控制器和DSP已经在芯片上包含了PWM控制器,这使数字控制的实现变得更加容易了。

(3)脉冲宽度调制优点 PWM的一个优点是从处理器到被控系统信号都是数字形式的,无需进行数模转换。让信号保持为数字形式可将噪声影响降到最小。噪声只有在强到足以将逻辑1改变为逻辑0或将逻辑0改变为逻辑1时,也才能对数字信号产生影响。

对噪声抵抗能力的增强是PWM相对于模拟控制的另外一个优点,而且这也是在某些时候将PWM用于通信的主要原因。从模拟信号转向PWM可以极大地延长通信距离。在接收端,通过适当的RC或LC网络可以滤除调制高频方波并将信号还原为模拟形式。

总之,PWM既经济、节约空间、抗噪性能强,是一种值得广大工程师在许多设计应用中使用的有效技术。

1.4 AT89C51 AT89C51是一种带4K字节FLASH存储器(FPEROM—Flash Programmable and Erasable Read Only Memory)的低电压高性能CMOS 8位微处理器,俗称单片机。

(1)主要特性:

² 全静态工作:0Hz24MHz ² 三级程序存储器锁定 ² 128×8位内部RAM ² 32可编程I/O线 ² 两个16位定时器/计数器 ² 5个中断源 ² 可编程串行通道 ² 低功耗的闲置和掉电模式 ² 片内振荡器和时钟电路 (2)管脚说明:

VCC:供电电压。

GND:接地。

P0口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当 P0口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数 据存储器,它可以被定义为数据/地址的低八位。在FIASH编程时,P0 口作 为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须接上 拉电阻。

P1口:P1口是一个内部提供上拉电阻的8位双向I/O口,P1 口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被内部上拉为高, 可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上 拉的缘故。在FLASH编程和校验时,P1口作为低八位地址接收。

P2口:P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输 出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且 作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这 是由于内部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据 存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用 内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特 殊功能寄存器的内容。P2口在FLASH编程和校验时接收高八位地址信号和 控制信号。

P3口:P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL 门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作 为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的 缘故。

P3口也可作为AT89C51的一些特殊功能口,如下表所示:

口管脚 备选功能

P3.0 RXD(串行输入口)

P3.1 TXD(串行输出口)

P3.2 /INT0(外部中断0)

P3.3 /INT1(外部中断1)

P3.4 T0(记时器0外部输入)

P3.5 T1(记时器1外部输入)

P3.6 /WR(外部数据存储器写选通)

P3.7 /RD(外部数据存储器读选通)

P3口同时为闪烁编程和编程校验接收一些控制信号。

RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平 时间。

ALE/PROG:当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的低 位字节。

在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端 以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可 用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数 据存储器时,治癫痫病有没有偏方将跳过一个ALE脉冲。如想禁止ALE的输出可在SFR8EH地址 上置0。此时, ALE只有在执行MOVX,MOVC指令是ALE才起作用。另外, 该引脚被略微拉高。如果微处理器在外部执行状态ALE禁止,置位无效。

/PSEN:外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机 器周期两次/PSEN有效。但在访问外部数据存储器时,这两次有效的/PSEN 信号将不出现。

/EA/VPP:当/EA保持低电平时,则在此期间外部程序存储器(0000HFFFFH), 不管是否有内部程序存储器。注意加密方式1时,/EA将内部锁定为RESET;

当/EA端保持高电平时,此间内部程序存储器。在FLASH编程期间,此引脚 也用于施加12V编程电源(VPP)。

XTAL1:反向振荡放大器的输入及内部时钟工作电路的输入。

XTAL2:来自反向振荡器的输出。

(3)振荡器特性:

XTAL1和XTAL2分别为反向放大器的输入和输出。该反向放大器可以配置 为片内振荡器。石晶振荡和陶瓷振荡均可采用。如采用外部时钟源驱动器件, XTAL2应不接。有余输入至内部时钟信号要通过一个二分频触发器,因此对外 部时钟信号的脉宽无任何要求,但必须保证脉冲的高低电平要求的宽度。

2.设计原理和方法 2.1单片机的基本组成 图1 51单片机框图 2.2方案的设计与选择 在电子技术领域中,实现函数信号发生器的方法有很多种,可以采用不同的原理及器件构成不同的电路,但是可以实现相同的功能。

(1)方案的比较:

方案一:采用单片函数发生器如8038,8038可同时产生正弦波,方波等,而且方法简单易行。用D/A转换器的输出来改变调制电压,也可以实现数控的调频进而改变周期,但是产生的频率稳定度不高。

方案二:采用锁相式频率合成器,利用锁相环,降压控振荡器(VOC)的输出,频率锁定在所需的频率上,该方案性能良好,但是难以达到输出频率覆盖系数的要求,其电路复杂。

方案三:采用单片机编程的方法实现。该方法可以通过编程,来控制方波信号输出的周期和占空比,并且只要改变程序的相关参数,便可以改变输出波形的周期和占空比。由于编程的方法产生的是数字信号,所以信号的精度可以做到很高。并且电路简单。

鉴于方案一的信号频率不够稳定和方案二的电路复杂,频率覆盖系数难以达标等缺点,所以决定采用方案三的设计方法。方案三不仅仅是软硬件结合,而且它使用的元器件,容易得到,且价格便宜,使得硬件的开销达到最省。

在此次设计中,利用AT89C51单片机,软硬件结合,实现占空比和周期可调。案件的操作是通过数字电路跟外部中断0来控制的。可以输出占空比在1%到99%可调,精度为1%,周期在5ms到60ms可调,精度为5ms的方波。

本设计用到一个AT89C51微处理器,4个按键,一个四输入与门。AT89C51用到两个定时器,定时器0和定时器1。其中定时器0工作在方式1下,决定输出信号的周期,定时器1工作在方式1下,决定输出信号的占空比。按键PERIOD+和PERIOD改变信号的周期,按键PERIOD+用于增大信号的周期,按一下就增大5ms,当增大到60ms后,就归为5ms。按键PERIOD用于减小输出信号的周期,按一次键,输出信号的周期增大5ms,当增大到60ms后,周期就归于5ms。按键ZKB+和ZKB改变信号的占空比,按键ZKB+用于增加信号的占空比,按下一次键,占空比就增加1,上限值为99,当再次按键时,就让占空比归1。按键ZKB用于减小信号的占空比,按下一次键,占空比就减1,下限值为1,当再次按键时,就让占空比回归到99。通过上面的步骤,可以实现占空比和周期的可调。

同时,设计中采用了上电或开关复位电路用以应对其他可能事件。开关闭合复位后回复初值:占空比50%,周期35ms。

2.3定时器、的工作原理 定时/计数器实质上是一个加1计数器,它可以工作于定时方式,也可以工作于计数方式,两种工作方式实际是对脉冲计数,只不过是所计脉冲来源不同。定时/计数器的内部结构和控制信号如下图2所示:

当其工作于定时方式时, =0,开关S打向上,计数器,的计数脉冲来自振荡器的12分频后的脉冲(即fosc/12),即对系统的机器周期计数。档开关K受控合上时,每过一个周期,计数器,加1;

当记满了预设的个数,回零,置位定时/计数器溢出中断标志位,产生溢出中断。

图2 定时器/计数器内部结构和控制信号 2.3.1工作方式寄存器TMOD 工作方式寄存器TMOD(地址:89H)为8位寄存器,8位分为两组,高四位控制T1,低四位控制T0。用于设置定时/计数器的工作方式。其格式如下表2.3.1所示。

表2.3.1 定时/计数器方式控制寄存器TMOD D7 D6 D5 D4 D3 D2 D1 D0 GATE M1 M0 GATE M1 M0 | ← T1方式字段 → | ← T0方式字段 →| 下面对TMOD的各位作以说明:

(1)GATE:门控位。

GATE=0时,仅有运行控制位TR0(或TR1)=1,就可以启动定时/计数器工作;

GATA=1时,由TR0(或TR1)=1和外部中断引脚(INT0或INT1)上的高电平共 同启动定时/计数器工作。

(2)

——定时/计数模式选择位。

=0为定时模式;

=1为计数模式。

(3)M1,M0—工作方式选择位。

定时/计数器工作方式选择如下表2.3.2所示。

表2.3.2 定时/计数器工作方式设置表 M1 M0 工作方式 说明 0 0 方式0 13位定时/计数器 0 1 方式1 16位定时/计数器 1 0 方式2 8位初值自动重装入的8位定时/计数器 1 1 方式3 仅适用于T0,分成两个8位定时/计数器;

T1停止计数 2.3.2定时/计数器控制寄存器TCON TCON的字节地址为88H,可进行位寻址,位地址为88H—8Fh。

格式如下表2.3.3所示。

表2.3.3 定时/计数器控制寄存器TCON D7 D6 D5 D4 D3 D2 D1 D0 TF1 TR1 TF0 TR0 IE1 IT1 IE0 IT0 在TCON寄存器中,定时/计数器的控制仅用了其中的高四位。

(1)TF1,TF0——T1,T0溢出中断请求标志位。

当计数溢湖北哪家医院治疗癫痫比较好出时该位由硬件自动置为1。CPU响应中断后由硬件自动清0。工作时,CPU可随时查询TF的状态。所以,可用作查询测试的标志。也可以用软件置1或清0,同硬件置1或清0的效果一样。

(2)TR1,TR0——运行控制位。

置1时,启动定时/计数器工作;

还与GATE位的状态有关。

置0时,停止定时/计数器工作。

由软件置1或清0。所以,用软件可控制定时/计数器的启动与停止。

2.4定时/计数器的工作方式 (1)方式0为13位计数,由TL0的低5位(高3位未用)和TH0的8位组成,最大计数值为(8192个脉冲)。启动后计数器加1计数。TL0的低5位计数满回零后向进位,当13位计数满回零时,中断溢出位置1,产生中断请求。

定时器模式时有:N=t/ Tcy (Tcy指令周期)

计数初值计算的公式为:

(X计数初值,N计数个数)

定时器的初值还可以采用计数个数直接取补法获得。

(2)方式1和方式0基本相同,唯一的区别是方式1的计数位数是16位,由TL1作为低8位、TH1作为高8位,组成了16位加1计数器 。其最大计数值为(65536个脉冲),是几种方式中计数值最大的方式。

计数个数(N)与计数初值(X)的关系为:

(3)方式2为自动重装初值的8位计数方式。在这种方式下,在和两个寄存器中,专用于寄存8位计数初值并保持不变,进行8位加1计数,当计数溢出时,除产生溢出中断请求外,还自动将中不变的初值重新装载到。

计数个数与计数初值的关系为:

(4)方式3只适用于T0定时/计数器,T0定时器处于方式3时,T1只能工作在0,1,2方式。TL0和TH0被分成为两个独立的8位定时/计数器。其中TL0可作为8位定时/计数器,TH0只能作为8位定时器。

2.5设计方法 (1)方波的产生 在本设计方案中,采用的定时器产生周期和占空比可调的方波。对比于工作方式0,工作方式1具有16位的寄存器,定时时间更长,产生的频率范围更宽。对比于工作方式2,虽然方式2的自动重载功能使定时更加准确,但对于产生低频来说,方式2的只有256us的定时时间,产生的中断多,误差更大,因此选择设置在工作方式1下,GATE=0。

设定定时器设置初始值,即给高低电平分别分配定时时间。当程序启动,由输入给定高电平,定时器开始加1计数,当高电平16位计数满回零时,TF置1,产生中断,高电平转为低电平,当低电平16位计数满回零时,TF置1,产生中断,低电平再转为高电平,得出方波。

(2)高电平时间的测量 本设计方案中,采用定时器测量高电平的时间。将定时器设置在工作方式1下,并设置GATE=1,此时要用软件使TR1=1,同时外部中断1(INT1)引脚也为高电平时,才能启动定时/计数器工作。所以将控制输出的方波接在外部中断1的输入引脚上,当输入高电平,定时器开始启动,在下降沿的时候,读T1的值,即可算出高电平时间T1_high。

3.系统硬件电路设计图 对于系统的软件仿真采用了proteus软件设计仿真。

四个独立按键分别与单片机的P1.0,P1.1,P1.2,P1.3相连接,并且通过一个四输入的与非门,将与非门的输出当做单片机外部中断0的触发信号。当有按键按下时,就会进入外部中断程序。

P1.4口输出信号连接到示波器,检测输出波形。

RST复位引脚接入上电或开关复位,电源接通后,单片机自动复位,并且在单片机运行期间,用开关操作也能使单片机复位。

系统硬件仿真电路原理图如下图所示:

4.程序框图 4.1主程序框图:

图4 主程序流程图 4.2系统初始化:

初始化程序主要是给计数器0和1赋初值,初始化占空比为50%,信号周期为35ms,设置定时器0和定时器1的工作方式,并开启计数器0和计数器1,设置外部中断的触发方式,开启总中断。

4.3定时器中断程序框图:

定时器0用于控制输出信号的周期,定时器1用于控制输出信号的占空比。

开始 赋初始值 结束 图5 定时器中断程序框图 4.4键盘扫描程序框图:

当有按键按下时,进入到外部中断,然后暂时关闭外部中断,启动延时程序,以消除抖动。然后检测是哪个按键被按下,然后对频率或占空比的变量做出相应的赋值,并且将占空比的值送到数码管显示。并且对定时器0和定时器1分别赋新的初值,开启外部中断,定时器0和1中断,中断程序结束。

开始 关中断 延时消抖 是否有键按下 N N 判断按键号 Y 按键处理 计算定时器初值 送入初值 关中断 结束 图6 键盘扫描程序框图 5.性能分析 5.1定时器中断分析 本次周期占空比可调的信号发生器的设计采用了定时器0和定时器1中断,定时器0中断用于控制信号的周期,定时器1用于控制信号的占空比。当调节输出信号的占空比时,信号的频率就不变;

如果调节信号的频率,占空比就不变。设period表示输出的周期,zkb表示输出的占空比,TX为定时器0的计数次数,TZ为定时器1的计数次数。给TX装入初值为:TX=(65536N);给TZ装入初值为TZ=(65536N);

当定时器0计数到时,开启定时器1,定时器1开始计数,并且P1.4口输出高电平。当经过一个周期中高电平持续的时间后,定时器1计数时间就到了,程序进入到定时器1中断执行,然后关掉定时器1,并且输出低电平。因为定时器0中断是一直开着的,当经过一个周期中低电平持续的时间后,定时器0计数又到了,进入定时器0中断执行,如此循环。当改变period或者zkb的时候,就可以相应改变输出信号的周期跟占空比。

5.2系统性能分析 该系统实现占空比跟周期可调的信号发生器。占空比的调节范围是1%到99%,精度是1%,当达到上限值时,再次增加时,占空比归于1%,达到下限时,再次减少,占空比自动归于99%。周期的调节范围是5ms到60ms,精度是5ms,当达到上限值时,再次增加时,周期自动归于5ms,当达到下限值时,再次减少时,周期自动归于60ms)。

总之,这次设计达到了设计要求,输出的信号稳定度高,误差小,并且方便调节,硬件电路简单。

6.源程序 #include #define uchar unsigned char #define uint unsigned int //float fosc=120郑州癫痫治疗方法00000; //系统时钟频率 sbit key1=P1^0; //控制周期的增加 sbit key2=P1^1; //控制周期的减少 sbit key3=P1^2; //控制占空比的增加 sbit key4=P1^3; //控制占空比的减少 sbit clk=P1^4; //信号输出端口 uint zkb=50; //占空比初值,取值范围为1到99 uint period=35; //周期初值,取值范围为5ms到60ms uint time0_H,time0_L,time1_H,time1_L; //延时程序 void delayms(uint z) { uint i,j; for(i=z;i;i>0) for(j=110;j;j>0); } //系统初始化 void init() { TMOD=0x11; //定时器0和1都工作在方式1 time0_H=(6553635000)/256; time0_L=(6553635000)%256; time1_H=(6553617500)/256; time1_L=(6553617500)%256; TH0=time0_H; //定时器0装入初值,计数器计数35000次,35ms TL0=time0_L; TH1=time1_H; //定时器1装入初值,计数器计数17500次,17.5ms TL1=time1_L; IT0=1; //外部中断0为下降沿触发 EX0=1; //开外部中断0允许位 ET0=1; //定时器T0中断允许 ET1=1; //定时器T1中断允许 EA=1; //开启总中断 TR0=1; //开启定时器0 } //主程序 void main() { init( ); while(1); } //TO中断程序 void T0_time() interrupt 1 { TR1=1; //开定时器1 TH0=time0_H; TL0=time0_L; clk=1; } //T1中断程序 void T1_time() interrupt 3 { TR1=0; //关定时器1 TH1=time1_H; TL1=time1_L; clk=0; } //键盘扫描程序 void keyscan() interrupt 0 //外部中断0 { float TX,TZ; EX0=0; //关中断 delayms(10); //延时消抖 if(P1!=0x0F) if(key1==0) { period=period+5; if(period>60) period=5; } if(key2==0) { period=period5; if(period<5) period=60; } if(key3==0) { zkb=zkb+1; if(zkb>99) zkb=1; } if(key4==0) { zkb=zkb1; if(zkb<1) zkb=99; } TX=(65536(period)*1000); TZ=(65536(period/2)*1000+(50zkb)*period*10); time0_H=(uint)TX/256; time0_L=(uint)TX%256; time1_H=(uint)TZ/256; time1_L=(uint)TZ%256; P1=0x0f; EX0=1; TR0=1; TR1=1; } 7. 仿真效果图 1. 电路通电仿真初始状态 初始值:周期35ms,占空比50% 2. 按PERIOD键改变周期 3.按ZKB+或ZKB键改变占空比 总 结 此次课程设计真的让我着实收获颇多。

大三上学期了,就快要进入大四,此次课设也是大学仅剩的几个课设之一了,我想通过自己的努力,好好做一下,好好锻炼自己的专业能力。

接到这个题目,第一感觉还是蛮简单的。因为以前自己也自学过一段时间的单片机,我的题目是占空比和周期可调的信号发生器,我感觉蛮简单。但是当我真正的去做的时候,事情并不是我想象中的那样。

刚开始没有怎么弄懂原理,只是脑袋里面有一个很模糊的概念,要慢慢的把它实现出来。在网上找了点参考资料,自己设计了一个电路图,弄了一个汇编程序,在protues里面仿真的时候,没有达到自己想要的结果,我调试了很久,不断地改程序,但是结果总是差强人意,频率的变化很大,没有规律。由于汇编程序的跳转指令比较多,我纠结了半天都没弄出来。

然后我就开始该用C语言写程序,以前用C语言写过,对C语言有一定的基础。我还在网上找了一点资料,对我的原理图也做了改进,我认为最经典的地方是把四个按键通过一个四输入与非门连接到外部中断0的入口,这样就可以很方便的检测按键,为写程序提供了方便。通过这一点我了解到,好的硬件电路是软件的基础啊。电路设计好了之后,写程序就方便多了,很快程序写出来了,在Protues里面仿真成功了,当时感觉好开心。

这次课程设计,我花了好几天的时间,前期是查资料,从上个星期六开始,我就在寝室研究,不断地调试程序,从刚开始的毫无进展,到做出课设要求的波形,心里还是很开心的。我感觉想做点东西,自己必须沉下心来,查阅资料,自己思考,要有耐心,只要你能坚持,你肯定能做出你想要做的东西的。

这次的设计到最后基本达到了设计的要求,最重要的是,在本次设计过程中我学到了很多平时没有学到的或者说是很欠缺的东西,在一定程度上也提升了自己的能力,受益匪浅。

致 谢 首先,在本课题的设计过程中,我的指导老师李文方老师倾注了大量的心血,从选题到开题报告,从写作提纲,到一遍又一遍地指出每稿中的具体问题,严格把关,循循善诱,在此我表示衷心感谢。

其次,我还要感谢在我学习期间给我极大关心和支持的各位老师以及关心我的同学和朋友。是他们为我提供了良好的学习工作环境,让我从中获得了很多很多。

最后,在这课程设计结束之际,我还要感谢默默奉献的科技教育技术人员,他们为我们提供了很好的学习平台。在他们这些“伟人”的肩膀上我们可以看的更远,进步更快,学的更精。

参考文献 1、 《微型计算机原理与接口技术》.姚燕南,薛钧义.北京:高等教育出版社.2004 2、《单片微型计算机与接口技术》(第2版)李群芳,张士军,黄建.北京:电子 工业出版社.2005 3、《单片微型计算机原理及应用》.徐维祥,刘旭敏.大连:大连理工大学出版 社.2006 4、《单片机原理及应用》.张鑫,华臻,陈书谦.北京:电子工业出版社.2008 5、《单片机系统设计与实践》.汪道辉.北京:电子工业出版社.2006 6、《新编MCS51单片机应用设计》.张毅刚.哈尔滨工业大学出版社.2008

北京军海癫痫医院
治疗癫痫病最好的医院   北京最好的癫痫病医院   癫痫病医院   黑龙江中亚癫痫病医院   西安中际医院   北京军海医院   西安中际医院   北京治疗癫痫病的医院   癫痫病怎么治最好   癫痫病医院   治疗癫痫方法   北京哪家医院治疗癫痫好   治疗癫痫病的方法   癫痫病医院   长春癫痫病医院   沈阳癫痫病医院   包头癫痫病医院   西安癫痫病医院   太原治疗癫痫病医院   武汉癫痫病医院   治疗癫痫医院哪家好   北京军海癫痫病医院  



新华网  人民网  新浪新闻  北京癫痫医院排名  39健康  心里频道  郑州癫痫医院排名