#基于VHDL语言的数字钟设计
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
一.程序代码及其仿真:
1.cnt60子模块代码:
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
ENTITY V_cnt60 IS
PORT ( clk :IN std_logic;
Q0,Q1,Q2,Q3,Q4,Q5,Q6,QC :OUT std_logic);
END V_cnt60;
ARCHITECTURE func OF V_cnt60 IS
SIGNAL count1 :std_logic_vector(3 downto 0);
SIGNAL count2 :std_logic_vector(3 downto 0);
SIGNAL carryin:std_logic;
BEGIN
Q0 <= count1(0);
Q1 <= count1(1);
Q2 <= count1(2);
Q3 <= count1(3);
Q4 <= count2(0);
Q5 <= count2(1);
Q6 <= count2(2);
QC <= carryin;
process(clk)
BEGIN
if (clk'event AND clk='1') then
carryin<='0';
if(count1="1001")then
count1<="0000";
count2<=count2+1;
else
count1<=count1+1;
END if;
if(count2="0101"AND count1="1001")then
count2<="0000";
count1<="0000";
carryin<='1';
END if;
END if;
END process;
END func;
cnt60仿真波形:
2.cnt24子模块代码:
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
ENTITY V_cnt24 IS
PORT ( clk :IN std_logic;
Q0,Q1,Q2,Q3,Q4,Q5:OUT std_logic); END V_cnt24;
ARCHITECTURE func_cnt24 OF V_cnt24 IS SIGNAL count1 :std_logic_vector(3 downto 0); SIGNAL count2 :std_logic_vector(3 downto 0); SIGNAL carryin:std_logic;
BEGIN
Q0 <= count1(0);
Q1 <= count1(1);
Q2 <= count1(2);
Q3 <= count1(3);
Q4 <= count2(0);
Q5 <= count2(1);
process(clk)
BEGIN
if (clk'event and clk='1') then
if(count1="1001")then
count1<="0000";
count2<=count2+1;
else
count1<=count1+1;
END if;
if(count2="0010" AND count1="0011")then
count2<="0000";
count1<="0000";
END if;
END if;
END process;
END func_cnt24;
cnt24仿真波形:
3.cnt1000字模块代码:
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity V_cnt1000 is
port( clk :in std_logic;
cnt1000 :out std_logic;
clk_c :out std_logic);
end V_cnt1000;
architecture bhv of V_cnt1000 is
signal tmp:std_logic_vector(9 downto 0);
signal amp:std_logic_vector(8 downto 0);
begin
process(clk)
begin
if (clk'event and clk='1') then
if (tmp=1023)then tmp<="0000000000";
else tmp<=tmp+1;
end if;
if (tmp<511) then cnt1000<='0';
else cnt1000<='1';
end if;
end if;
end process;
process(clk)
begin
if (clk'event and clk='1') then
if (amp=511)then amp<="000000000";
else amp<=amp+1;
end if;
if (amp<255) then clk_c<='0';
else clk_c<='1';
end if;
end if;
end process;
end bhv;
cnt1000仿真波形:
4.clk_c子模块代码:
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;
ENTITY V_clk_c IS
PORT
(clk,CLK_C,M1,S1,SS,MM,HH,CTRL : IN STD_LOGIC;
CLKS,CLKM,CLKH : OUT STD_LOGIC);
END V_clk_c;
ARCHITECTURE func OF V_clk_c IS
BEGIN
process
begin
CLKS<=(CTRL AND CLK) OR((NOT CTRL) AND HH AND MM AND (NOT SS) AND CLK_C);
CLKM<=(CTRL AND S1) OR((NOT CTRL) AND HH AND (NOT MM) AND SS AND CLK_C);
CLKH<=(CTRL AND M1) OR((NOT CTRL) AND (NOT HH) AND MM AND SS AND CLK_C);
END process;
END func;
5.display子模块代码:
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;
ENTITY display IS
PORT
( clk : IN std_logic;
LED1Q_0,LED1Q_1,LED1Q_2,LED1Q_3: IN std_logic;
LED2Q_0,LED2Q_1,LED2Q_2,LED2Q_3: IN std_logic;
LED3Q_0,LED3Q_1,LED3Q_2,LED3Q_3: IN std_logic;
LED4Q_0,LED4Q_1,LED4Q_2,LED4Q_3: IN std_logic;
LED5Q_0,LED5Q_1,LED5Q_2,LED5Q_3: IN std_logic;
LED6Q_0,LED6Q_1,LED6Q_2,LED6Q_3: IN std_logic;
LED1,LED2,LED3,LED4,LED5,LED6: OUT std_logic;
SE_A,SE_B,SE_C,SE_D,SE_E,SE_F,SE_G: OUT std_logic); END display;
ARCHITECTURE func OF display IS
SIGNAL ctrl : std_logic_vector(2 downto 0);
SIGNAL code : std_logic_vector(3 downto 0);
BEGIN
process(ctrl)
BEGIN
CASE ctrl IS
WHEN "000"=> L ED1<='1';
LED2<='0';
LED3<='0';
LED4<='0';
LED5<='0';
LED6<='0';
code(0)<=LED1Q_0;
code(1)<=LED1Q_1;
code(2)<=LED1Q_2;
code(3)<=LED1Q_3; WHEN"001"=> L ED1<='0';
LED2<='1';
LED3<='0';
LED4<='0';
LED5<='0';
LED6<='0';
code(0)<=LED2Q_0;
code(1)<=LED2Q_1;
code(2)<=LED2Q_2;
code(3)<=LED2Q_3; WHEN "010"=> L ED1<='0';
LED2<='0';
LED3<='1';
LED4<='0';
LED5<='0';
LED6<='0';
code(0)<=LED3Q_0;
code(1)<=LED3Q_1;
code(2)<=LED3Q_2;
code(3)<=LED3Q_3; WHEN "011"=>LED1<='0';
LED2<='0';
LED3<='0';
LED4<='1';
LED5<='0';
LED6<='0';
code(0)<=LED4Q_0;
code(1)<=LED4Q_1;
code(2)<=LED4Q_2;
code(3)<=LED4Q_3; WHEN "100"=>LED1<='0';
LED2<='0';
LED3<='0';
LED4<='0';
LED5<='1';
LED6<='0';
code(0)<=LED5Q_0;
code(1)<=LED5Q_1;
code(2)<=LED5Q_2;
code(3)<=LED5Q_3; WHEN "101"=> L ED1<='0';
LED2<='0';
LED3<='0';
LED4<='0';
LED5<='0';
LED6<='1';
code(0)<=LED6Q_0;
code(1)<=LED6Q_1;
code(2)<=LED6Q_2;
code(3)<=LED6Q_3;
WHEN OTHERS => NULL;
END CASE;
END process;
process(code)
BEGIN
CASE code IS
WHEN "0000"=>
SE_A<='1';SE_B<='1';SE_C<='1';SE_D<='1';SE_E<='1';SE_F<='1';SE_G<='0'; WHEN "0001"=>
SE_A<='0';SE_B<='1';SE_C<='1';SE_D<='0';SE_E<='0';SE_F<='0';SE_G<='0'; WHEN "0010"=>
SE_A<='1';SE_B<='1';SE_C<='0';SE_D<='1';SE_E<='1';SE_F<='0';SE_G<='1'; WHEN "0011"=>
SE_A<='1';SE_B<='1';SE_C<='1';SE_D<='1';SE_E<='0';SE_F<='0';SE_G<='1'; WHEN "0100"=>
SE_A<='0';SE_B<='1';SE_C<='1';SE_D<='0';SE_E<='0';SE_F<='1';SE_G<='1'; WHEN "0101"=>
SE_A<='1';SE_B<='0';SE_C<='1';SE_D<='1';SE_E<='0';SE_F<='1';SE_G<='1'; WHEN "0110"=>
SE_A<='1';SE_B<='0';SE_C<='1';SE_D<='1';SE_E<='1';SE_F<='1';SE_G<='1'; WHEN "0111"=>
SE_A<='1';SE_B<='1';SE_C<='1';SE_D<='0';SE_E<='0';SE_F<='0';SE_G<='0'; WHEN "1000"=>
SE_A<='1';SE_B<='1';SE_C<='1';SE_D<='1';SE_E<='1';SE_F<='1';SE_G<='1'; WHEN "1001"=>
SE_A<='1';SE_B<='1';SE_C<='1';SE_D<='1';SE_E<='0';SE_F<='1';SE_G<='1'; WHEN "1010"=>
SE_A<='1';SE_B<='1';SE_C<='1';SE_D<='0';SE_E<='1';SE_F<='1';SE_G<='1'; WHEN "1011"=>
SE_A<='0';SE_B<='0';SE_C<='1';SE_D<='1';SE_E<='1';SE_F<='1';SE_G<='1'; WHEN "1100"=>
SE_A<='1';SE_B<='0';SE_C<='0';SE_D<='1';SE_E<='1';SE_F<='1';SE_G<='0'; WHEN "1101"=>
SE_A<='0';SE_B<='1';SE_C<='1';SE_D<='1';SE_E<='1';SE_F<='0';SE_G<='1'; WHEN "1110"=>
SE_A<='1';SE_B<='0';SE_C<='0';SE_D<='1';SE_E<='1';SE_F<='1';SE_G<='1';
WHEN "1111"=>
SE_A<='1';SE_B<='0';SE_C<='0';SE_D<='0';SE_E<='1';SE_F<='1';SE_G<='1'; WHEN OTHERS=>
SE_A<='0';SE_B<='0';SE_C<='0';SE_D<='0';SE_E<='0';SE_F<='0';SE_G<='0'; END CASE;
END process;
process(clk)
BEGIN
if(clk'event and clk='1') then
ctrl<=ctrl+1;
if(ctrl="101")then
ctrl<="000";
END if;
END if;
END process;
END func;
display仿真波形:
6.de4_7子模块代码:
library ieee;
use ieee.STD_logic_1164.ALL;
use ieee.STD_logic_unsigned.ALL;
ENTITY V_de4_7 IS
PORT ( a,b,c,d : in std_logic;
se_a,se_b,se_c,se_d,se_e,se_f,se_g : out std_logic); END V_de4_7;
ARCHITECTURE actde4_7 OF V_de4_7 IS
signal segment : std_logic_vector(6 downto 0 );
signal input : std_logic_vector(3 downto 0 );
begin
se_a<=segment(0);
se_b<=segment(1);
se_c<=segment(2);
se_d<=segment(3);
se_e<=segment(4);
se_f<=segment(5);
se_g<=segment(6);
input(0)<=d;
input(1)<=c;
input(2)<=b;
input(3)<=a;
process(a,b,c,d)
begin
case input is
when"0000"=> segment<="1111110";
when"0001"=> segment<="0110000";
when"0010"=> segment<="1101101";
when"0011"=> segment<="1111001";
when"0100"=> segment<="0110011";
when"0101"=> segment<="1011011";
when"0110"=> segment<="1011111";
when"0111"=> segment<="1110000";
when"1000"=> segment<="1111111";
when"1001"=> segment<="1111011";
when"1010"=> segment<="1110111";
when"1011"=> segment<="0011111";
when"1100"=> segment<="1001110";
when"1101"=> segment<="0111101";
when"1110"=> segment<="1001111";
when"1111"=> segment<="1000111";
when others=> segment<="0000000";
end case;
end process;
end actde4_7;
de4_7仿真波形:
7.mul8_1子模块代码:
LIBRARY IEEE;
use ieee.STD_LOGIC_1164.ALL;
ENTITY V_mul8_1 IS
PORT( ST: IN STD_LOGIC;
A: IN STD_LOGIC_VECTOR(2 DOWNTO 0);
D: IN STD_LOGIC_VECTOR(7 DOWNTO 0);
Q: OUT STD_LOGIC);
END V_mul8_1;
ARCHITECTURE HBV OF V_mul8_1 IS
SIGNAL Q1: STD_LOGIC;
BEGIN
PROCESS(a)
BEGIN
IF ST='1' THEN Q1<='0';
ELSE
CASE a IS
WHEN "000"=> Q1 <= D(0);
WHEN "001"=> Q1 <= D(1);
WHEN "010"=> Q1 <= D(2);
WHEN "011"=> Q1 <= D(3);
WHEN "100"=> Q1 <= D(4);
WHEN "101"=> Q1 <= D(5);
WHEN "110"=> Q1 <= D(6);
WHEN "111"=> Q1 <= D(7);
WHEN OTHERS => NULL;
END CASE;
END IF;
END PROCESS;
Q<= Q1;
END HBV;
mul8_1仿真波形:
二.总体资源占用率:50%
三.
11。