收藏 分销(赏)

基于51单片机的数字频率计课程设计.doc

上传人:w****g 文档编号:2490369 上传时间:2024-05-30 格式:DOC 页数:20 大小:353.50KB 下载积分:10 金币
下载 相关 举报
基于51单片机的数字频率计课程设计.doc_第1页
第1页 / 共20页
基于51单片机的数字频率计课程设计.doc_第2页
第2页 / 共20页


点击查看更多>>
资源描述
四川航天学院电子工程系课程设计——基于51单片机的数字频率计 摘 要 MAXIM是直接用十进制数字显示被测信号频率的一种测量装置。传统的数字频率计大多采用74LS系列数字集成电路直接测频,在使用过程中存在电路结构复杂,测量精度低、故障率高、维护不易等问题。于是,随着芯片技术的发展,很多芯片被应用到频率计的设计当中。 一种是专用芯片,如利用MAXIM 公司的ICM7240制作的频率计。其特点是简单易行,但由于这种芯片的最高计数频率仅有15MHz,远不能达到在一些场合需要测量很高频率的要求,而且测量精度也受到芯片本身的限制。 以单片机为主再附加一些外围电路来设计数字频率计,采用这种方案有一个很大的优点,那就是可通过单片机的软件设计,采用适当的算法,取代很多以前用硬件实现的电路,这不仅能弥补以往频率计测量精度低、故障率高、维护不易等不足,而且性能也得到了很大的提高。 关键字:MAXIM 74LS MAXIM 高频率 芯片 目 录 第1节 引言 - 4 - 1.1数字频率计概述 - 4 - 1.2频率测量仪的设计思路与频率的计算 - 4 - 1.3 基本设计原理 - 5 - 第2节 数字频率计(低频)的硬件结构设计 - 5 - 2.1 系统硬件的构成 - 6 - 2.2 系统工作原理图 - 6 - 2.3 AT89C51单片机及其引脚说明 - 7 - 2.5 时基信号产生电路: - 9 - 2.6显示模块 - 11 - 1)、主要功能 - 11 - 2)、技术参数 - 11 - 3)、时序特性表 - 12 - 4)、引脚和指令功能 - 12 - 5)、显示位与DD RAM 地址的对应关系 - 13 - 6)、初始化方法 - 13 - 第3节 软件设计 - 15 - 3.1定时读数 - 15 - 3.2量程转换 - 15 - 3.3 BCD转换 - 15 - 3.4LCD显示的功能 - 15 - 结 束 语 - 16 - 参考文献 - 17 - 附件: - 17 - 基于51单片机的数字频率计 1.1数字频率计概述 数字频率计是计算机、通讯设备、音频视频等科研生产领域不可缺少的测量仪器。它是一种用十进制数字显示被测信号频率的数字测量仪器。它的基本功能是测量正弦信号,方波信号及其他各种单位时间内变化的物理量。在进行模拟、数字电路的设计、安装、调试过程中,由于其使用十进制数显示,测量迅速,精确度高,显示直观,经常要用到频率计。 本数字频率计将采用定时、计数的方法测量频率,采用一个1602A LCD显示器动态显示6位数。测量范围从1Hz—10kHz的正弦波、方波、三角波,时基宽度为1us,10us,100us,1ms。用单片机实现自动测量功能。 基本设计原理是直接用十进制数字显示被测信号频率的一种测量装置。它以测量周期的方法对正弦波、方波、三角波的频率进行自动的测量。 1.2频率测量仪的设计思路与频率的计算 图1 频率测量原理图 频率测量仪的设计思路主要是:对信号分频,测量一个或几个被测量信号周期中已知标准频率信号的周期个数,进而测量出该信号频率的大小,其原理如右图1所示。 若被测量信号的周期为,分频数m1,分频后信号的周期为T,则:T=m1Tx 。由图可知: T=NTo (注:To为标准信号的周期,所以T为分频后信号的周期,则可以算出被测量信号的频率f。) 由于单片机系统的标准频率比较稳定,而是系统标准信号频率的误差,通常情况下很小;而系统的量化误差小于1,所以由式T=NTo可知,频率测量的误差主要取决于N值的大小,N值越大,误差越小,测量的精度越高。 1.3 基本设计原理 基本设计原理是直接用十进制数字显示被测信号频率的一种测量装置。它以测量周期的方法对正弦波、方波、三角波的频率进行自动的测量。 所谓“频率”,就是周期性信号在单位时间(1s)内变化的次数。若在一定时间间隔T内测得这个周期性信号的重复变化次数N,则其频率可表示为f=N/T。其中脉冲形成电路的作用是将被测信号变成脉冲信号,其重复频率等于被测频率fx。时间基准信号发生器提供标准的时间脉冲信号,若其周期为1s,则门控电路的输出信号持续时间亦准确地等于1s。闸门电路由标准秒信号进行控制,当秒信号来到时,闸门开通,被测脉冲信号通过闸门送到计数译码显示电路。秒信号结束时闸门关闭,计数器停止计数。由于计数器计得的脉冲数N是在1秒时间内的累计数,所以被测频率fx=NHz。 第2节 数字频率计(低频)的硬件结构设计 2.1 系统硬件的构成 本频率计的数据采集系统主要元器件是单片机AT89C51,由它完成对待测信号频率的计数和结果显示等功能,外部还要有分频器、显示器等器件。可分为以下几个模块:放大整形模块、秒脉冲产生模块、换档模拟转换模块、单片机系统、LCD显示模块。各模块关系图如图2所示: 图2 数字频率计功能模块 2.2 系统工作原理图 该系统工作的总原理图如图3所示: 图3 数字频率计系统工作原理图 2.3 AT89C51单片机及其引脚说明 89C51是一种高性能低功耗的采用CMOS工艺制造的8位微控制器,它提供下列标准特征:4K字节的程序存储器,128字节的RAM,32条I/O线,2个16位定时器/计数器, 一个5中断源两个优先级的中断结构,一个双工的串行口, 片上震荡器和时钟电路。 引脚说明: ·VCC:电源电压 ·GND:地 ·P0口:P0口是一组8位漏极开路型双向I/O口,作为输出口用时,每个引脚能驱动8个TTL逻辑门电路。当对0端口写入1时,可以作为高阻抗输入端使用。 当P0口访问外部程序存储器或数据存储器时,它还可设定成地址数据总线复用的形式。在这种模式下,P0口具有内部上拉电阻。 在EPROM编程时,P0口接收指令字节,同时输出指令字节在程序校验时。程序校验时需要外接上拉电阻。 ·P1口:P1口是一带有内部上拉电阻的8位双向I/O口。P1口的输出缓冲能接受或输出4个TTL逻辑门电路。当对P1口写1时,它们被内部的上拉电阻拉升为高电平,此时可以作为输入端使用。当作为输入端使用时,P1口因为内部存在上拉电阻,所以当外部被拉低时会输出一个低电流(IIL)。 ·P2口:P2是一带有内部上拉电阻的8位双向的I/O端口。P2口的输出缓冲能驱动4个TTL逻辑门电路。当向P2口写1时,通过内部上拉电阻把端口拉到高电平,此时可以用作输入口。作为输入口,因为内部存在上拉电阻,某个引脚被外部信号拉低时会输出电流(IIL)。 P2口在访问外部程序存储器或16位地址的外部数据存储器(例如MOVX @ DPTR)时,P2口送出高8位地址数据。在这种情况下,P2口使用强大的内部上拉电阻功能当输出1时。当利用8位地址线访问外部数据存储器时(例MOVX @R1),P2口输出特殊功能寄存器的内容。 当EPROM编程或校验时,P2口同时接收高8位地址和一些控制信号。 ·P3口:P3是一带有内部上拉电阻的8位双向的I/O端口。P3口的输出缓冲能驱动4个TTL逻辑门电路。当向P3口写1时,通过内部上拉电阻把端口拉到高电平,此时可以用作输入口。作为输入口,因为内部存在上拉电阻,某个引脚被外部信号拉低时会输出电流(IIL)。 P3口同时具有AT89C51的多种特殊功能,具体如下表1所示: 端口引脚 第二功能 P3.0 RXD (串行输入口) P3.1 TXD(串行输出口) P3.2 (外部中断0) P3.3 (外部中断1) P3.4 T0(定时器0) P3.5 T1(定时器1) P3.6 (外部数据存储器写选通) P3.7 (外部数据存储器都选通) 表1 P3口的第二功能 •RST:复位输入。当振荡器工作时,RST引脚出现两个机器周期的高电平将使单片机复位。 •ALE/ :当访问外部存储器时,地址锁存允许是一输出脉冲,用以锁存地址的低8位字节。当在Flash编程时还可以作为编程脉冲输出( )。 一般情况下,ALE是以晶振频率的1/6输出,可以用作外部时钟或定时目的。但也要注意,每当访问外部数据存储器时将跳过一个ALE脉冲。 • :程序存储允许时外部程序存储器的读选通信号。当AT89C52执行外部程序存储器的指令时,每个机器周期 两次有效,除了当访问外部数据存储器时, 将跳过两个信号。 • /VPP:外部访问允许。为了使单片机能够有效的传送外部数据存储器从0000H到FFFH单元的指令, 必须同GND相连接。需要主要的是,如果加密位1被编程,复位时EA端会自动内部锁存。 当执行内部编程指令时, 应该接到VCC端。 •XTAL1:振荡器反相放大器以及内部时钟电路的输入端。·XTAL2:振荡器反相放大器的输出端。 在本次设计中,采用89C51作为CPU处理器,充分利用其硬件资源,结合D触发器CD4013,分频器CD4060,模拟转换开关CD4051,计数器74LS90等数字处理芯片,主要控制两大硬件模块,量程切换以及显示模块。下面还将详细说明。 2.4 信号调理及放大整形模块 放大整形系统包括衰减器、跟随器、放大器、施密特触发器。它将正弦输入信号Vx整形成同频率方波Vo,幅值过大的被测信号经过分压器分压送入后级放大器,以避免波形失真。由运算放大器构成的射级跟随器起阻抗变换作用,使输入阻抗提高。同相输入的运算放大器的放大倍数为(R1+R2)/R1,改变R1的大小可以改变放大倍数。系统的整形电路由施密特触发器组成,整形后的方波送到闸门以便计数。 由于输入的信号幅度是不确定、可能很大也有可能很小,这样对于输入信号的测量就不方便了,过大可能会把器件烧毁,过小可能器件检测不到,所以在设计中采用了这个信号调理电路对输入的波形进行阻抗变换、放大限幅和整形,信号调理部分电路具体实现电路原理图和参数如下图4所示: 图4 2.5 时基信号产生电路: CD4013------双上升沿D触发器 ,引脚及功能见如下图5: CD4013 由两个相同的、相互独立的数据型触发器构成。每个触发器有独立的数据置位复位时钟输入和 Q及Q非输出。此器件可用作移位寄存器,且通过将Q非输出连接到数据输入,可用作计数器和触发器。在时钟上升沿触发时,加在D 输入端的逻辑电平传送到Q输出端。置位和复位或复位线上的高电平完成。 图5 CD4013芯片引脚用功能图 CD4060------14位二进制串行计数器,引脚及功能见如下图6: CD4060 由一震荡器和14极二进制串行计数器位组成,震荡器的结构可以是RC或晶振电路。CR为高电平时,计数器清零且振荡器使用无效,所有的计数器位均为主从触发器 CP1非(和 CP0)的下降沿计数器以二进制进行计数,在时钟脉冲线上使用施密特触发器对时钟上升和下降时间无限制。 图6 CD4060芯片引脚用功能图 时基信号的产生原理: 本电路采用32768HZ晶体震荡器,利用CD4060芯片经过14级分频得到2HZ的信号(32768/214),在经过CD4013双D触发器经过二分频得到0.5HZ的方波,即输出秒脉冲信号使单片机进行计数。 图七 秒脉冲产生电路原理图 2.6显示模块 1602基本技术: 1)、主要功能 A、 40通道点阵LCD 驱动; B、 可选择当作行驱动或列驱动; C、 输入/输出信号:输出,能产生20×2个LCD驱动波形;输入,接受控制器送出的串行数据和控制信号,偏压(V1∽V6); D、 通过单片机控制将所测的频率信号读数显示出来。 2)、技术参数 2.1)极限参数表 名 称 符 号 标 准 值 单 位 MIN TYPE MAX 电路电源 VDD - VSS -0.3 7.0 V LCD驱动电压 VDD - VEE VDD - 13.5 VDD + 0.3 V 输入电压 VIN -0.3 VDD + 0.3 V 静电电压 - - 100 V 工作温度 -20 +70 °C 储存温度 -30 +80 °C 2.2) 电参数表 名 称 符 号 测 试 条 件 标 准 值 单位 MIN TYPE MAX 输入高电平 VIH - 2.2 VDD V 输入低电平 VIL - -0.3 0.6 V 输出高电平 VOH IOH = 0.2mA 2.4 - V 输出低电平 VOL IOL = 1.2mA - 0.4 V 工作电流 IDD VDD = 5.0V 2.0 mA 液晶驱动电压 VDD- VEE Ta = 0°C 4.9 V Ta = 25°C 4.7 Ta = 50°C 4.5 3)、时序特性表 项 目 符 号 测试条件 标 准 值 单位 MIN TYPE MAX 允许时间周期 TCYCE 5.1a 5.1b 1000 ns 允许脉冲宽度,高电平 PWEH 450 -- -- ns 允许上升和下降时间 tEr tEf -- -- 25 ns 地址建立时间 tAS 140 -- -- ns 数据延迟时间 tDDR -- -- 320 ns 数据建立时间 tDSW 195 -- -- ns 数据保持时间 tH 10 -- -- ns DATA HOLD TIME tDHR 20 -- -- ns 地址保持时间 tAH 10 -- -- ns 4)、引脚和指令功能 4.1)模块引脚功能表 引 线 号 符 号 名 称 功 能 1 Vss 接地 0V 2 VDD 电路电源 5V±10% 3 VEE 液晶驱动电压 保证VDD-VEE=4.5∽5V电压差 4 RS 寄存器选择信号 H:数据寄存器 L:指令寄存器 5 R/W 读/写信号 H:读 L:写 6 E 片选信号 下降沿触发,锁存数据 7 | 14 DB0 | DB7 数据线 数据传输 4.2)寄存器选择功能表 RS R/W 操 作 0 0 指令寄存器(IR)写入 0 1 忙标志和地址计数器读出 1 0 数据寄存器(DR)写入 1 1 数据寄存器读出 (注:忙标志为"1"时,表明正在进行内部操作,此时不能输入指令或数据,要等内部操作结束,即忙标志为"0"时。) 4.3) 指令功能 格式:RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 共11种指令:清除,返回,输入方式设置,显示开关,控制,移位,功能设置,CGRAM地址设 置,DDRAM地址设置,读忙标志,写数据到CG/DDRAM,读数据由CG/DDRAM。 5)、显示位与DD RAM 地址的对应关系 显 示 位 序 号 1 2 3 4 5 ……………… 40 DD RAM 地 址(HEX) 第 一 行 00 01 02 03 04 ..………….. 27 第 二 行 40 41 42 43 44 …………….. 67 6)、初始化方法 用户所编的显示程序,开始必须进行初始化,否则模块无法正常显示,下面介绍两种初始化方法; 6.1利用内部复位电路进行初始化 下面指令是在初始化过程中执行的。 (1) 清屏(DISPLAY CLEAR); (2) 功能设置(FUNCTION SET); DL = 1: 8Bit 接口数据; N = 0: 1行显示; F = 0:5×7dot字形; (3) 显示开/关控制(DISPLAY ON/OFF CONTROL) D = 0: 显示关; C = 0: 光标关; B = 0: 消隐关 (4) 输入方式设置(ENTRY MODE SET ) I/D = 1:(增量): S = 0: 无移位: 6.2) 软件复位 如果电路电源不能满足复位电路的要求的话,那么初始化就要用软件来实现,过程如下: 八位接口初始化流程图 VDD 上升到4.5V后等待>15 电 源 开 ↓ RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 1 1 × × × × ↓ ↓等待>4.1ms RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 1 1 × × × × RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 1 1 × × × × ↓等待>100us RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 1 1 N F × × ↓检查忙标志或延时40us RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 0 0 1 0 × × ↓检查忙标志或延时40us RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 0 0 0 0 0 1 ↓检查忙标志或延时40 us RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 0 0 0 1 I/D S ↓检查忙标志或延时1.64 初 始 化 结 束 ↓检查忙标志或延时40 第3节 软件设计 主要能过编写软件来控制硬件完成以下各模块的功能: 3.1定时读数 3.2量程转换 3.3 BCD转换 3.4LCD显示的功能 单片机当C/T=1时为计数方式,多路开关与定时器的外部引脚连通,外部计数脉冲由引脚输入。当外部信号由1至0跳变时,计数器加1,此时T0成为外部事件的计数器。由于确认一次由1至0的跳变要用24个振荡器周期,所以计数器的计数频率为单片机内部计数器频率的1/24。 当C/T=0时为定时方式,对单片机内部计数器进行m2分频后,计数器的实际计数频率为单片机内部频率凡的1/m2, 当GATE=0时,反相器输出为1,或门输出为1,打开与门,使定时器的启动仅受TRO端信号电平的控制。 在此种情况下,INT0引脚的电平变化对或门不起作用。TRO=1时接通控制开关,计数脉冲加到计数器上,每来一个计数脉冲,计数器加1,只有当TRO=0时,控制开关断开,计数器停止计数。 当GATA=0时,若TRO=1,或门、与门全部打开,外部信号电平通过INTO引脚直接控制定时器的启动和关闭。输人高电平时允许计数,否则停止计数。 根据定时器的结构原理,若我们将GATE位、TR0均设为‘1’,INT0端输人被测频率信号,当被测信号的高电平到来时,开始计数;当被测信号的低电平到来时,计数器停止计数,此时TL0、TH0的数据就是相应的N值。 #include <reg51.H>  unsigned  char  code  dispcode[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};  unsigned char a=0,b=0,c=0,d=0;  unsigned int pinlv=0;  unsigned long int count=0;  void delay()  {  int j;  for(j=0;j<2000;j++);  }  void display()  { a=pinlv/1000;         // 千位     b=pinlv/100%10;   百位 c=pinlv%100/10;  十位 d=pinlv%10;  个位 P2=0xfe;   P0=dispcode[a];  delay();  P2=0xfd;  P0=dispcode[b];  delay();  P2=0xfb;  P0=dispcode[c];  delay();  P2=0xf7   P0=dispcode[d];  delay();  }  /*void delay1(n)  {  int i,j;  for(i=0;i<n;i++)  {  for(j=0;j<255;j++){   }  display();  }  } */  void main(void)  {  EA=0;  TMOD=0x51; //T0 定时 T1 计数 TH0=15602/256;  //0x3c,T0 定时 50ms TL0=15602%256;  //0x00  T1=1;  ET0=1;  17  EA=1;  TR1=1;  TR0=1; while(1)  {  display();  }  }  void time0(void) interrupt 1 using 2  {  ET0=0;  count++;  if(count==20)  //T1 计数 20次 {  count=0;  TR1=0;  pinlv=TH1*256+TL1;  TH1=0;  TL1=0;  TR1=1;  }  TH0=15602/256;  //0x3c  TL0=15602%256;  // 0x00  TR0=1; ET0=1;  //T1 计数 20次时产生中断,定时1S到 目 录 第一章 总 论 1 1.1项目概况 1 1.2研究依据及范围 2 1.3结论 3 1.4建议 4 第二章 项目建设的背景和必要性 5 2.1项目建设的背景 6 2.2项目建设的必要性 7 第三章 项目服务需求分析 9 第四章 项目选址与建设条件 11 4.1选址原则 11 4.2项目选址 11 4.3建设条件 12 第五章 建设方案与设计 12 5.1建设规模与内容 12 5.2总体规划设计 13 5.3结构方案 18 5.4主要配套设备 19 5.5给水工程 20 5.6排水工程 22 5.7电气设计 23 5.8节能设计 26 第六章 项目实施进度和招投标管理 29 6.1 项目实施进度 29 6.2招投标管理 31 第七章 环境影响分析 31 7.1项目主要污染源分析 32 7.2 环境保护措施及治理效果 35 第八章 消防、安全与卫生防护 37 8.1 消防 37 8.2  劳动安全 38 8.3  卫生防护 39 第九章 组织机构、运作方式与项目实施进度 39 9.1  项目建设组织机构 39 9.2项目运营组织机构 41 9.3劳动定员 42 第十章 投资估算和资金筹措 42 10.1投资估算 43 10.2 项目所需流动资金 49 10.3资金筹措 49 第十一章  经济和社会效益评价 50 11.1 经济效益评价 50 11.2 社会效益评价 50 第十二章 结 论 50 12.1 主要结论 50 12.2 建 议 51 附录:1、****发改局《关于*******迁建工程项目建议书的批复》 2、****村镇建设管理所《*******迁建项目用地红线》 - 19 -
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 研究报告 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服