[導(dǎo)讀]近年來,隨著集成電路技術(shù)的發(fā)展,用傳統(tǒng)的方法進行芯片或系統(tǒng)設(shè)計已不能滿足要求,迫切需要提高設(shè)計效率。在這樣的技術(shù)背景下,能大大降低設(shè)計難度的VHDL設(shè)計方法正越來越廣泛地被采用。但是VHDL設(shè)計是行為
近年來,隨著集成電路技術(shù)的發(fā)展,用傳統(tǒng)的方法進行芯片或系統(tǒng)設(shè)計已不能滿足要求,迫切需要提高設(shè)計效率。在這樣的技術(shù)背景下,能大大降低設(shè)計難度的VHDL設(shè)計方法正越來越廣泛地被采用。但是VHDL設(shè)計是行為級的設(shè)計?所帶來的問題是設(shè)計者的設(shè)計思考與電路結(jié)構(gòu)相脫節(jié)。設(shè)計者主要是根據(jù)VHDL的語法規(guī)則?對系統(tǒng)目標(biāo)的邏輯行為進行描述?然后通過綜合工具進行電路結(jié)構(gòu)的綜合、編譯、優(yōu)化,通過仿真工具進行邏輯功能仿真和系統(tǒng)時延的仿真。實際設(shè)計過程中,由于每個工程師對語言規(guī)則、對電路行為的理解程度不同,每個人的編程風(fēng)格不同,往往同樣的系統(tǒng)功能,描述的方式是不一樣的,綜合出來的電路結(jié)構(gòu)更是大相徑庭。因此,即使最后綜合出的電路都能實現(xiàn)相同的邏輯功能,其電路的復(fù)雜程度和時延特性都會有很大的差別,甚至某些臃腫的電路還會產(chǎn)生難以預(yù)料的問題。從這個問題出發(fā),我們就很有必要深入討論在VHDL設(shè)計中如何簡化電路結(jié)構(gòu),優(yōu)化電路設(shè)計的問題。1 描述方法對電路結(jié)構(gòu)的影響用VHDL進行設(shè)計,其最終綜合出的電路的復(fù)雜程度除取決于設(shè)計要求實現(xiàn)的功能的難度外,還受設(shè)計工程師對電路的描述方法和對設(shè)計的規(guī)劃水平的影響。最常見的使電路復(fù)雜化的原因之一是設(shè)計中存在許多本不必要的類似LATCH的結(jié)構(gòu)。而且由于這些結(jié)構(gòu)通常都由大量的觸發(fā)器組成,不僅使電路更復(fù)雜,工作速度降低,而且由于時序配合的原因而導(dǎo)致不可預(yù)料的結(jié)果。例如對于同一譯碼電路有不同VHDL描述:1: IF INDEX=″00000″ THENSTEPSIZE<=″0000111″?ELSIF INDEX=″00001″ THENSTEPSIZE<=″0001000″?LSIF INDEX=″00010″ THENSTEPSIZE<=″0001001″?……ELSESTEPSIZE<=″0000000″?END IF;2:STEPSIZE<=″0000111″ WHEN INDEX=″00000″ ELSE″0001000″ WHEN INDEX=″00001″ELSE″0001001″WHEN INDEX=″00010″ ELSE……以上兩段程序描述了同一個譯碼電路。第二段程序由于WHEN .....ELSE的語句不能生成鎖存器的結(jié)構(gòu)且ELSE后一定要有結(jié)果,所以不會有問題,而第一個程序如果不加ELSE STEPSIZE〈=“0000000”這句,則會生成一個含有7位寄存器的結(jié)構(gòu),雖然都能實現(xiàn)相同的譯碼功能。但是電路復(fù)雜度會大增。而由于每個工程師的寫作習(xí)慣不同,有的喜歡用IF....ELSE的語句,有的喜歡用WHEN.....ELSE的方式,而用IF.....ELSE時,如稍不注意,在描述不需要寄存器的電路時沒加ELSE,則會引起電路不必要的開銷。所以在VHDL設(shè)計中要慎用IF ...ELSE這類能描述自身值代入的語句。2 設(shè)計規(guī)劃的優(yōu)劣直接影響電路結(jié)構(gòu)另一主要引起電路復(fù)雜化的原因是對設(shè)計規(guī)劃的不合理。雖然VHDL語言能從行為描述生成電路,但一個完整的設(shè)計一般來說都不可能由直接描述設(shè)計的目標(biāo)功能來實現(xiàn)的??傄言O(shè)計分成若干部分,每一部分再分別描述其行為。這就涉及到如何劃分功能模塊的問題,要求對設(shè)計了解的較深入,才能使劃分更有效,才能降低電路的復(fù)雜程度。例如我們設(shè)計一個時鐘源為1kHz,每32秒發(fā)出一組信號(共八組)的簡單的控制器來說。下面有兩種實現(xiàn)方法:(1)用15位的記數(shù)器實現(xiàn)把輸入1KHz的時鐘分頻為1/32Hz,然后用這個作為時鐘驅(qū)動一個3位的記數(shù)器,這個記數(shù)器的八個狀態(tài)分別通過一個3-8譯碼器發(fā)出所要求的信號。(2)直接用18位的記數(shù)器把輸入的1KHz時鐘進行分頻,再利用記數(shù)器的八個相距32秒的狀態(tài)來推動一個12-8譯碼器來實現(xiàn)。對于如此的設(shè)計要求,VHDL程序分別如下所示:1. 第一種設(shè)計方法的VHDL源程序process(clk?cclk?count2)beginif(clk='1' and clk'event)thencount2<=count2 + 1?if(count2=″000000000000000″)thencclk<='1'?elsecclk<='0'?end if?end if?end process?process(cclk?count3?ctemp)beginif(cclk='1' and cclk'event)thencount3<=count3 + 1?if(count3=″000″)thenctemp<=″00000001″?elsif(count3=″001″)thenctemp<=″00000010″?elsif(count3=″010″)thenctemp<=″00000100″?elsif(count3=″011″)thenctemp<=″00001000″?elsif(count3=″100″)thenctemp<=″00010000″?elsif(count3=″101″)thenctemp<=″00100000″?elsif(count3=″110″)thenctemp<=″01000000″?elsif(count3=″111″)thenctemp<=″10000000″?elsectemp<=″00000000″?end if?end if?end process?2. 第二種設(shè)計方法的VHDL源程序process(clk?ctemp?count)beginif(clk='1' and clk'event)thencount<=count + 1?if(count=″00000000000000000″)thenctemp<=″00000001″?elsif(count=″001000000000000000″)thenctemp<=″00000010″?elsif(count=″010000000000000000″)thenctemp<=″00000100″?elsif(count=″011000000000000000″)thenctemp<=″00001000″?elsif(count=″100000000000000000″)thenctemp<=″00010000″?elsif(count=″101000000000000000″)thenctemp<=″00100000″?elsif(count=″110000000000000000″)thenctemp<=″01000000″?elsif(count=″111000000000000000″)thenctemp<=″10000000″?end if?end if?end process?對于第一種的程序可以綜合出的電路如圖1所示。該電路用一個15位的加法器和寄存器組成一個15位的記數(shù)器。在記數(shù)器記完一周回到“000000000000000”時,通過后面的15輸入的與非門和一位的觸發(fā)器就可以實現(xiàn)同步的進行215次分頻,同步輸出32Hz的時鐘CCLK。CCLK再驅(qū)動一8位的移位寄存器,便可實現(xiàn)每32秒輸出一信號。而用第二種的程序設(shè)計綜合出的電路如圖2所示。圖2所示的電路用一個18位的加法器和寄存器組成一個18位的記數(shù)器。后接了8個18輸入的邏輯門和8輸入的或門。輸入的1KHz時鐘經(jīng)過記數(shù)器被分頻,其中有八個相隔32Hz的記數(shù)狀態(tài),邏輯門就負責(zé)把這八狀態(tài)譯碼成所需的八組信號。譯碼后的數(shù)據(jù)通過選擇器輸出到8位的觸發(fā)器,以實現(xiàn)同步輸出。還有個鎖存器,是用來保持輸出信號不變,在八個狀態(tài)中的從一個狀態(tài)變到下一個之前,保持前一個的數(shù)值。選擇器當(dāng)邏輯門輸出新的數(shù)據(jù)時讓其輸出數(shù)據(jù)通過,在新數(shù)據(jù)到來之前輸出鎖存器的數(shù)據(jù)。以上兩種方法都能實現(xiàn)相同的邏輯功能,但圖2所示的方法由于運用了較少位數(shù)的記數(shù)器,所用的邏輯門也較簡單,而且還少用了多路選擇器和鎖存器資源,所以綜合出來的電路較簡單,以XILINXSpartan S05 -3 芯片為例。第一種方法占用芯片CLB的12%,其中FMAPS為9%,最高工作速度為82MHz。而第二種方法占用了15%的CLB,FMAPS占用15%,最高工作速度只有69.9MHz。在這一個簡單的設(shè)計之中就能?。玻埃サ碾娐罚岣撸保玻保停龋墓ぷ魉俣?,由此可見科學(xué)的劃分設(shè)計對降低電路復(fù)雜程度的重要意義。3 邏輯設(shè)計對電路結(jié)構(gòu)的影響還有一個使電路復(fù)雜化的原因是邏輯電路的輸入項太多以致需占用過多的面積。我們從圖3和圖4兩個相同功能的邏輯電路和他們對應(yīng)的VHDL描述來分析。比較兩圖可知,圖3是二級邏輯門,每個輸入信號與不只一個邏輯門相連,圖4是三級的邏輯門,每個輸入信號只與一邏輯門相連。由于級數(shù)少,延時也較少,因此圖3的速度要比圖4快。然而,由于圖3的輸入項要比圖4大的多(10:5),因此,占用的面積必然也比圖3大。圖4是圖3通過提取公因數(shù)(例中是B和C)得來的,這是把附加的中間項加到結(jié)構(gòu)描述中去的一種過程,它使輸入到輸出中的邏輯級數(shù)增加,犧牲速度換來電路占用面積的減少。對于對延時要求不高的情況下采用這種方法分解邏輯電路以達到減少電路復(fù)雜度的目的。通過以上簡單、初步的探討,我們可以知道,用VHDL進行集成電路的設(shè)計,牽涉到對VHDL語言的使用方法和對設(shè)計的理解程度。本文討論了以下幾個簡化和優(yōu)化電路設(shè)計的3個值得注意的方面:(1)在用VHDL進行設(shè)計中要注意避免不必要的寄存器描述。(2)在編寫程序前要先對整個設(shè)計進行較深入的了解?科學(xué)的劃分設(shè)計,多設(shè)想幾種方案?再進行比較?用多個較少位數(shù)的單元取代較多位數(shù)的單元。(3)在延時要求不高的情況下,可提取邏輯電路公因子?把它分解成含有中間變量的多級電路。
來源:零八我的愛
0次
本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
本文介紹一款小尺寸、功能強大、低噪聲的單芯片同步升壓轉(zhuǎn)換器。文章重點介紹了該集成電路的多個特性。這些特性能夠增強電路性能,并支持定制,以滿足各種應(yīng)用的要求。
關(guān)鍵字:
升壓轉(zhuǎn)換器
集成電路
電路
在電子電路設(shè)計領(lǐng)域,放大器是極為關(guān)鍵的元件,用于增強電信號的幅度,以滿足各類電子設(shè)備的需求。內(nèi)置增益設(shè)置電阻的放大器和分立差動放大器是兩種常見類型,它們在電路結(jié)構(gòu)、性能表現(xiàn)、成本以及設(shè)計靈活性等方面存在諸多不同。深入了解...
關(guān)鍵字:
放大器
電信號
電路
在電子設(shè)備的保護領(lǐng)域,雙向 TVS 管(瞬態(tài)電壓抑制二極管)發(fā)揮著至關(guān)重要的作用,能有效抵御瞬態(tài)過電壓對電路的損害。雙向 TVS 管根據(jù)內(nèi)部結(jié)構(gòu)的不同,可分為共陰和共陽兩種類型,它們在諸多方面存在顯著差異。深入了解這些區(qū)...
關(guān)鍵字:
瞬態(tài)電壓抑制二極管
雙向
電路
在電子電路的世界里,電感是一種不可或缺的元件,它如同一個 “電慣性” 的守護者,默默影響著電路中電流的變化。電感量與流過電感的電流之間存在著復(fù)雜而精妙的關(guān)系,深入理解這種關(guān)系,對于掌握電路原理、設(shè)計電子設(shè)備以及解決實際電...
關(guān)鍵字:
電流
電感量
電路
電氣設(shè)計領(lǐng)域常用的圖紙包括電氣原理圖、電器元件布置圖、電氣安裝接線圖以及二次電路圖。
關(guān)鍵字:
電路
原理圖
一直以來,可控硅都是大家的關(guān)注焦點之一。因此針對大家的興趣點所在,小編將為大家?guī)砜煽毓璧南嚓P(guān)介紹,詳細內(nèi)容請看下文。
關(guān)鍵字:
可控硅
萬用表
電路
在電子電路的世界里,電阻是最基礎(chǔ)且不可或缺的元件之一,它如同電路中的 “交通指揮員”,通過阻礙電流的流動,實現(xiàn)對電壓、電流的精準(zhǔn)調(diào)控,保障各類電子設(shè)備的正常運行。然而,在實際應(yīng)用中,電阻會因各種因素出現(xiàn)損壞,進而影響整個...
關(guān)鍵字:
電阻
電路
電流
在電子電路的廣袤世界里,電感線圈作為一種基礎(chǔ)且關(guān)鍵的電子元件,默默發(fā)揮著不可或缺的作用。從日常使用的手機、電腦,到復(fù)雜精密的工業(yè)控制設(shè)備、通信基站,電感線圈無處不在。它能夠儲存和釋放電磁能量,實現(xiàn)濾波、振蕩、變壓等多種功...
關(guān)鍵字:
電感線圈
電子元件
電路
為增進大家對集成電路的認(rèn)識,本文將對集成電路的分類以及集成電路的替換方法予以介紹。
關(guān)鍵字:
電路
指數(shù)
集成電路
為增進大家對集成電路的認(rèn)識,本文將對集成電路的核心器件以及檢測集成電路好壞的方法予以介紹。
關(guān)鍵字:
電路
指數(shù)
集成電路
在電子電路領(lǐng)域,電感和電容作為兩種基礎(chǔ)且重要的元件,廣泛應(yīng)用于各類電路之中。從簡單的濾波電路到復(fù)雜的通信系統(tǒng),它們的身影無處不在。然而,對于電感和電容究竟屬于線性元件還是非線性元件,以及如何準(zhǔn)確判斷這一屬性,許多人存在疑...
關(guān)鍵字:
電感
電容
電路
在電子電路的紛繁世界里,電阻 - 電容(RC)低通濾波器以其簡潔而高效的結(jié)構(gòu),成為信號處理與電路優(yōu)化的得力助手。它如同電子世界的 “濾網(wǎng)”,按照特定規(guī)則篩選和處理信號,在眾多領(lǐng)域發(fā)揮著不可或缺的作用。
關(guān)鍵字:
低通濾波器
信號處理
電路
在電子電路設(shè)計中,接地(GND)是構(gòu)建穩(wěn)定可靠電路系統(tǒng)的關(guān)鍵環(huán)節(jié)。合理的接地設(shè)計能夠減少電磁干擾、穩(wěn)定電路電位,確保電子設(shè)備正常運行。然而,有時出于特定的電路功能需求或解決電磁兼容性(EMC)問題,會在電路 GND 中串...
關(guān)鍵字:
接地
電磁兼容
電路
開關(guān)電源在現(xiàn)代電子設(shè)備中扮演著至關(guān)重要的角色,其體積小、效率高、穩(wěn)定性好的特點使其廣泛應(yīng)用于各個領(lǐng)域。然而,在實際應(yīng)用中,開關(guān)電源可能會因各種原因發(fā)生故障,導(dǎo)致設(shè)備停機。為了提高系統(tǒng)的可靠性和穩(wěn)定性,設(shè)計一種能夠?qū)崿F(xiàn)自動...
關(guān)鍵字:
開關(guān)電源
電路
在下述的內(nèi)容中,小編將會對反饋電路的相關(guān)消息予以報道,如果反饋電路是您想要了解的焦點之一,不妨和小編共同閱讀這篇文章哦。
關(guān)鍵字:
電路
反饋電路
一直以來,差分放大電路都是大家的關(guān)注焦點之一。因此針對大家的興趣點所在,小編將為大家?guī)聿罘址糯箅娐返南嚓P(guān)介紹,詳細內(nèi)容請看下文。
關(guān)鍵字:
電路
放大電路
差分放大電路
在電子電路中,電容是一種極為常見且重要的電子元件,廣泛應(yīng)用于濾波、耦合、儲能等電路環(huán)節(jié)。然而,當(dāng)電容受到過高電壓、過大電流或其他異常因素影響時,可能會發(fā)生擊穿現(xiàn)象。電容擊穿后究竟是開路還是短路,這一問題不僅關(guān)乎電子電路的...
關(guān)鍵字:
電容
電子元件
電路
PCB板,全稱為印刷電路板(Printed Circuit Board),是一種用于組裝電子元件的基板。它通常由一層或多層絕緣材料制成,上面印制有銅線軌跡,這些軌跡將電路中的各個部分連接起來,形成一個完整的電路系統(tǒng)。這些...
關(guān)鍵字:
PCB
電路
在電子電路中,變壓器降壓后整流是常見的電源處理方式。電解電容在其中起著關(guān)鍵作用,其值的選擇直接影響到電源的穩(wěn)定性、紋波大小以及電路的性能。合理選擇電解電容值對于確保電路正常運行至關(guān)重要。
關(guān)鍵字:
變壓器
電解電容
電路
在電力電子和電源設(shè)計領(lǐng)域,變壓器次級兩端串聯(lián)RC(電阻-電容)電路是一種常見的設(shè)計實踐。這種配置在多種應(yīng)用中發(fā)揮著關(guān)鍵作用,以下是RC串聯(lián)在變壓器次級兩端的主要作用:
關(guān)鍵字:
電力電子
RC串聯(lián)
電路