《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 汽車尾燈VHDL設計
汽車尾燈VHDL設計
摘要: 汽車尾燈VHDL設計標簽/分類:1.系統設計要求用6個發光管模擬6個汽車尾燈(左右各3個),用4個開關作為汽車控制信號,分別為:左拐、右拐、故障和剎車。車勻速行駛時,6個汽車尾燈全滅;右拐時,車右邊
Abstract:
Key words :

汽車尾燈VHDL設計

標簽/分類:


1.系統設計要求
     用6個發光管模擬6個汽車尾燈(左右各3個),用4個開關作為汽車控制信號,分別為:左拐、右拐、故障和剎車。
    車勻速行駛時,6個汽車尾燈全滅;右拐時,車右邊3個尾燈從左至右順序亮滅;左拐時,車左邊3個尾燈從右至左順序亮滅;故障時車6個尾燈一起明滅閃爍;剎車時,6個尾燈全亮
2.系統設計方案
   根據系統設計要求,采用自頂向下設計方法,頂層設計采用原理圖設計,它由主控模塊、左邊燈控制模塊和右邊燈控制模塊三部分組成。
3參考VHDL源程序
(1) 主控制模塊
     說明:此程序為系統主控制模塊。當左轉時,lft信號有效;右轉時,rit信號有效;當左右信號都有效的時,lr有效。
library ieee;
use ieee.std_logic_1164.all;
entity kz is
   port(left,right:in std_logic;
        lft,rit,lr:out std_logic);
end kz;
architecture kz_arc of kz is
begin
   process(left,right)
   variable a:std_logic_vector(1 downto 0);
   begin
     a:=left&right;
     case a is 
        when"00"=>lft<='0';
                  rit<='0';
                  lr<='0';
        when"10"=>lft<='1';
                  rit<='0';
                  lr<='0';
        when"01"=>rit<='1';
                  lft<='0';
                  lr<='0';
        when others=>rit<='1';
                     lft<='1';
                     lr<='1';
     end case;
   end process;
end kz_arc;
        
(2)左邊燈控制模塊
說明:此模塊的功能是當左轉時控制左邊的3個燈,當左右信號都有效時,輸出為全“1”。
library ieee;
use ieee.std_logic_1164.all;
entity lfta is
   port(en,clk,lr:in std_logic;
        l2,l1,l0:out std_logic);
end lfta;
architecture lft_arc of lfta is
begin
   process(clk,en,lr)
   variable tmp:std_logic_vector(2 downto 0);
   begin
      if lr='1' then
         tmp:="111";
      elsif en='0' then
         tmp:="000";
      elsif clk'event and clk='1' then
         if tmp="000" then
            tmp:="001";
         else
            tmp:=tmp(1 downto 0)&'0';
         end if;
      end if;
      l2<=tmp(2);
      l1<=tmp(1);
      l0<=tmp(0);
   end process;
end lft_arc;
 
(2) 右邊燈控制模塊
說明:此模塊的功能是控制右邊的3個燈,與上面模塊相似。
library ieee;
use ieee.std_logic_1164.all;
entity rita is
    port(en,clk,lr:in std_logic;
         r2,r1,r0:out std_logic);
end rita;
architecture rit_arc of rita is
begin
   process(clk,en,lr)
   variable tmp:std_logic_vector(2 downto 0);
   begin
    if lr='1' then
       tmp:="111";
    elsif en='0' then
       tmp:="000";
    elsif clk'event and clk='1' then
       if tmp="000" then
          tmp:="100";
       else
         tmp:='0'&tmp(2 downto 1);
       end if;
    end if;
       r2<=tmp(2);
       r1<=tmp(1);
       r0<=tmp(0);
    
   end process;
end rit_arc;
此內容為AET網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 射综合网| 欧美最猛性xxxxxhd | 欧美黄色片 一级片 | 久青草视频在线 | 美国一级片在线观看 | 成人三级在线视频 | 500第一导航亚洲精品导航 | 日本深夜18免费看片高清网 | 青草视频青年娱乐 | 亚洲成在人天堂一区二区 | 国产一区二区三区美女秒播 | 欧美日韩国产在线成人网 | 国产在线a免费观看 | 中文字幕在线视频观看 | 大尺度激烈叫床视频免费 | 中文字幕在线观看你懂的 | 免费人成激情视频在线观看冫 | 高清国产精品久久久久 | 国产欧美日韩在线一区二区不卡 | 亚洲午夜视频在线观看 | 伊人a.v在线 | 日韩av成人| 日韩欧美精品综合久久 | 亚洲国产观看 | 无遮挡h纯内动漫在线观看 无遮挡1000部拍拍拍免费观看 | 色偷偷人人澡久久天天 | 久久青青成人亚洲精品 | 日本三级香港三级人妇网站 | 日韩在线三级视频 | 国产成人a毛片在线 | 国产人成精品综合欧美成人 | 一个人免费看的视频 | 黄色片视频网 | 久久久免费观成人影院 | 91国自产精品中文字幕亚洲 | 久久综合狠狠综合久久综合88 | 美腿丝袜在线 | 久久国产一区二区 | 簧片在线免费看 | 国产精品自产拍视频观看 | 精品视频久久 |