




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、8位数码扫描显示电路设计一、实验目的学习硬件扫描显示电路的设计;二、实验原理动态数码扫描显示方式是利用了人眼的视觉暂留效应,把八个数码管按一定顺序进行点亮,当点亮的频率不大时,我们看到的是数码管一个个的点亮,然而,当点亮频率足够大时,我们看到的不再是一个一个的点亮,而是全部同时显示,与传统方式得到的视觉效果完全一样。因此我们只要给数码管这样一个扫描频率,那么就可以实现两个以上的数码管同时点亮。而这个频率我们可以通过一个计数器来产生,只要计数频率足够大,就可以实现我们的要求。事实上,因为数码管点亮不是瞬间就可以的,它也需要一定的时间,该时间与数码管的选择有关系。为了折中这一对矛盾,实验中一般可将
2、计数频率选择在100Hz左右。图示8位数码扫描显示电路,其中每个数码管的8 个段:h、g、f、e、d、c、b、a(h 是小数点)都分别连在一起,8 个数码管分别由8 个选通信号k1、k2、 k8 来选择。被选通的数码管显示数据,其余关闭。如在某一时刻,k3 为高电平,其余选通信号为低电平,这时仅k3 对应的数码管显示来自段信号端的数据,而其它7 个数码管呈现关闭状态。根据这种电路状况,如果希望在8 个数码管显示希望的数据,就必须使得8 个选通信号k1、k2、 k8 分别被单独选通,并在此同时,在段信号输入口加上希望在该对应数码管上显示的数据,于是随着选通信号的扫变,就能实现扫描显示的目的。实验
3、参考扫描显示程序中clk 是扫描时钟;SG 为7 段控制信号,由高位至低位分别接g、f、e、d、c、b、a 7个段;BT 是位选控制信号,接图5-2 中的8 个选通信号:k1、k2、 k8 。程序中CNT8 是一个3 位计数器,作扫描计数信号,由进程P2 生成;进程P3 是7 段译码查表输出程序,进程P1 是对8 个数码管选通的扫描程序,例如当CNT8 等于"001" 时,K2 对应的数码管被选通,同时,A 被赋值3,再由进程P3 译码输出"1001111", 显示在数码管上即为“3”;当CNT8 扫变时,将能在8 个数码管上显示数据:13579BDF
4、。原理图如图1所示。图1 八位数码管显示电路三、实验步骤1、建立一个工程项目,设置路径,项目名和顶层实体名一致;2、设计一个动态扫描显示电路,在8 个数码管上显示数据:13579BDF;并进行编译仿真与下载测试;四、8位数码扫描显示电路的VHDL描述:LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY SCAN_LED IS PORT ( CLK : IN STD_LOGIC; SG : OUT STD_LOGIC_VECTOR(6 DOWNTO 0);BT: OUT STD_LOGIC
5、_VECTOR(7 DOWNTO 0) );END; ARCHITECTURE one OF SCAN_LED IS SIGNAL CNT8 : STD_LOGIC_VECTOR(2 DOWNTO 0); SIGNAL A : INTEGER RANGE 0 TO 15;BEGIN P1:PROCESS( CNT8 ) BEGIN CASE CNT8 IS WHEN "000" => BT <= "00000001" ; A <= 1 ; WHEN "001" => BT <= "0000001
6、0" ; A <= 2 ; WHEN "010" => BT <= "00000100" ; A <= 3 ; WHEN "011" => BT <= "00001000" ; A <= 4 ; WHEN "100" => BT <= "00010000" ; A <= 5 ; WHEN "101" => BT <= "00100000" ; A <
7、= 6 ; WHEN "110" => BT <= "01000000" ; A <= 7 ;WHEN "111" => BT <= "10000000" ; A <= 8 ; WHEN OTHERS => NULL ; END CASE ; END PROCESS P1; P2:PROCESS(CLK) BEGIN IF CLK'EVENT AND CLK = '1' THEN CNT8 <= CNT8 + 1; END IF; END PR
8、OCESS P2 ; P3:PROCESS( A ) BEGIN CASE A IS WHEN 0 => SG <= "0111111" WHEN 1 => SG <= "0000110" WHEN 2 => SG <= "1011011" WHEN 3 => SG <= "1001111" WHEN 4 => SG <= "1100110" WHEN 5 => SG <= "1101101" WHEN
9、6 => SG <= "1111101" WHEN 7 => SG <= "0000111" WHEN 8 => SG <= "1111111" WHEN 9 => SG <= "1101111" WHEN 10 => SG <= "1110111" WHEN 11 => SG <= "1111100" WHEN 12 => SG <= "0111001" WHEN 13
10、=> SG <= "1011110" WHEN 14 => SG <= "1111001" WHEN 15 => SG <= "1110001" WHEN OTHERS => NULL ; END CASE ;END PROCESS P3; END;五、仿真波形功能仿真波形时序仿真波形32位并进/并出移位寄存器设计一、实验原理用一个8位移位寄存器,再增加一些电路,如4个8位锁存器等,设计成为一个能为32位二进制数进行不同方式移位的移位寄存器。二、实验步骤1、建立一个工程项目,设置路径,项目名和
11、顶层实体名一致;2、设计一个8位移位寄存器电路;3、设计一个8位锁存器电路;4、运用元件调用声明语句和元件例化语句完成顶层设计。三、实验程序1、八位移位寄存器程序LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY jicun IS PORT ( CLK,CO: IN STD_LOGIC; MD : IN STD_LOGIC_VECTOR(2 DOWNTO 0); D : IN STD_LOGIC_VECTOR(7 DOWNTO 0); QB : OUT STD_LOGIC_VECTOR(7 DOWNTO 0); CN : OUT STD_LOGIC)
12、; END jicun;ARCHITECTURE behav OF jicun IS SIGNAL REG : STD_LOGIC_VECTOR(7 DOWNTO 0); SIGNAL CY : STD_LOGIC;BEGIN PROCESS(CLK,CO,MD) BEGIN IF CLK'EVENT AND CLK='1' THEN CASE MD IS WHEN "001"=> REG(0)<=CO; REG(7 DOWNTO 1)<= REG(6 DOWNTO 0);CY<=REG(7); WHEN "010&
13、quot; => REG(0)<=REG(7); -自循环左移 REG(7 DOWNTO 1)<= REG(6 DOWNTO 0); WHEN "011"=>REG(7)<=REG(0); -自循环右移 REG(6 DOWNTO 0)<=REG(7 DOWNTO 1); WHEN "100" =>REG(7)<=CO; -带进位循环右移 REG(6 DOWNTO 0)<=REG(7 DOWNTO 1);CY<=REG(0); WHEN "101" =>REG(7 DOW
14、NTO 0)<=D(7 DOWNTO 0); -加载待移数 WHEN OTHERS=>REG<=REG;CY<=CY;-保持 END CASE; END IF; END PROCESS; QB(7 DOWNTO 0)<=REG(7 DOWNTO 0);CN<=CY;END behav;2、锁存器程序library ieee ;use ieee.std_logic_1164.all ;entity suocun isport(d : in std_logic_vector(7 downto 0) ; q: out std_logic_vector(7 down
15、to 0); clk : in std_logic );end suocun ;architecture one of suocun issignal q1: std_logic_vector(7 downto 0);beginprocess(clk,q1)beginif clk'event and clk='1'then q1<=d;end if;end process;q<=q1;end one;3、顶层设计程序LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY jicun32 IS PORT ( clk0,c
16、o: IN STD_LOGIC; md : IN STD_LOGIC_VECTOR(2 DOWNTO 0); db : IN STD_LOGIC_VECTOR(31 DOWNTO 0); qb : OUT STD_LOGIC_VECTOR(31 DOWNTO 0); cn : OUT STD_LOGIC); END jicun32;ARCHITECTURE one OF jicun32 IS COMPONENT jicunPORT ( CLK,CO: IN STD_LOGIC; MD : IN STD_LOGIC_VECTOR(2 DOWNTO 0); D : IN STD_LOGIC_VEC
17、TOR(7 DOWNTO 0); QB : OUT STD_LOGIC_VECTOR(7 DOWNTO 0); CN : OUT STD_LOGIC); END COMPONENT; COMPONENT suocunport(d : in std_logic_vector(7 downto 0) ; q: out std_logic_vector(7 downto 0); clk : in std_logic ); END COMPONENT; SIGNAL e,f,g,h : STD_LOGIC_VECTOR(7 DOWNTO 0); SIGNAL l,m,n : STD_LOGIC; BE
18、GIN u1: suocun PORT MAP(d=>db(7 DOWNTO 0),q=>e,clk=>clk0);u2: jicun PORT MAP (D=>e,QB=>qb(7 DOWNTO 0), CLK=>clk0,CO=>co,CN=>l,MD=>md); u3: suocun PORT MAP(d=>db(15 DOWNTO 8),q=>f,clk=>clk0); u4: jicun PORT MAP(D=>f,QB=>qb(15 DOWNTO 8), CLK=>clk0,CO=>l,CN=>m,MD=>md); u5: suocun PORT MAP(d=>db(23 DOWNTO 16),q=>g,clk=>clk0); u6: jicun PORT MAP
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 编程培训班汇报
- 交通工程安全生产培训
- 研究生教育与保安专业发展的联系计划
- 车辆过户项目合同协议
- 演出用工协议书
- 车位出租转让合同协议
- 送水店转让合同协议
- 《古代小说选读》课件
- 消防双方协议书
- 陶瓷产品购销合同书
- 政教主任国旗下的讲话稿-讲话稿
- 国学文化古典中国风模板
- 伤口评估与护理记录
- 国民经济核算司精讲GDP核算
- 毕业论文PLC在机械手控制系统中的应用
- HY/T 0331-2022绿潮生态调查与监测技术规范
- GB/T 31928-2015船舶用不锈钢无缝钢管
- GB/T 28046.4-2011道路车辆电气及电子设备的环境条件和试验第4部分:气候负荷
- 中药学-七版教材
- 配位化学-配合物结构的表征和测试研究课件
- 商务英语阅读(第二版)参考译文 王关富编
评论
0/150
提交评论