版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上 EDA数字频率计 课程设计报告专 业: 电子信息工程 班 级: 08电信 姓 名: 刘冰 学 号: F 指导教师: 任苹 年 月 日 一 课程设计目的1)课程设计题:数字频率计2)任务及要求1、设计一个能测量方波信号的频率的频率计。2、测量的频率范围是0Hz。3、结果用十进制数显示。4、按要求写好设计报告(设计报告内容包括:引言,方案设计与论证,总体设计,各模块设计,调试与数据分析,总结)。3)教学提示1、脉冲信号的频率就是在单位时间内所产生的脉冲个数,其表达式为,f为被测信号的频率,N为计数器所累计的脉冲个数,T为产生N个脉冲所需的时间。所以,在1秒时间内计数器所
2、记录的结果,就是被测信号的频率。2、被测频率信号取自实验箱晶体振荡器输出信号,加到主控门的输入端。3、再取晶体振荡器的另一标准频率信号,经分频后产生各种时基脉冲:1ms,10ms,0.1s,1s等,时基信号的选择可以控制,即量程可以改变。4、时基信号经控制电路产生闸门信号至主控门,只有在闸门信号采样期间内(时基信号的一个周期),输入信号才通过主控门。5f=N/T,改变时基信号的周期T,即可得到不同的测频范围。5、 当主控门关闭时,计数器停止计数,显示器显示记录结果,此时控制电路输出一个置零信号,将计数器和所有触发器复位,为新的一次采样做好准备。6、 改变量程时,小数点能自动移位。4)设计报告要
3、求1、说明设计作品的功能、特点、应用范围;2、方案对比,确定方案。3、电路工作原理、操作方法;4、编程方法、程序框图及关键程序清单。5、课程设计总结。数字频率计是计算机、通讯设备、音频视频等科研生产领域不可缺少的测量仪器。它是一种用十进制数字,显示被测信号频率的数字测量仪器。它的基本功能是测量正弦信号,方波信号以及其他各种单位时间内变化的物理量。在进行模拟、数字电路的设计、安装、调试过程中,由于其使用十进制数显示,测量迅速,精度高,显示直观,所以经常要用到数字频率计。二、设计方案论证、结果以及分析1 原理图编译成功后其波形图如下:2、信号发生器library ieee;use ieee.std
4、_logic_1164.all;use ieee.std_logic_unsigned.all;entity sele is port(clk: in std_logic; jian: in std_logic_vector(1 downto 0); oclk: out std_logic);end;architecture s_1 of sele issignal full : std_logic;signal t :integer range 0 to ; beginP1:process(jian,t) begin case jian is when "00" =>
5、; t <= ; -产生时基脉冲1s when "01" => t <= ; -产生时基脉冲100ms when "10" => t <= 59999; -产生时基脉冲10ms when "11" => t <= 5999; -产生时基脉冲1ms when others => null; end case;end process P1;P2: process(clk,t) variable s : integer range 0 to ; begin if (clk'event
6、and clk = '1') then if s < t then s := s +1; else s := 0 ; end if; end if; if s = t then full <= '1' else full <= '0' end if;end process P2;P3: process(full) variable c : std_logic;begin if full'event and full = '1' then c := not c; if c = '1' the
7、n oclk <= '1' else oclk <='0' end if; end if; end process P3;end;其仿真波形为:3、 测频library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity cp is port(clkk: in std_logic; en,rst,load: out std_logic);end;architecture cp_1 of cp is signal div2: std_logic;beginpro
8、cess(clkk)begin if(clkk'event and clkk='1') then div2 <= not div2; end if;end process;process(clkk,div2)begin if (clkk='0' and div2='0') then rst <='1' else rst <='0' end if;end process;load <= not div2;en <= div2;end;其仿真波形为:4、 计数器library ie
9、ee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity jishu is port(rst,en,clk: in std_logic; Q: out std_logic_vector(3 downto 0); cout: out std_logic);end;architecture cnt of jishu is signal cnt: std_logic_vector(3 downto 0);beginprocess(rst,en,clk)beginif rst='1' then cnt &
10、lt;= "0000"elsif(clk'event and clk='1') and en = '1' then if cnt = "1001" then cnt <= "0000" cout <= '1' else cnt <= cnt + 1; cout <= '0' end if;end if;end process;Q <= cnt;end;在源程序中COUT是计数器的进位输出;Q3.0是计数器的状态输出;CLK是时钟输入端
11、;RST是复位控制端;当RST=1时,Q3.0=0,EN是使能控制输入端,当EN=1时,计数器计数,当EN=0时,计数器保持状态不变。编译成功后,其仿真波形如下:在项目编译仿真成功后,将设计的十进制计数器电路设置成可调用的元件jishu.sym用于以下的顶层设计。5、 16位寄存器library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity suocun is port(load: in std_logic; din : in std_logic_vector(15 downto 0); dout
12、: out std_logic_vector(15 downto 0);end;architecture suo of suocun is beginprocess(load,din)beginif (load'event and load='1') then dout <= din;end if;end process;end;在源程序中load是锁存信号,上升沿触发;din3.0是寄存器输入;dout3.0是寄存器输出。编译成功后生成元件图如下图,以便顶层模块的调用。4位寄存器寄存器是在计数结束后,利用触发器的上升沿吧最新的频率测量值保存起来,这样在计数的过程
13、中可不必一直看数码显示器,显示器将最终的频率读数定期进行更新,其输出作为动态扫描电路的输入。library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity suo is port(load: in std_logic; din : in std_logic_vector(3 downto 0); dout: out std_logic_vector(3 downto 0);end;architecture suo_1 of suo is beginprocess(load,din)beginif (
14、load'event and load='1') then dout <= din;end if;end process;end;在源程序中load是锁存信号,上升沿触发;din3.0是寄存器输入;dout3.0是寄存器输出。编译成功后生成元件图如下图,以便顶层模块的调用。6、 译码器library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity leds is port(clk: in std_logic; Din: in std_logic_vector(15 do
15、wnto 0); sg: out std_logic_vector(6 downto 0); bt: out std_logic_vector(1 downto 0);end;architecture led_1 of leds issignal cnt8: std_logic_vector(1 downto 0);signal q: std_logic_vector(3 downto 0); beginP1:process(cnt8,Din,q) begin case cnt8 is when "00" => bt <= "00"q <
16、;= Din(3 downto 0); when "01" => bt <= "01"q <= Din(7 downto 4); when "10" => bt <= "10"q <= Din(11 downto 8); when "11" => bt <= "11"q <= Din(15 downto 12); when others => null; end case; case q is when "
17、0000" => sg <= "" when "0001" => sg <= "" when "0010" => sg <= "" when "0011" => sg <= "" when "0100" => sg <= "" when "0101" => sg <= "" when "
18、0110" => sg <= "" when "0111" => sg <= "" when "1000" => sg <= "" when "1001" => sg <= "" when others => null; end case;end process P1;P2:process(clk) begin if(clk'event and clk='1') the
19、n cnt8 <= cnt8 +1; end if;end process P2;end;编译成功后,其波形图为:7、 译码library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity divid is port(clk50: in std_logic; qlkhz: out std_logic);end;architecture div of divid isbeginK1:process(clk50) variable cout: integer:=0; begin if(clk50
20、39;event and clk50='1') then cout := cout + 1; if cout <= 24999 then qlkhz <= '1' elsif cout <= 49999 then qlkhz <= '1' else cout :=0; end if; end if;end process;end;编译成功后,其波形图为:8、 动态扫描电路library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;enti
21、ty dongtai is port(q200hz: in std_logic; bt: in std_logic_vector(1 downto 0); sg: in std_logic_vector(6 downto 0); led0,led1,led2,led3: out std_logic_vector(6 downto 0);end;architecture behav of dongtai isbeginprocess(q200hz) begin if(q200hz'event and q200hz='1') then case bt iswhen &quo
22、t;00" => led0 <= sg(6 downto 0);when "01" => led1 <= sg(6 downto 0);when "10" => led2 <= sg(6 downto 0);when "11" => led3 <= sg(6 downto 0);when others => null;end case;end if;end process;end;仿真波形如下:编译成功后生成元件图如下图,以便顶层模块的调用。9、 分频设计library
23、ieee;use ieee.std_logic_1164.all;use ieee.std_logic_signed.all;entity fp is port( clk : in std_logic; oclk: out std_logic);end;architecture fp_1 of fp issignal full : std_logic;beginP1: process(clk) variable s : integer range 0 to 99; begin if (clk'event and clk = '1') then if s < 99
24、then s := s +1; elsif s > 99 then s := 0; elsif s = 99 then full <= '1' end if; end if;end process P1;P2: process(full) variable c : std_logic; begin if full = '1' then c := not c; if c = '1' then oclk <= '1' else oclk <='0' end if; end if; end process P2;end;编译成功后,其波形图为:三设计体会通过对EDA技术这门课程的学习,心得体会甚多。虽然一开始觉得
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 影响农村信用社发展的政策性障碍分析
- 轮椅车 第31部分 电动轮椅车的锂离子电池系统和充电器 要求和试验方法 征求意见稿
- 直播招商课件教学课件
- 金融培训课件教学课件
- 三年级数学计算题专项练习及答案集锦
- 维修水泵机组合同(2篇)
- 学习领会《新就业形态劳动者权益协商指引》心得体会
- 南京航空航天大学《编译原理》2022-2023学年第一学期期末试卷
- 发现问题说课稿
- 阳春市河朗镇饮用水供水工程施工组织设计
- 听神经瘤讲课课件
- 2023年食品安全粮食类理论知识考试题库(含答案)
- 人教版五年级上册数学《可能性》作业设计
- 学校建设工程项目自查报告
- 混凝土结构理论智慧树知到答案章节测试2023年华南理工大学
- 土地整理项目结算审计方案及提供资料清单
- 某文化博物馆建设项目可行性研究报告
- 二年级语文质量分析ppt课件精选ppt
- JJF 1272-2011阻容法露点湿度计校准规范
- GB/T 39517.2-2020农林拖拉机和机械农用定位与导航系统测试规程第2部分:在直线和水平运行状态下卫星自动导航系统的测试
- 高中生学法指导课件
评论
0/150
提交评论