日韩床上生活一级视频|能看毛片的操逼网站|色悠悠网站在线观看视频|国产免费观看A淫色免费|国产av久久久久久久|免费A级视频美女网站黄|国产毛片av日韩小黄片|热久久免费国产视频|中文字幕无码色色|成人在线视频99久久久

機(jī)電之家資源網(wǎng)
單片機(jī)首頁|單片機(jī)基礎(chǔ)|單片機(jī)應(yīng)用|單片機(jī)開發(fā)|單片機(jī)文案|軟件資料下載|音響制作|電路圖下載 |嵌入式開發(fā)
培訓(xùn)信息
贊助商
VHDL設(shè)計(jì)中電路簡化問題的探討
VHDL設(shè)計(jì)中電路簡化問題的探討
 更新時(shí)間:2008-8-4 4:58:28  點(diǎn)擊數(shù):30
【字體: 字體顏色


    

摘 要: 從描述方法、設(shè)計(jì)規(guī)則、邏輯函數(shù)分析了VHDL設(shè)計(jì)中容易引起電路復(fù)雜化的原因,并提出了相應(yīng)的解決方法。

關(guān)鍵詞: VHDL 電路簡化

  近年來,隨著集成電路技術(shù)的發(fā)展,用傳統(tǒng)的方法進(jìn)行芯片或系統(tǒng)設(shè)計(jì)已不能滿足要求,迫切需要提高設(shè)計(jì)效率。在這樣的技術(shù)背景下,能大大降低設(shè)計(jì)難度的VHDL設(shè)計(jì)方法正越來越廣泛地被采用。但是VHDL設(shè)計(jì)是行為級(jí)的設(shè)計(jì)所帶來的問題是設(shè)計(jì)者的設(shè)計(jì)思考與電路結(jié)構(gòu)相脫節(jié)。設(shè)計(jì)者主要是根據(jù)VHDL的語法規(guī)則對(duì)系統(tǒng)目標(biāo)的邏輯行為進(jìn)行描述然后通過綜合工具進(jìn)行電路結(jié)構(gòu)的綜合、編譯、優(yōu)化,通過仿真工具進(jìn)行邏輯功能仿真和系統(tǒng)時(shí)延的仿真。實(shí)際設(shè)計(jì)過程中,由于每個(gè)工程師對(duì)語言規(guī)則、對(duì)電路行為的理解程度不同,每個(gè)人的編程風(fēng)格不同,往往同樣的系統(tǒng)功能,描述的方式是不一樣的,綜合出來的電路結(jié)構(gòu)更是大相徑庭。因此,即使最后綜合出的電路都能實(shí)現(xiàn)相同的邏輯功能,其電路的復(fù)雜程度和時(shí)延特性都會(huì)有很大的差別,甚至某些臃腫的電路還會(huì)產(chǎn)生難以預(yù)料的問題。從這個(gè)問題出發(fā),我們就很有必要深入討論在VHDL設(shè)計(jì)中如何簡化電路結(jié)構(gòu),優(yōu)化電路設(shè)計(jì)的問題。

 。 描述方法對(duì)電路結(jié)構(gòu)的影響

  用VHDL進(jìn)行設(shè)計(jì),其最終綜合出的電路的復(fù)雜程度除取決于設(shè)計(jì)要求實(shí)現(xiàn)的功能的難度外,還受設(shè)計(jì)工程師對(duì)電路的描述方法和對(duì)設(shè)計(jì)的規(guī)劃水平的影響。最常見的使電路復(fù)雜化的原因之一是設(shè)計(jì)中存在許多本不必要的類似LATCH的結(jié)構(gòu)。而且由于這些結(jié)構(gòu)通常都由大量的觸發(fā)器組成,不僅使電路更復(fù)雜,工作速度降低,而且由于時(shí)序配合的原因而導(dǎo)致不可預(yù)料的結(jié)果。例如對(duì)于同一譯碼電路有不同VHDL描述:

  1: IF INDEX=″00000″ THEN
        STEPSIZE<=″0000111″;
        WLSIF INDEX=″00001″ THEN
        STEPSIZE<=″0001000″;
        LSIF INDEX=″00010″ THEN
        STEPSIZE<=″0001001″;
        ……
        ELSE
            STEPSIZE<=″0000000″;
        END IF;

 。玻篠TEPSIZE<=″0000111″ WHEN INDEX=″00000″ ELSE
                  ″0001000″ WHEN INDEX=″00001″ELSE
                  ″0001001″WHEN INDEX=″00010″ ELSE
        ……
                 ″0000000″;

  以上兩段程序描述了同一個(gè)譯碼電路。第二段程序由于WHEN......ELSE的語句不能生成鎖存器的結(jié)構(gòu)且ELSE后一定要有結(jié)果,所以不會(huì)有問題,而第一個(gè)程序如果不加ELSE STEPSIZE〈=“0000000”這句,則會(huì)生成一個(gè)含有7位寄存器的結(jié)構(gòu),雖然都能實(shí)現(xiàn)相同的譯碼功能。但是電路復(fù)雜度會(huì)大增。而由于每個(gè)工程師的寫作習(xí)慣不同,有的喜歡用IF....ELSE的語句,有的喜歡用WHEN....ELSE的方式,而用IF....ELSE時(shí),如稍不注意,在描述不需要寄存器的電路時(shí)沒加ELSE,則會(huì)引起電路不必要的開銷。所以在VHDL設(shè)計(jì)中要慎用IF....ELSE這類能描述自身值代入的語句。

  2 設(shè)計(jì)規(guī)劃的優(yōu)劣直接影響電路結(jié)構(gòu)

  另一主要引起電路復(fù)雜化的原因是對(duì)設(shè)計(jì)規(guī)劃的不合理。雖然VHDL語言能從行為描述生成電路,但一個(gè)完整的設(shè)計(jì)一般來說都不可能由直接描述設(shè)計(jì)的目標(biāo)功能來實(shí)現(xiàn)的?傄言O(shè)計(jì)分成若干部分,每一部分再分別描述其行為。這就涉及到如何劃分功能模塊的問題,要求對(duì)設(shè)計(jì)了解的較深入,才能使劃分更有效,才能降低電路的復(fù)雜程度。例如我們?cè)O(shè)計(jì)一個(gè)時(shí)鐘源為1kHz,每32秒發(fā)出一組信號(hào)(共八組)的簡單的控制器來說。下面有兩種實(shí)現(xiàn)方法:

 。ǎ保┯15位的記數(shù)器實(shí)現(xiàn)把輸入1kHz的時(shí)鐘分頻為1/32Hz,然后用這個(gè)作為時(shí)鐘驅(qū)動(dòng)一個(gè)3位的記數(shù)器,這個(gè)記數(shù)器的八個(gè)狀態(tài)分別通過一個(gè)3-8譯碼器發(fā)出所要求的信號(hào)。

 。ǎ玻┲苯佑18位的記數(shù)器把輸入的1kHz時(shí)鐘進(jìn)行分頻,再利用記數(shù)器的八個(gè)相距32秒的狀態(tài)來推動(dòng)一個(gè)12-8譯碼器來實(shí)現(xiàn)。

  對(duì)于如此的設(shè)計(jì)要求,VHDL程序分別如下所示:

 。保 第一種設(shè)計(jì)方法的VHDL源程序

  process(clk,cclk,count2)
  begin
  if(clk='1' and clk'event)then
      count2<=count2 + 1;
      if(count2=″000000000000000″)then
        cclk<='1';
      else
        cclk<='0';
   end if;
  end if;
  end process;
  process(cclk,count3,ctemp)
  begin
  if(cclk='1' and cclk'event)then
     count3<=count3 +1;
     if(count3=″000″)then
        ctemp<=″00000001″;
     elsif(count3=″001″)then
        ctemp<=″00000010″;
     elsif(count3=″010″)then
        ctemp<=″00000100″;
     elsif(count3=″011″)then
        ctemp<=″00001000″;
     elsif(count3=″100″)then
        ctemp<=″00010000″;
     elsif(count3=″101″)then
        ctemp<=″00100000″;
     elsif(count3=″110″)then
        ctemp<=″01000000″;
     elsif(count3=″111″)then
       ctemp<=″10000000″;
     else
       ctemp<=″00000000″;
     end if;
  end if;
  end process;

 。玻 第二種設(shè)計(jì)方法的VHDL源程序

  process(clk,ctemp,count)
  begin
  if(clk='1' and clk'event)then
     count<=count + 1;
     if(count=″00000000000000000″)then
        ctemp<=″00000001″;
     elsif(count=″001000000000000000″)then
        ctemp<=″00000010″;
     elsif(count=″010000000000000000″)then
        ctemp<=″00000100″;
     elsif(count=″011000000000000000″)then
        ctemp<=″00001000″;
     elsif(count=″100000000000000000″)then
        ctemp<=″00010000″;
     elsif(count=″101000000000000000″)then
        ctemp<=″00100000″;
     elsif(count=″110000000000000000″)then
        ctemp<=″01000000″;
     elsif(count=″111000000000000000″)then
        ctemp<=″10000000″;
     end if;
  end if;
  end peocess;

[1] [2] [3]  下一頁
  • 上一篇: AT93C46/56/55串行EEPROM及單片機(jī)程序
  • 下一篇: 固定邏輯與可編程邏輯有何區(qū)別
  • 發(fā)表評(píng)論   告訴好友   打印此文  收藏此頁  關(guān)閉窗口  返回頂部
    熱點(diǎn)文章
     
    推薦文章
     
    相關(guān)文章
    網(wǎng)友評(píng)論:(只顯示最新5條。)
    關(guān)于我們 | 聯(lián)系我們 | 廣告合作 | 付款方式 | 使用幫助 | 機(jī)電之家 | 會(huì)員助手 | 免費(fèi)鏈接

    點(diǎn)擊這里給我發(fā)消息66821730(技術(shù)支持)點(diǎn)擊這里給我發(fā)消息66821730(廣告投放) 點(diǎn)擊這里給我發(fā)消息41031197(編輯) 點(diǎn)擊這里給我發(fā)消息58733127(審核)
    本站提供的機(jī)電設(shè)備,機(jī)電供求等信息由機(jī)電企業(yè)自行提供,該企業(yè)負(fù)責(zé)信息內(nèi)容的真實(shí)性、準(zhǔn)確性和合法性。
    機(jī)電之家對(duì)此不承擔(dān)任何保證責(zé)任,有侵犯您利益的地方請(qǐng)聯(lián)系機(jī)電之家,機(jī)電之家將及時(shí)作出處理。
    Copyright 2007 機(jī)電之家 Inc All Rights Reserved.機(jī)電之家-由機(jī)電一體化網(wǎng)更名-聲明
    電話:0571-87774297 傳真:0571-87774298
    杭州濱興科技有限公司提供技術(shù)支持

    主辦:杭州市高新區(qū)(濱江)機(jī)電一體化學(xué)會(huì)
    中國行業(yè)電子商務(wù)100強(qiáng)網(wǎng)站

    網(wǎng)站經(jīng)營許可證:浙B2-20080178-1