<var id="fnfpo"><source id="fnfpo"></source></var>
<rp id="fnfpo"></rp>

<em id="fnfpo"><object id="fnfpo"><input id="fnfpo"></input></object></em>
<em id="fnfpo"><acronym id="fnfpo"></acronym></em>
  • <th id="fnfpo"><track id="fnfpo"></track></th>
  • <progress id="fnfpo"><track id="fnfpo"></track></progress>
  • <tbody id="fnfpo"><pre id="fnfpo"></pre></tbody>

  • x
    x

    VHDL設計中電路簡化問題的探討

    發布時間:2010-12-7 00:52    發布者:conniede
    關鍵詞: CCLK , VHDL , 記數器
    近年來,隨著集成電路技術的發展,用傳統的方法進行芯片或系統設計已不能滿足要求,迫切需要提高設計效率。在這樣的技術背景下,能大大降低設計難度的VHDL設計方法正越來越廣泛地被采用。但是VHDL設計是行為級的設計?熕?帶來的問題是設計者的設計思考與電路結構相脫節。設計者主要是根據VHDL的語法規則,行為進行描述,綜合工具進行電路結構的綜合、編譯、優化,通過仿真工具進行邏輯功能仿真和系統時延的仿真。實際設計過程中,由于每個工程師對語言規則、對電路行為的理解程度不同,每個人的編程風格不同,往往同樣的系統功能,描述的方式是不一樣的,綜合出來的電路結構更是大相徑庭。因此,即使最后綜合出的電路都能實現相同的邏輯功能,其電路的復雜程度和時延特性都會有很大的差別,甚至某些臃腫的電路還會產生難以預料的問題。從這個問題出發,我們就很有必要深入討論在VHDL設計中如何簡化電路結構,優化電路設計的問題。

    1描述方法對電路結構的影響

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

    1):IFINDEX=″00000″THEN

    STEPSIZE<=″0000111″;??

    WLSIFINDEX=″00001″THEN

    STEPSIZE<=″0001000″;??

    LSIFINDEX=″00010″THEN

    STEPSIZE<=″0001001″;??

    ……

    ELSE

    STEPSIZE<=″0000000″;??

    ENDIF;

    2):STEPSIZE<=″0000111″WHENINDEX=″00000″ELSE

    ″0001000″WHENINDEX=″00001″ELSE

    ″0001001″WHENINDEX=″00010″ELSE

    ……

    ″0000000″;??

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

    2設計規劃的優劣直接影響電路結構

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

    (1)用15位的記數器實現把輸入1kHz的時鐘分頻為1/32Hz,然后用這個作為時鐘驅動一個3位的記數器,這個記數器的八個狀態分別通過一個3-8譯碼器發出所要求的信號。

    18位的記數器把輸入的1kHz時鐘進行分頻,再利用記數器的八個相距32秒的狀態來推動一個12-8譯碼器來實現。

    對于如此的設計要求,VHDL程序分別如下所示:

    1).第一種設計方法的VHDL源程序

    process(clk,cclk,count2)??

    begin

    if??(clk='1'andclk'event)then

    count2<=count2+1;??

    if(count2=″000000000000000″)then

    cclk<='1';??

    else

    cclk<='0';??

    endif;??

    endif;??

    endprocess;??

    process(cclk,count3,ctemp)??

    begin

    if(cclk='1'andcclk'event)then

    count3<=count3+1;??

    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″;??

    endif;??

    endif;??

    endprocess;??

    2).第二種設計方法的VHDL源程序

    process(clk,ctemp,count)

    begin

    if(clk='1'andclk'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″;??

    endif;??

    endif;??

    endpeocess;??

    對于第一種的程序可以綜合出的電路如圖1所示。


    該電路用一個15位的加法器和寄存器組成一個15位的記數器。在記數器記完一周回到“000000000000000”時,通過后面的15輸入的與非門和一位的觸發器就可以實現同步的進行215次分頻,同步輸出32Hz的時鐘CCLK。CCLK再驅動一8位的移位寄存器,便可實現每32秒輸出一信號。

    而用第二種的程序設計綜合出的電路如圖2所示。


    圖2所示的電路用一個18位的加法器和寄存器組成一個18位的記數器。后接了8個18輸入的邏輯門和8輸入的或門。輸入的1kHz時鐘經過記數器被分頻,其中有八個相隔32Hz的記數狀態,邏輯門就負責把這八狀態譯碼成所需的八組信號。譯碼后的數據通過選擇器輸出到8位的觸發器,以實現同步輸出。還有個鎖存器,是用來保持輸出信號不變,在八個狀態中的從一個狀態變到下一個之前,保持前一個的數值。選擇器當邏輯門輸出新的數據時讓其輸出數據通過,在新數據到來之前輸出鎖存器的數據。

    以上兩種方法都能實現相同的邏輯功能,但圖2所示的方法由于運用了較少位數的記數器,所用的邏輯門也較簡單,而且還少用了多路選擇器和鎖存器資源,所以綜合出來的電路較簡單,以XILINX SpartanS05-3芯片為例。第一種方法占用芯片CLB的12%,其中FMAPS為9%,最高工作速度為82Hz。而第二種方法占用了15%的CLB,FMAPS占用15%,最高工作速度只有69.9MHz。在這一個簡單的設計之中就能省20%的電路,提高12.1MHz的工作速度,由此可見科學的劃分設計對降低電路復雜程度的重要意義。

    還有一個使電路復雜化的原因是邏輯電路的輸入項太多以致需占用過多的面積。我們從圖3和圖4兩個相同功能的邏輯電路和他們對應的VHDL描述來分析。




    比較兩圖可知,圖3是二級邏輯門,每個輸入信號與不只一個邏輯門相連,圖4是三級的邏輯門,每個輸入信號只與一邏輯門相連。由于級數少,延時也較少,因此圖3的速度要比圖4快。然而,由于圖3 的輸入項要比圖4大的多(10:5),因此,占用的面積必然也比圖3大。圖4是圖3通過提取公因數(例中是B和C)得來的,這是把附加的中間項加到結構描述中去的一種過程,它使輸入到輸出中的邏輯級數增加,犧牲速度換來電路占用面積的減少。對于對延時要求不高的情況下采用這種方法分解邏輯電路以達到減少電路復雜度的目的。

    通過以上簡單、初步的探討,我們可以知道,用VHDL進行集成電路的設計,牽涉到對VHDL語言的使用方法和對設計的理解程度。本文討論了以下幾個簡化和優化電路設計的3個值得注意的方面:

    (1)在用VHDL進行設計中要注意避免不必要的寄存器描述。

    (2)在編寫程序前要先對整個設計進行較深入的了解?熆蒲У幕?分設計,多設想幾種方案行比較的單元取代較多位數的單元。

    (3)在延時要求不高的情況下,可提取邏輯電路公因子?分解成含有中間變量的多級電路。
    本文地址:http://www.portaltwn.com/thread-44541-1-1.html     【打印本頁】

    本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
    wmf000000 發表于 2011-1-13 10:43:04
    very good! thanks!!!
    您需要登錄后才可以發表評論 登錄 | 立即注冊

    廠商推薦

    • Microchip視頻專區
    • EtherCAT®和Microchip LAN925x從站控制器介紹培訓教程
    • MPLAB®模擬設計器——在線電源解決方案,加速設計
    • 讓您的模擬設計靈感,化為觸手可及的現實
    • 深度體驗Microchip自動輔助駕駛應用方案——2025巡展開啟報名!
    • 貿澤電子(Mouser)專區
    關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
    電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
    快速回復 返回頂部 返回列表
    精品一区二区三区自拍图片区_国产成人亚洲精品_亚洲Va欧美va国产综合888_久久亚洲国产精品五月天婷