中国高校课件下载中心 》 教学资源 》 大学文库

《数字电路与逻辑设计》课程实验指导(课程设计)设计三 数字频率计的设计

文档信息
资源类别:文库
文档格式:DOC
文档页数:20
文件大小:900.5KB
团购合买:点击进入团购
内容简介
《数字电路与逻辑设计》课程实验指导(课程设计)设计三 数字频率计的设计
刷新页面文档预览

3数字频率计的设计 设计要求 设计一个能测量方波信号频率的频率计,测量结果用十进制数显示 2.测量的频率范围是1~10KHz,分成两个频段,即1~999H2,1KH210KHz,用三 位数码管显示测量频率,用LED显示表示单位,如亮绿灯表示Hz,亮红灯表示 KHz。 3且有白动验和刚品两种功能,即能用标准时钟炒验侧品结度 4.具有超量程报警功能,在超出目前量程档的测量范围时,发出灯光和音响信号。 单位显 陆存器 LD E 图1颜率计系统框图。 设计提示 ●脉冲信号的频率就是在单位时间内所产生的脉冲个数,其表达式为=NT,f 为被测信号的频率,N为计数器所累计的脉冲个数,T为产生N个脉冲所需 的时间。所以,在1秒时间内计数器所记录的结果,就是被测信号的频率。 ·测量校验选择模块* 计数器模块 ·送存选择报警模块 ·锁存模块 。扫描显示模块 。测量校验选择模块* 输入信号:选择信号selet被测信号meas测试信号test 输出信号:CP1 当selet=-0时,为测量状态,CPI=meas: 当selet=1时,为校验状态,CPI=test。 校验与测量共用一个电路,只是被测信号CP1不同而已。 少定时信号(周期为2秒),在1秒定时时间内的所有被测信号送计数 器输入端。 ·计数器对CP1信号进行计数,在1秒定时结束后,将计数器结果送锁存器锁

3 数字频率计的设计 设计要求 1.设计一个能测量方波信号频率的频率计,测量结果用十进制数显示。 2. 测量的频率范围是 110KHz,分成两个频段,即 1999Hz,1KHz10KHz,用三 位数码管显示测量频率,用 LED 显示表示单位,如亮绿灯表示 Hz,亮红灯表示 KHz。 3. 具有自动校验和测量两种功能,即能用标准时钟校验测量精度。 4. 具有超量程报警功能,在超出目前量程档的测量范围时,发出灯光和音响信号。 设计提示 ⚫ 脉冲信号的频率就是在单位时间内所产生的脉冲个数,其表达式为 f=N/T,f 为被测信号的频率,N 为计数器所累计的脉冲个数,T 为产生 N 个脉冲所需 的时间。所以,在 1 秒时间内计数器所记录的结果,就是被测信号的频率。 ⚫ 测量/校验选择模块* ⚫ 计数器模块 ⚫ 送存选择报警模块 ⚫ 锁存模块 ⚫ 扫描显示模块 ⚫ 测量/校验选择模块* 输入信号:选择信号 selet 被测信号 meas 测试信号 test 输出信号:CP1 当 selet=0 时,为测量状态,CP1=meas; 当 selet=1 时,为校验状态,CP1=test。 校验与测量共用一个电路,只是被测信号 CP1 不同而已。 ⚫ 设置 1 秒定时信号(周期为 2 秒),在 1 秒定时时间内的所有被测信号送计数 器输入端。 ⚫ 计数器对 CP1 信号进行计数,在 1 秒定时结束后,将计数器结果送锁存器锁

存,同时将计数器清零,为下一次采样测量做好准备。 ●设置量程档控制开关K,单位显示信号Y,当K=0时,为1~999Hz量程档 数码管显示的数值为被测信号频率值,Y显示绿色,即单位为H2:当K=1 时, 0KHz量程档,被测信号频率值为数码管显示的数值乘1000 即单位为KHz。 。设置超出量程档测量范围示警信号alert。计数器由四级十进制计数构成(带 进位C)。若被测信号频率小于1KHz(K=O),则计数器只进行三级十进制计 数,最大显示值为999.Hz,如果被测信号频率超过此范围,示警信号驱动灯 光、扬声器报警:若被测信号为1KHz10KH2(K=1),计数器进行四位十进 制计数,取高三位显示,最大显示值为9.99水Hz,如果被测信号频率超过此 范围,报警。 alert 单位显示 1Hz时钟源 被测信号 FPGA/CPLD meas 标准时钟 test k select % 购2 图2数字频率计硬件系統示意图 设计文档 一是的原归结成一句活,即在单位时间内对号进行计数。下图说 测频的原理及误差产生的原因。 Π几ΠΠ几几几 丢失(少一个腺冲) 计到7个脉冲 (比际密0x个条冲神) 图1测频的原理 在上图中,假设时基信号为1khz,则用此法测得待测信号为1khz*7=70kh2。但

存,同时将计数器清零,为下一次采样测量做好准备。 ⚫ 设置量程档控制开关 K,单位显示信号 Y,当 K=0 时,为 1999Hz 量程档, 数码管显示的数值为被测信号频率值,Y 显示绿色,即单位为 Hz;当 K=1 时,为 1KHz10KHz 量程档,被测信号频率值为数码管显示的数值乘 1000, Y 显示红色,即单位为 KHz。 ⚫ 设置超出量程档测量范围示警信号 alert。计数器由四级十进制计数构成(带 进位 C)。若被测信号频率小于 1KHz(K=0),则计数器只进行三级十进制计 数,最大显示值为 999.Hz,如果被测信号频率超过此范围,示警信号驱动灯 光、扬声器报警;若被测信号为 1KHz10KHz(K=1),计数器进行四位十进 制计数,取高三位显示,最大显示值为 9.99KHz,如果被测信号频率超过此 范围,报警。 设计文档 一、原理 测频的原理归结成一句话,即在单位时间内对被测信号进行计数。下图说明了 测频的原理及误差产生的原因。 图 1 测频的原理 在上图中,假设时基信号为 1khz,则用此法测得待测信号为 1khz*7=70khz。但

从图中可以看出,待测信号应该在77kz,误差约为777~9.1%。这个误差是比较大 的,实际上,测量的脉冲个数的误差会在±1间。假设所测得脉冲个数为,则所测 频率的最大误差为1/(n-1)*100%。显然,减小误差的方法就是增大n。本频率计 的要求测量结果以3位数表示,则测频误差应为1%0.1%,则的取值范围为: 100≤n<100 即时基信号的频率为量程中最低频率的1100(同时约为最高频率的11000)。通过 计算得出下表中的数据。 待测信号与时基信号的关系 待测信号hz 时基信号z 10-99.9 100 1-9.99 10 二、系统框图 分频器 各档时基信号 费想件号与 一发光二极管 状态机 七段数码管 一七股数码管 信号同步 译码电路 整形电路 锁存器 计数器 图2数字频率计系统框图 根据题意,各个模块的作用简述如下: 1、分频器:由于测频时不同量程需要不同的时基信号,分频模块是必不可少的

从图中可以看出,待测信号应该在 77khz,误差约为 7/77~9.1%。这个误差是比较大 的,实际上,测量的脉冲个数的误差会在  1 间。假设所测得脉冲个数为 n,则所测 频率的最大误差为 1/(n-1)*100%。显然,减小误差的方法就是增大 n。本频率计 的要求测量结果以 3 位数表示,则测频误差应为 1%~0.1%,则 n 的取值范围为: 100  n<100 即时基信号的频率为量程中最低频率的 1/100(同时约为最高频率的 1/1000)。通过 计算得出下表中的数据。 待测信号与时基信号的关系 待测信号/khz 时基信号/hz 10~99.9 100 1~9.99 10 二、系统框图 图 2 数字频率计系统框图 根据题意,各个模块的作用简述如下: 1、分频器:由于测频时不同量程需要不同的时基信号,分频模块是必不可少的

系统通过分频模块从晶振时钟(20Mz)分出系统所需要的几个时基信号,其中包 括状态机所需时钟。 2、计数器:从原理中可以看出,测频的本质上是计数,所以计数器也是系统中不 可或缺的模块。为实现量程的自动转换,本计数器需输出指示超量程和欠量程状态 的信是 3、状态机:题目要求本系统可以自动转换量程,如果把每个量程看成一个状态, 那么量程的切换实际上就是状态的转换。显然,用状态机来实现是最方便的。 4、其他:如锁存器(用来使显示数字稳定)、同步整形电路(用来处理超量程和欠 量程信号,避免状态机多次转移)和七段数码管译码电路等。 三、各功能模块的实现 1状态机的设计 系统的状态机是用来自动切换量程的。根据前面的分析,我们可以设立4个状 态,状态名及其对应的量程如下表所列 状态名 对应量程 时基信号州z F100K 10-99.9kHz 100 F10K 1-999kHz 10 OverError 超过数字频率计最高频率 100 LowError 低于数字频率计最低频率 10 假设计数器的超量程信号为over,欠量程信号为low,那么可以画出如下图所 示的状态转移图 图3状态转移图 根据此状态转移图,很容易就可以写出对应的状态机程序。状态机见附录1

系统通过分频模块从晶振时钟(20MHz)分出系统所需要的几个时基信号,其中包 括状态机所需时钟。 2、计数器:从原理中可以看出,测频的本质上是计数,所以计数器也是系统中不 可或缺的模块。为实现量程的自动转换,本计数器需输出指示超量程和欠量程状态 的信号。 3、状态机:题目要求本系统可以自动转换量程,如果把每个量程看成一个状态, 那么量程的切换实际上就是状态的转换。显然,用状态机来实现是最方便的。 4、其他:如锁存器(用来使显示数字稳定)、同步整形电路(用来处理超量程和欠 量程信号,避免状态机多次转移)和七段数码管译码电路等。 三、各功能模块的实现 1 状态机的设计 系统的状态机是用来自动切换量程的。根据前面的分析,我们可以设立 4 个状 态,状态名及其对应的量程如下表所列 状态名 对应量程 时基信号/Hz F100K 10—99.9kHz 100 F10K 1—9.99kHz 10 OverError 超过数字频率计最高频率 100 LowError 低于数字频率计最低频率 10 假设计数器的超量程信号为 over,欠量程信号为 low,那么可以画出如下图所 示的状态转移图。 图 3 状态转移图 根据此状态转移图,很容易就可以写出对应的状态机程序。状态机见附录 1

图4状态机的仿真波形 2计数器的设计 计数器的原理很简单,计数值大于999,就将超量程信号Ovr置1:若计数值 小于100,则将欠量程信号Low置1。 本计数器在待计数信号的两个周期内完成计数与控制信号(Ov©r与Low)的 传输,在量程合适的情况下,将计数值输出。在这两个时钟周期内,第1个时钟周 期完成计数,第2个时钟周期完成控制信号的传输与计数值输出。这样做的好处是 稳定,将计数与控制信号传输分开进行,避免了时钟的跳变。 计数器的程序见附录2。 20ns 0s 60s -clack2 bw 号的 0T27305a7a9 0 O/nUmG 0020000a▣ numt 0 图5计数器仿真波形 3同步整形电路的设计 在实际应用中 外部输入的异步信号常常需要进行同步化(与系统时钟同步) 和整形(将输入信号整形为一个时钟周期长的信号脉冲),其波形图见图6。其 程序见附录3

图 4 状态机的仿真波形 2 计数器的设计 计数器的原理很简单,计数值大于 999,就将超量程信号 Over 置 1;若计数值 小于 100,则将欠量程信号 Low 置 1。 本计数器在待计数信号的两个周期内完成计数与控制信号(Over 与 Low)的 传输,在量程合适的情况下,将计数值输出。在这两个时钟周期内,第 1 个时钟周 期完成计数,第 2 个时钟周期完成控制信号的传输与计数值输出。这样做的好处是 稳定,将计数与控制信号传输分开进行,避免了时钟的跳变。 计数器的程序见附录 2。 图 5 计数器仿真波形 3 同步整形电路的设计 在实际应用中,外部输入的异步信号常常需要进行同步化(与系统时钟同步) 和整形(将输入信号整形为一个时钟周期长的信号脉冲),其波形图见图 6。其 程序见附录 3

Name: Valu 500ns 100.0n 150.0ns signalin clock signalou 图6同步整形电路仿真波形 4分频器的设计 要得到状态机及各个功能模块所需的各种频率,就必须通过分频器从己知的 频率中得到,我们先实现了200分频和10分须,然后通过如下电路得到了所需 的频率: 速腿三南g udoha 图7分频器总图 10分频、200分频和分频模块的波形仿真如下: Name: 23s00s0s0s1msm0s10s1简0s1阅 oUUUUUUUUU 012345678901234567 图8十分频器仿真波形

图 6 同步整形电路仿真波形 4 分频器的设计 要得到状态机及各个功能模块所需的各种频率,就必须通过分频器从已知的 频率中得到,我们先实现了 200 分频和 10 分频,然后通过如下电路得到了所需 的频率: 图 7 分频器总图 10 分频、200 分频和分频模块的波形仿真如下: 图 8 十分频器仿真波形

制ssms迎s阳s就0s做0ssg如s0sss】 TTTTTTT 0 丙无7刀网00m的8西国日丽的02阳网3第7阳丽 图9200分频仿真波形 100.ns 0s 300.0ns 400.0ns 50.0s 600.0ns 700.0ns B00.0ns 900.0 U @ckOk恒 Dch10h位 och恤 0 图10分频器模块仿真波形 10分频和200分频的程序见附录4。 5锁存器的设计 在本课题中,用的是一个正沿触发的D锁存器,它有一个数据输入端d, 一个 时钟输入端ck和 个数据输出端q。D锁存器的输出端只有在正脉冲沿过后,输入 端d的数据才传递到输出端q。用VHDL语言描述该D锁存器的程序见附录5。 上述D锁存器只是一个单输入输出的锁存器,通过元件例化将单输入输出的锁 存器扩张成3输入输出的锁存器。详见下图: 59 33 图11锁存器模块

图 9 200 分频仿真波形 图 10 分频器模块仿真波形 10 分频和 200 分频的程序见附录 4。 5 锁存器的设计 在本课题中,用的是一个正沿触发的 D 锁存器,它有一个数据输入端 d,一个 时钟输入端 clk 和一个数据输出端 q。D 锁存器的输出端只有在正脉冲沿过后,输入 端 d 的数据才传递到输出端 q。用 VHDL 语言描述该 D 锁存器的程序见附录 5。 上述 D 锁存器只是一个单输入输出的锁存器,通过元件例化将单输入输出的锁 存器扩张成 3 输入输出的锁存器。详见下图: 图 11 锁存器模块

Name 500ns 100.0ns 1500s U 0 图12锁存器仿真波形 Rane 00s· 00n 0s Mm301B00m00m0m01010001t0i000101001110m1011010011 Fwn8邵0月0m0m00m1o1001000010100110m101100011 Mn4月0m0m0m100010000100010m10110001 0Mmot03.0咋00000010010Y0110100101Y01001110010m1001 号mouB3d啡000010000101001010i001010m1100 mot480啡0m0m0001000110100010i0011000m100 图13锁存器模块仿真波形 6显示器的设计 七段数码管分为共阴极和共阳极两种。简而言之,对共阴极来说,公共引脚要 接地,想要点亮某段数码管,就在相应的引脚上加高电平:对共阳极来说正好相反, 公共引脚提高电平, 想要点亮某段数码管 就在相应的引脚上加低电平 设计时用的是并行连接的七段数码管驱动程序。并行连接,即每个数码管都由 单独的译码电路控制,各数码管之间除地端GND接在一起外,其余引脚各不相关。 并行法的优点是控制简单,有几个数码管就用几个译码电路,不必修改程序,十分 简单。但当系统中所需粉码管较多时,文种方法溉耗资顶,又上用较多的门口 N个数码管需占用N个引脚 (若需要小数点,则是8N个引脚)。因此,此接法适 合于系统中数码管数量不多的应用场合。 所以,本设计中用并行连接比较方便。 带使能端的译码器的程序见附录6,根据该程序通过类属映射得到显示器, ■ 1 5num B0wm00m10001000010t001t110m0 创 11t001o01o10111010101010101t111001tit1 ■

图 12 锁存器仿真波形 图 13 锁存器模块仿真波形 6 显示器的设计 七段数码管分为共阴极和共阳极两种。简而言之,对共阴极来说,公共引脚要 接地,想要点亮某段数码管,就在相应的引脚上加高电平;对共阳极来说正好相反, 公共引脚提高电平,想要点亮某段数码管,就在相应的引脚上加低电平。 设计时用的是并行连接的七段数码管驱动程序。并行连接,即每个数码管都由 单独的译码电路控制,各数码管之间除地端 GND 接在一起外,其余引脚各不相关。 并行法的优点是控制简单,有几个数码管就用几个译码电路,不必修改程序,十分 简单。但当系统中所需数码管较多时,这种方法既耗资源,又占用较多的 I/O 口, N 个数码管需占用 7N 个引脚(若需要小数点,则是 8N 个引脚)。因此,此接法适 合于系统中数码管数量不多的应用场合。 所以,本设计中用并行连接比较方便。 带使能端的译码器的程序见附录 6,根据该程序通过类属映射得到显示器

图14七段数码管仿真波形 的mE 21s 00s 创 子um成 子mb B000m000100【01010001X0110011100】1011010101 子um 300000010001000010100t1100101100101 11001000101100101011010101tt10t1110100 云m的 tH00001000101o101010t0H00t01010 110010010100010101010t01001100100 图15显示器仿真波形 下图为数字频率计的顶层文件图。其中clkproduct是分频模块,statemachine 为状态机,counter为计数器,signallatch为同步整形电路,numlatch为琐存器, shownum为七段数码管译码电路。 COUNTER 1: 图16数字频率计顶层文件

图 14 七段数码管仿真波形 图 15 显示器仿真波形 下图为数字频率计的顶层文件图。其中 clkproduct 是分频模块,statemachine 为状态机,counter 为计数器,signallatch 为同步整形电路,numlatch 为琐存器, shownum 为七段数码管译码电路。 图 16 数字频率计顶层文件

图中的输入输出引脚的作用如下表所列。 输入输出引脚的作用 引脚名 作用 Clock 接品振时钟(20mhz) Clkin 接待训信号 Dpl 接百为的小数点 Dp2 接十位的小数点 Overlight 接表征高溢出的发光二极管 Lowlight 接表征低流出的发光二极管 Lsb|0.6] 接个位七段数码管 Middle[0.6] 接十位七段数码 Msb[0.6] 接百位七段数码管 实际操作的设计过程如下: (1)系统层次划分/画出系统框图 按照“自顶而下”的设计方法对系统进行划分(确定系统由哪些模 块构成,各模块又由哪些子模块构成)。 (2) 编码 EMAX+plusII的编辑器中写出VHDL代码。 (3)编译 编译器会对VHDL程序进行语法检查,还会产生用于防真的 些内部信息。这二步骤通常由编译器自动完成,毋须我们干预, 果VHDL语法有错误,编译无法通过 到 2) 事实上,在VHDL设计过程中,常常需要往后退 修改程序。 (4)功能仿真 VHDL仿真器允许定义输入并应用到设计中,不必生成实际电路 就可以观察出。此仿真主要用于检验系统功能设计的正确性,不涉及 具体器件的特性。 例如:library ieee; use ieee.std_logic1164.all; entity shownum is en:in std_logic; numina numinb.numinc:in integer range 0 to 15; Isb.middle,msb:out std_logic_vector(to6) end;

图中的输入/输出引脚的作用如下表所列。 输入/输出引脚的作用 引脚名 作用 Clock 接晶振时钟(20mhz) Clkin 接待测信号 Dp1 接百为的小数点 Dp2 接十位的小数点 Overlight 接表征高溢出的发光二极管 Lowlight 接表征低溢出的发光二极管 Lsb[0.6] 接个位七段数码管 Middle[0.6] 接十位七段数码管 Msb[0.6] 接百位七段数码管 实 际 操 作 的 设 计 过 程 如 下 : ( 1) 系 统 层 次 划 分 /画 出 系 统 框 图 按 照 “自 顶 而 下 ”的 设 计 方 法 对 系 统 进 行 划 分 ( 确 定 系 统 由 哪 些 模 块 构 成 , 各 模 块 又 由 哪 些 子 模 块 构 成 )。 ( 2) 编 码 在 MA X +plusII 的 编 辑 器 中 写 出 VHDL 代 码 。 ( 3) 编 译 编 译 器 会 对 V HDL 程 序 进 行 语 法 检 查 , 还 会 产 生 用 于 防 真 的 一 些 内 部 信 息 。 这 一 步 骤 通 常 由 编 译 器 自 动 完 成 , 毋 须 我 们 干 预 。 如 果 VHD L 语 法 有 错 误 , 编 译 无 法 通 过 , 则 须 修 改 程 序 , 即 回 到第( 2) 步 。事 实 上 ,在 VHDL 设 计 过 程 中 ,常 常 需 要 往 后 退 一 步 修 改 程 序 。 ( 4) 功能仿真 VHDL 仿 真 器 允 许 定 义 输 入 并 应 用 到 设 计 中 , 不 必 生 成 实 际 电 路 就 可 以 观 察 出 。 此 仿 真 主 要 用 于 检 验 系 统 功 能 设 计 的 正 确 性 , 不 涉 及 具体器 件 的 特 性 。 例如: library ieee; use ieee.std_logic_1164.all; entity shownum is port ( en:in std_logic; numina,numinb,numinc:in integer range 0 to 15; lsb,middle,msb:out std_logic_vector(0 to 6) ); end;

共20页,试读已结束,阅读完整版请下载
刷新页面下载完整文档
VIP每日下载上限内不扣除下载券和下载次数;
按次数下载不扣除下载券;
注册用户24小时内重复下载只扣除一次;
顺序:VIP每日次数-->可用次数-->下载券;
相关文档