• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 新聞中心

    EEPW首頁 > 嵌入式系統 > 設計應用 > CPLD設計的驅動數碼顯示電路案例

    CPLD設計的驅動數碼顯示電路案例

    作者: 時間:2010-06-20 來源:網絡 收藏

    when 101=>q=11011111;
    when 110=>q=10111111;
    when others=>q=01111111;
    end case;
    end process;
    end rtl;

    1.3.3 八選一數據選擇模塊
    八選一數據選擇模塊 SEL81 如圖1.7 所示。SEL81 模塊輸入信號一個是數據選擇器SEL81的地址碼SEL[2..0],另一部分是數據信息A[3..0] ~H[3..0]。地址碼SEL[2..0]來自時鐘脈沖計數器CN8,由地址碼SEL[2..0]決定輸出哪個輸入數據。輸出信號是Q[3..0]。

    圖 1.7 八選一數據選擇模塊SEL81

    本文引用地址:http://www.czjhyjcfj.com/article/151796.htm

    library ieee;
    use ieee.std_logic_1164.all;
    entity sel81 is
    port(sel:in std_logic_vector(2 downto 0);
    a,b,c,d,e,f,g,h:in std_logic_vector(3 downto 0);
    q:out std_logic_vector(3 downto 0));
    end sel81;
    architecture rtl of sel81 is
    begin
    process(a,b,c,d,e,f,g,h,sel)
    variable cout: std_logic_vector(3 downto 0);
    begin
    case (sel) is
    when 000=>cout:=a;
    when 001=>cout:=b;
    when 010=>cout:=c;
    when 011=>cout:=d;
    when 100=>cout:=e;
    when 101=>cout:=f;
    when 110=>cout:=g;
    when others=>cout:=h;
    end case;
    q=cout;
    end process;
    end rtl;

    1.3.4 七段譯碼器模塊
    七段譯碼器模塊 DISP 如圖1.8 所示。DISP 模塊是七段譯碼器,將輸入的4 位二進制數轉換為管所對應的數字。例如輸入為4 位二進制數0000 的時候,使0,則要七段譯碼器輸出為0111111,即g 段為0,g 段發光二極管不亮,其他發光二極管被點亮,顯示效果為0。DISP 模塊輸入信號D[3..0]接到八選一數據選擇模塊的輸出信號Q[3..0];七段譯碼器輸出信號Q[6..0]接管的a~g 管腳。

    圖 1.8 七段譯碼器模塊DISP

    library ieee;
    use ieee.std_logic_1164.all;
    entity disp is
    port(d:in std_logic_vector(3 downto 0);
    q:out std_logic_vector(6 downto 0));
    end disp;
    architecture rtl of disp is
    begin
    process(d)
    begin
    case d is
    when0000=>q=0111111;
    when0001=>q=0000110;
    when0010=>q=1011011;
    when0011=>q=1001111;
    when0100=>q=1100110;
    when0101=>q=1101101;
    when0110=>q=1111101;
    when0111=>q=0100111;
    when1000=>q=1111111;
    when others=>q=1101111;
    end case;
    end process;
    end rtl;

    1.3.5 八位數碼管顯示的整體
    將各個模塊連接起來構成整體圖如圖 1.9 所示,可以實現用 一個八位數碼管顯示的功能。clk 是時鐘脈沖輸入信號,經過時鐘脈沖計數器CN8 模塊,將信號以3 位2 進制數的形式輸出,輸出信號是COUT[2..0]。時鐘脈沖計數器CN8 的輸出同時作為3 線―8 線譯碼器DECODER3_8 和八選一數據選擇器SEL81 地址碼SEL[2..0]的輸入。時鐘脈沖計數器CN8 的輸出經過3 線―8 線譯碼器DECODER3_8 譯碼其輸出信號Vss[7..0]接到八位數碼管的陰極Vss7、Vss6、Vss5、Vss4、Vss3、Vss2、Vss1、Vss0 端,決定點亮哪位數碼管。同時時鐘脈沖計數器CN8 模塊輸出的信號也進入數據選擇器SEL81 地址碼SEL[2..0]的輸入,進行輸出數據的選擇,其輸出是Q[3..0]。八選一數據選擇器SEL81 模塊的輸出是Q[3..0]再經過七段譯碼器DISP 模塊,將其翻譯成可以用數碼顯示管的數據。七段譯碼器DISP 模塊的輸出Q[6..0]分別經300 歐電阻接數碼顯示管的a~g 管腳。八選一數據選擇器模塊的輸入端,可根據具體需要進行。

    圖 1.9 八位數碼管顯示的整體電路

    DIY機械鍵盤相關社區:機械鍵盤DIY



    上一頁 1 2 下一頁

    評論


    相關推薦

    技術專區

    關閉
    主站蜘蛛池模板: 开封市| 大荔县| 呼伦贝尔市| 陈巴尔虎旗| 永吉县| 彭阳县| 尉氏县| 凤山县| 平阳县| 莱西市| 东辽县| 冀州市| 高尔夫| 隆子县| 长泰县| 综艺| 奉节县| 平乐县| 积石山| 明水县| 晋宁县| 临江市| 姚安县| 拉萨市| 安多县| 石嘴山市| 兰州市| 利川市| 广丰县| 呼伦贝尔市| 天津市| 阿勒泰市| 炉霍县| 铅山县| 五峰| 宝兴县| 灵台县| 武威市| 葫芦岛市| 福清市| 正镶白旗|