版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p> 計算機科學(xué)與工程學(xué)院</p><p><b> 課程設(shè)計報告</b></p><p> 題目全稱: 用硬件描述語言設(shè)計浮點乘法器(補碼一位乘法) </p><p> 課程名稱: 計算機組成原理 </p><p> 指導(dǎo)老師:
2、 職稱: </p><p><b> 指導(dǎo)老師評語:</b></p><p> 指導(dǎo)教師簽字: </p><p><b> 摘 要</b></p><p> 數(shù)字乘法器,作為現(xiàn)代計算機中必不可少的一部分,其設(shè)計工作越來越受到人們的重視
3、。本文采用硬件描述語言verilog HDL設(shè)計了一個基于補碼一位乘法的浮點乘法器,設(shè)計功能完善,靈活性較好。理論依據(jù)包括浮點運算和補碼一位乘法運算。本文對開發(fā)環(huán)境,測試環(huán)境做了簡要介紹,并對設(shè)計過程進行了詳細(xì)的描述分析,使用Modelsim軟件的Simulator模塊進行了功能仿真。</p><p> 關(guān)鍵字:浮點運算;補碼一位乘法;乘法器;verilog HDL</p><p>&l
4、t;b> Abstract</b></p><p> Digital multiplier,as an essential part of modern computer,its design has been paid more and more attention.In this paper,we use the hardware description language verilog
5、 HDL-based to design a complement of multiplication of floating-point multiplier whose function and flexibility are good.Theoretical basis includes floating-point operations and complement multiplication.In this paper,w
6、e introduce the environment of development and test briefly,and the design process is described in detail anal</p><p> Key words: floating-point operations; complement of multiplication; multiplier;</p&
7、gt;<p> verilog HDL</p><p><b> 目 錄</b></p><p> 第一章 引言4</p><p><b> 1.1課題背景4</b></p><p> 1.1.1應(yīng)用領(lǐng)域4</p><p> 1.1
8、.2國內(nèi)外研究現(xiàn)狀4</p><p> 1.2課題意義及價值5</p><p> 1.3 理論依據(jù)5</p><p> 1.3.1浮點運算原理5</p><p> 1.3.2補碼一位乘法運算原理6</p><p> 1.4課題的難點、重點、核心問題及方向9</p><p>
9、 1.5本組所做的工作9</p><p> 1.6主要內(nèi)容與章節(jié)安排9</p><p> 第二章 課題設(shè)計與實現(xiàn)11</p><p> 2.1開發(fā)工具簡介11</p><p> 2.1.1 Verilog HDL硬件描述語言11</p><p> 2.1.2 Quartus II11<
10、;/p><p> 2.2需求分析與概要設(shè)計12</p><p> 2.3設(shè)計框架與流程圖13</p><p> 2.3.1設(shè)計框圖13</p><p> 2.3.2設(shè)計流程圖13</p><p> 2.4詳細(xì)設(shè)計16</p><p> 2.4.1補碼一位乘法模塊設(shè)計16<
11、;/p><p> 2.4.2規(guī)格化模塊設(shè)計19</p><p> 2.4.3控制模塊及加法模塊設(shè)計21</p><p> 2.4.3.1加法模塊設(shè)計21</p><p> 2.4.3.2控制模塊設(shè)計21</p><p> 第三章 仿真測試22</p><p> 3.1仿真
12、測試環(huán)境22</p><p> 3.2模塊仿真測試24</p><p> 3.2.1(補碼一位)乘法模塊仿真測試24</p><p> 3.2.2規(guī)格化模塊仿真測試25</p><p> 3.2.3加法模塊仿真測試27</p><p> 3.3總測試(控制模塊測試)29</p>&l
13、t;p> 第四章 總結(jié)與展望33</p><p> 4.1問題及解決方案總結(jié)33</p><p> 4.1.1乘法模塊編寫問題33</p><p> 4.1.2規(guī)格化模塊編寫問題33</p><p> 4.2結(jié)論及展望33</p><p><b> 參考文獻(xiàn)34</b
14、></p><p><b> 致 謝34</b></p><p> 第一章 引言</p><p><b> 1.1課題背景</b></p><p><b> 1.1.1應(yīng)用領(lǐng)域</b></p><p> 近三十年來,隨著數(shù)
15、字信號處理技術(shù)(DSP)的廣泛應(yīng)用和超大規(guī)模集成電路工藝的不斷進步,數(shù)字乘法器的設(shè)計越來越受到人們的重視。該技術(shù)是上世紀(jì)60年代發(fā)展起來的一門新興學(xué)科,當(dāng)時主要采用計算機模擬的方法研究數(shù)字濾波器,現(xiàn)在已經(jīng)廣泛用于需要對信號進行譜分析、濾波、壓縮的眾多學(xué)科和工程領(lǐng)域。</p><p> 1.1.2國內(nèi)外研究現(xiàn)狀</p><p> 當(dāng)今數(shù)字信號處理技術(shù)領(lǐng)域里較好,運用較為廣泛的帶符號數(shù)乘法
16、的算法本文列出三個:上世紀(jì)50年代,VLSI技術(shù)發(fā)展出的由門陣列和二維加法器陣列組成的陣列乘法器;之后是由A.D.Booth在1951年提出的Booth算法,十年后由MacSorely提出了修正之后的Booth算法,并一直廣泛運用至今;再有就是1977年由Ron Rivest、Adi Shamirh和LenAdleman開發(fā)的當(dāng)今通信領(lǐng)域廣發(fā)運用的加密算法之一的RSA算法,其主要涉及到的計算為:</p><p>
17、<b> ?。?)</b></p><p> 下面簡要介紹一下上文提到過的三種算法:</p><p> 陣列乘法器:早期計算機中為了簡化硬件結(jié)構(gòu),采用串行的1位乘法方案,即反復(fù)執(zhí)行“加法-移位”操作來實現(xiàn),這種方法并不需要很多的器件。而陣列乘法器的出現(xiàn)就是為了解決這種因串行執(zhí)行方式而消耗大量時間的問題,所以自從大規(guī)模集成電路問世以來,出現(xiàn)了各種形式的流水式陣列乘法
18、器,它們屬于并行乘法器。帶符號數(shù)的陣列乘法器在邏輯結(jié)構(gòu)中,由兩個求補器作無符號數(shù)乘法處理,和一個算后求補器作符號位處理。</p><p> RSA算法:它主要涉及公式(1)的計算,而用反復(fù)平方法可使上述計算時間只與log2(e)線性相關(guān)。在超大規(guī)模集成電路的發(fā)展中,高速、低功耗、版圖設(shè)計規(guī)則、占用芯片面積小等成為乘法器研究的重點。</p><p> Booth算法:它采用相加和相減的操
19、作計算補碼數(shù)據(jù)的乘積。Booth算法對乘數(shù)從低位開始判斷,根據(jù)兩個數(shù)據(jù)位的情況決定進行加法、減法還是僅僅移位操作。判斷的兩個數(shù)據(jù)位為當(dāng)前位及其右邊的位(初始時需要增加一個輔助位0),移位操作是向右移動。其核心思想是通過對乘數(shù)編碼,壓縮部分積個數(shù),進而縮短乘法運算的時間,而修正后的Booth算法將部分積的個數(shù)壓縮至原來的1/2左右,且與乘數(shù)無關(guān)。本次課程設(shè)計所選用的設(shè)計算法就是Booth算法,所以會在正文中作詳細(xì)的說明。</p>
20、;<p> 1.2課題意義及價值</p><p> 乘法運算在數(shù)字信號處理算法中占有重要地位。因為在數(shù)字信號處理中存在著大量形如Y=AX+B的運算,即兩個數(shù)相乘后與另一個數(shù)相加,而且這種運算往往是反復(fù)進行的。因此,研究硬件乘法器是實時數(shù)字信號處理器中乘法實現(xiàn)的需要。自數(shù)字信號處理技術(shù)誕生之日起,實時處理就是人們奮斗不懈的目標(biāo)。實時處理的實現(xiàn),一方面在于采用先進算法降低運算量,另一方面在于提高硬件
21、運算的速度。根據(jù)查閱資料并顯示,假設(shè)每條基本指令按1us計算(乘除指令除外),軟件執(zhí)行完成一次4位×4位(2二進制)的乘法需要約100us,協(xié)處理器(如8087),執(zhí)行定點和浮點乘法運算需要20us,而硬件乘法器作為專用運算單元,可以在幾十ns內(nèi)完成一次浮點乘法運算。由此可見,乘法的硬件實現(xiàn)對于提升DSP系統(tǒng)性能有重要意義。目前再來看一組數(shù)據(jù),“目前,嵌入式設(shè)計中約有38%已經(jīng)采用了DSP芯片代替?zhèn)鹘y(tǒng)的MCU芯片,以制造具有更
22、高性能的產(chǎn)品;另外約有49%正計劃采用(Fig1.7)。全國DSP市場的年增長率超過30%,是集成電路平均增長速度的兩倍(Fig1.8)。”由上可以看出,數(shù)字乘法器的技術(shù)發(fā)展推動著DSP的發(fā)展。</p><p> 研究本課題,于組內(nèi)成員而言的意義在于,通過查閱相關(guān)的資料,能使我們進一步透徹的掌握補碼一位乘法的計算原理,分析乘法的計算過程及整個運算中涉及到的各模塊的工作原理。本課題實現(xiàn)的是浮點一位乘法運算,這是一
23、個從簡到繁的過程,對以后涉及多位乘法器打下了好的基礎(chǔ)。此外,本課程設(shè)計還是我們學(xué)習(xí)、熟悉了新的一種硬件編程語言Verilog HDL。</p><p><b> 1.3 理論依據(jù)</b></p><p> 1.3.1浮點運算原理</p><p><b> 設(shè)浮點數(shù)A=,則</b></p><p&g
24、t; 即階碼相加,尾數(shù)相乘。其運算可按以下步驟進行。</p><p> ?、?檢測能否簡化操作,并置結(jié)果數(shù)符。如果操作數(shù)中有一個為0,乘積必為0,不需做其他操作。如果兩數(shù)均不為0,才進行乘法運算。結(jié)果數(shù)符按同號相乘為正、異號相乘為負(fù)的規(guī)則確定。</p><p> ?、?階碼相加。如果階碼用補碼表示,則階碼相加可按常規(guī)補碼加法進行。如果階碼用移碼(增碼)表示,由于階碼本身已有一個偏移量,相
25、加后偏移量將加倍,所以移碼相加后應(yīng)作修正(即減去)。階碼相加有可能產(chǎn)生溢出,同號相加可能上溢(正階碼),也可能下溢(負(fù)階碼)。當(dāng)產(chǎn)生溢出時,浮點運算器將發(fā)出溢出信號,使機器轉(zhuǎn)入溢出處理。</p><p> ?、?尾數(shù)相乘,可以用任何一種定點小數(shù)乘法實現(xiàn)??梢姼↑c數(shù)乘法包含兩組定點運算,即定點整數(shù)的階碼運算與定點小數(shù)的尾數(shù)運算。這兩組運算可以共用一個加法器,分步執(zhí)行;也可以在常規(guī)加法器的基礎(chǔ)上再設(shè)置一個專門的階碼加
26、法器,并行執(zhí)行,以提高運算速度。</p><p> ?、?乘積規(guī)格化。尾數(shù)相乘后,可能需要左規(guī)。由于尾數(shù)是定點小數(shù),相乘后不會出現(xiàn)需右規(guī)的情況。左規(guī)時階碼減1,有下溢的可能。</p><p> 1.3.2補碼一位乘法運算原理</p><p> 補碼乘法是指操作數(shù)與結(jié)果均以補碼表示,連同符號位一起,按相應(yīng)算法運算。實現(xiàn)補碼乘法有兩種方法。一種是先按原碼乘法那樣直接
27、乘,再根據(jù)乘數(shù)符號進行校。其算法規(guī)則如下:</p><p> 1)、不管被乘數(shù)X補的符號如何,只要乘數(shù)Y補為正,則可像原碼乘法一樣進行運算,其結(jié)果不需要校正。</p><p> 2)、如果乘數(shù)Y補為負(fù),則先按原碼乘法運算,結(jié)果再加一個校正量-X補。這種算法稱為校正法。</p><p> 另一種方法是將校正法的兩種情況統(tǒng)一起來,演變?yōu)楸容^法。由于它是Booth夫
28、婦首先提出的,所以又稱為Booth算法。這是現(xiàn)在廣泛采用的補碼乘法,如果不加說明,一般所指的補碼算法就是比較法。</p><p><b> (1)比較算法分析</b></p><p> 補碼一位乘比較法可用下式表示:</p><p> ?。?)式(1)概括了校正法的兩種情況:如果乘數(shù)為正,即,Y的尾數(shù)乘以被乘數(shù)(X)補,不需校正。若乘數(shù)為
29、負(fù),即,則(X)補乘以(Y)補的尾數(shù)后,再減(X)補校正。</p><p><b> 將式(1)改寫為:</b></p><p><b> ?。?)</b></p><p> 在機器實現(xiàn)中可在末位Yn之后再增設(shè)一個附加位Yn+1,其初始值為0,對乘數(shù)Y的值并無影響。若定義(A0)補為初始部分積,[A1]補-[An]補依
30、次為各步求得累加并右移后的部分積,則式(2)改寫為如下遞推公式,它更接近于乘法的分步運算形式。</p><p> ?。?) </p><p> 式(3)表明了補碼一位乘法的基本操作:被乘數(shù)X補乘以對應(yīng)的相鄰兩位乘數(shù)之差值,再與原部分積累加,然后右移一位,形成該步的部分積累加和。由于根據(jù)相鄰兩位乘數(shù)之差(低位減高位),即兩位的比較結(jié)果來決定相應(yīng)操作,所以稱為比較法。
31、因為每步要右移1位,所以參與比較的兩位始終位于最末的Yn、Yn+1,可根據(jù)這兩位的值決定操作,規(guī)則如表1-1所示。</p><p> 表1-1 補碼一位乘規(guī)則</p><p><b> (2)運算實例</b></p><p> X=-0.1101,Y=-0.1011,求(XY)補。初值:A=00.0000,B=X補=11.0011,
32、 -B=(-X)補=00.1101,C =Y補=1.0101</p><p> 圖1-1 補碼一位乘實例</p><p> 本例以分步算式的形式表明了補碼一位乘法的運算過程,下面再對有關(guān)要點進行說明。</p><p><b> 1、初始值和符號位</b></p><p> A寄存器用來存放部分積累加和,初
33、始值為0 ,采取雙符號位。累加時可能產(chǎn)生的進位暫存于第二符號位,第一符號位始終指示部分積累加和的正負(fù),以控制右移時補0或補1.補碼乘法中有加或減,相應(yīng)地,部分積可能有正有負(fù),這就需要第一符號位保持正負(fù)標(biāo)志。</p><p> B寄存器中存放補碼表示的被乘數(shù)X補,雙符號為(與A相對應(yīng))。補碼一位乘的基本操作有A+B和A-B,所以在算式中先寫X補(B)和-X補(-B)的值。</p><p>
34、 C寄存器存放補碼表示的乘數(shù)Y補。取單符號位,以控制最后一步操作,該步操作體現(xiàn)了乘數(shù)正負(fù)的影響。Y的末位添0,稱為附加位。</p><p><b> 2、基本操作</b></p><p> 用C寄存器最末兩位(含增加的)作判斷位,按前述規(guī)則決定各步操作。如第一步,判斷位為10,低位減高位得-1,所以執(zhí)行A-B,然后右移一位。又如第二步,判斷位為01,低位減高位得
35、1,執(zhí)行A+B。</p><p> 每步加/減后讓A與C右移一位,而每次是相鄰兩位乘數(shù)比較,所以除去C的符號位和增加的末位0以外,各乘數(shù)位將參加兩次比較。注意,現(xiàn)在討論的是補碼一位乘,比較兩位只相當(dāng)于處理一位乘數(shù),不可誤認(rèn)為兩位乘。</p><p><b> 3、移位</b></p><p> 在右移時,第二符號位值移入尾數(shù)的最高數(shù)位,第
36、一符號位值移入第二符號位。第一符號位本身不變,而A寄存器末位移入C寄存器。</p><p> 4、步數(shù)與最后一步操作</p><p> 如上例,乘數(shù)的有效位數(shù)是4位,共做5步。除C0與Cn+1位外,有效尾數(shù)中各位均參與兩次比較。注意,最后一位不移位,因為這一步是用來處理符號位的,按式(3),這一步不再移位。</p><p> 1.4課題的難點、重點、核心問題及
37、方向</p><p> 根據(jù)本課程設(shè)計的基本思路,課題最核心的問題在于補碼一位乘法模塊的設(shè)計,同時,這也是本課題設(shè)計的重點與難點。本課題的方向為,使浮點乘法器靈活實現(xiàn)各位數(shù)級(4位,8位,16位等)上的浮點乘法運算。</p><p> 1.5本組所做的工作</p><p> 本組采用硬件描述語言設(shè)計,實現(xiàn)一個基于補碼一位乘法的浮點乘法器,包括加法器,補碼一位乘
38、法器,規(guī)格化程序等子設(shè)計。本組所做的工作包括,對浮點運算,補碼一位乘法運算原理的分析,編碼實現(xiàn)浮點乘法器,編寫測試代碼對浮點乘法器進行仿真測試。最后是將設(shè)計原理,設(shè)計框圖,設(shè)計代碼及測試代碼,以及對設(shè)計的背景與意義,總結(jié)與分析編輯,整理,撰寫成課程設(shè)計論文。</p><p> 1.6主要內(nèi)容與章節(jié)安排</p><p> 本文第二章介紹了課題的設(shè)計與實現(xiàn)過程,包括概要設(shè)計與詳細(xì)設(shè)計兩部分
39、,涵蓋了設(shè)計思想,邏輯框圖,流程圖以及程序源代碼等。第三章介紹的是對本設(shè)計所做的測試工作,包括對測試環(huán)境的介紹,以及各模塊測試和總體測試的測試用例、測試依據(jù)等的介紹。第四章主要是對代碼編寫與測試過程中遇到的問題及其解決方案的介紹,最后是對工作的總結(jié)和未來的展望。</p><p> 第二章 課題設(shè)計與實現(xiàn)</p><p><b> 2.1開發(fā)工具簡介</b>&
40、lt;/p><p> 2.1.1 Verilog HDL硬件描述語言</p><p> Verilog HDL是一種硬件描述語言,用于從算法級、門級到開關(guān)級的多種抽象設(shè)計層次的數(shù)字系統(tǒng)建模。被建模的數(shù)字系統(tǒng)對象的復(fù)雜性可以介于簡單的門和完整的電子數(shù)字系統(tǒng)之間。數(shù)字系統(tǒng)能夠按層次描述,并可在相同描述中顯式地進行時序建模。</p><p> Verilog HDL語言
41、最初是于1983年由Gateway Design Automation公司為其模擬器產(chǎn)品開發(fā)的硬件建模語言。那時它只是一種專用語言。由于他們的模擬、仿真器產(chǎn)品的廣泛使用,Verilog HDL 作為一種便于使用且實用的語言逐漸為眾多設(shè)計者所接受。在一次努力增加語言普及性的活動中,Verilog HDL語言于1990年被推向公眾領(lǐng)域。 Open Verilog International (OVI)是促進Verilog發(fā)展的國際性組織。1
42、992年, OVI決定致力于推廣Verilog OVI標(biāo)準(zhǔn)成為IEEE標(biāo)準(zhǔn)。這一努力最后獲得成功,Verilog 語言于1995年成為IEEE標(biāo)準(zhǔn),稱為IEEE Std 1364-1995。完整的標(biāo)準(zhǔn)在Verilog硬件描述語言參考手冊中有詳細(xì)描述。</p><p> Verilog HDL 語言具有下述描述能力:設(shè)計的行為特性、設(shè)計的數(shù)據(jù)流特性、設(shè)計的結(jié)構(gòu)組成以及包含響應(yīng)監(jiān)控和設(shè)計驗證方面的時延和波形產(chǎn)生機制
43、。所有這些都使用同一種建模語言。此外,Verilog HDL語言提供了編程語言接口,通過該接口可以在模擬、驗證期間從設(shè)計外部訪問設(shè)計,包括模擬的具體控制和運行。</p><p> Verilog HDL語言不僅定義了語法,而且對每個語法結(jié)構(gòu)都定義了清晰的模擬、仿真語義。因此,用這種語言編寫的模型能夠使用Verilog仿真器進行驗證。語言從C編程語言中繼承了多種操作符和結(jié)構(gòu)。Verilog HDL提供了擴展的建模
44、能力,其中許多擴展最初很難理解。但是,Verilog HDL語言的核心子集非常易于學(xué)習(xí)和使用,這對大多數(shù)建模應(yīng)用來說已經(jīng)足夠。當(dāng)然,完整的硬件描述語言足以對從最復(fù)雜的芯片到完整的電子系統(tǒng)進行描述。 </p><p> 2.1.2 Quartus II</p><p> Quartus II 是Altera公司的綜合性PLD開發(fā)軟件,支持原理圖、VHDL、Verilog HDL以及AHD
45、L(Altera Hardware Description Language)等多種設(shè)計輸入形式,內(nèi)嵌自有的綜合器以及仿真器,可以完成從設(shè)計輸入到硬件配置的完整PLD設(shè)計流程。</p><p> Quartus II可以在XP、Linux以及Unix上使用,除了可以使用Tcl腳本完成設(shè)計流程外,提供了完善的用戶圖形界面設(shè)計方式。具有運行速度快,界面統(tǒng)一,功能集中,易學(xué)易用等特點。</p><
46、p> Quartus II支持Altera的IP核,包含了LPM/MegaFunction宏功能模塊庫,使用戶可以充分利用成熟的模塊,簡化了設(shè)計的復(fù)雜性、加快了設(shè)計速度。對第三方EDA工具的良好支持也使用戶可以在設(shè)計流程的各個階段使用熟悉的第三方EDA工具。</p><p> 此外,Quartus II 通過和DSP Builder工具與Matlab/Simulink相結(jié)合,可以方便地實現(xiàn)各種DSP應(yīng)用
47、系統(tǒng);支持Altera的片上可編程系統(tǒng)(SOPC)開發(fā),集系統(tǒng)級設(shè)計、嵌入式軟件開發(fā)、可編程邏輯設(shè)計于一體,是一種綜合性的開發(fā)平臺。</p><p> Maxplus II 作為Altera的上一代PLD設(shè)計軟件,由于其出色的易用性而得到了廣泛的應(yīng)用。目前Altera已經(jīng)停止了對Maxplus II 的更新支持,Quartus II 與之相比不僅僅是支持器件類型的豐富和圖形界面的改變。Altera在Quartu
48、s II 中包含了許多諸如SignalTap II、Chip Editor和RTL Viewer的設(shè)計輔助工具,集成了SOPC和HardCopy設(shè)計流程,并且繼承了Maxplus II 友好的圖形界面及簡便的使用方法。</p><p> 2.2需求分析與概要設(shè)計</p><p> 本課題實現(xiàn)的是基于補碼一位乘法的浮點乘法器。輸入輸出情況如下:</p><p>
49、 輸入:待進行乘法運算的兩個浮點數(shù)的尾數(shù)和階碼(階底默認(rèn)為2)。</p><p> 輸出:運算結(jié)果的尾數(shù)與階碼。</p><p> 基于以上的輸入輸出條件,設(shè)計一個加法模塊進行階碼運算,一個補碼一位乘法模塊進行尾數(shù)運算。此外,考慮浮點運算的規(guī)格化問題,最終輸出結(jié)果,尾數(shù)應(yīng)該為大于1/2,小于1的數(shù),且乘法運算結(jié)果可能存在溢出位需要處理,故還須設(shè)計一個規(guī)格化模塊。最后設(shè)計一個控制模塊,驅(qū)
50、動三個模塊完成工作。</p><p> 基本運算過程為:先后調(diào)用加法模塊計算階碼相加結(jié)果,乘法模塊計算尾數(shù)相乘結(jié)果,再調(diào)用規(guī)格化模塊對前兩個模塊得到的結(jié)果進行規(guī)格化,最后輸出階碼與尾數(shù)結(jié)果。</p><p> 各模塊的輸入輸出設(shè)計如下:</p><p> module adder(EX,EY,EOUT);//階碼加法模塊</p><p>
51、; module multiply(Mx,My,Mout);//補碼一位乘法模塊</p><p> module SPEC( EIn,MIn,EOut,MOut);//規(guī)格化模塊</p><p> module run(Mx,My,E_X,E_Y,M_out,E_out);//運行控制模塊</p><p> 2.3設(shè)計框架與流程圖</p>
52、<p><b> 2.3.1設(shè)計框圖</b></p><p><b> 圖2-1 設(shè)計框圖</b></p><p> 依照概要設(shè)計方案,使用Quartus II工具生成邏輯框圖,如圖2-1所示。其中u1為加法模塊,四位的E_X,E_Y為兩個階碼輸入,四位EOUT為階碼輸出。u2為乘法模塊,六位的Mx,My(高兩位設(shè)計為符號位)為兩
53、個尾數(shù)輸入,Mout為尾數(shù)輸出。U3為規(guī)格化模塊,4位的EIn為階碼輸入,MIn為尾數(shù)輸入,EOut和MOut分別為階碼與尾數(shù)輸出。</p><p> 2.3.2設(shè)計流程圖</p><p> 圖2-2 設(shè)計流程圖</p><p> 本流程圖左側(cè)為階碼處理模塊,右側(cè)為尾數(shù)處理模塊。階碼處理模塊將輸入的階碼相加后輸出至下一個模塊,尾數(shù)處理模塊進行n次循環(huán)移位(n為
54、乘數(shù)的尾數(shù)小數(shù)點后的位數(shù)),再進行一次判斷決定是否加(減)一次被乘數(shù)。隨后將尾數(shù)結(jié)果輸出至下一個模塊。規(guī)格化模塊接收到上兩個模塊的階碼,尾數(shù)結(jié)果后進行溢出判斷,大小判斷,將規(guī)格化結(jié)果輸出,作為最終結(jié)果。</p><p><b> 2.4詳細(xì)設(shè)計</b></p><p> 2.4.1補碼一位乘法模塊設(shè)計</p><p> 設(shè)計思想:程序首先
55、進行判0操作,如果乘數(shù)中有一個或兩個為0,則直接輸出結(jié)果0,否則進入程序主體。程序主體分成三個判斷模塊進行,當(dāng)乘數(shù)最低位與次低位值相等時,先將乘數(shù)右移一位,再將原部分累加和右移一位至乘數(shù)最高位,同時部分積累加和的最高位根據(jù)次高位正負(fù)補0或1;如果乘數(shù)最低位與次低位分別為1,0時,將原部分累加和加上被乘數(shù)X補后,再右移一位至乘數(shù)最高位,同時部分積累加和的最高位根據(jù)次高位正負(fù)補0或1;如果乘數(shù)最低位與次低位分別為0,1時,將原部分累加和減去
56、被乘數(shù)X補后,再右移一位至乘數(shù)最高位,同時部分積累加和的最高位根據(jù)次高位正負(fù)補0或1。每次比較一次乘數(shù)的最末兩位,進行相應(yīng)運算后,共循環(huán)4次。循環(huán)結(jié)束后,再進行一次判斷,如果乘數(shù)最低位與次低位分別為1、0,將原部分累加和加上被乘數(shù)X補。如果乘數(shù)最低位與次低位分別為0、1,將原部分累加和減去被乘數(shù)X補。此時,最終累加和就是乘積的高位結(jié)果,取乘數(shù)的高四位作為低位結(jié)果,拼接即為最終乘法結(jié)果。</p><p><b
57、> 代碼如下:</b></p><p> module multiply(Mx,My,Mout);//補碼一位乘法模塊</p><p> input[5:0]Mx,My;//定義六位的尾數(shù)輸入,其中前兩位為符號位。</p><p> output reg[9:0]Mout;//定義九位的尾數(shù)輸出,其中前兩位為符號位。</p>
58、<p> reg[5:0] a;//a寄存器存放部分積累加和</p><p> reg[5:0] b,c;//b寄存器存放補碼表示的被乘數(shù),c寄存器存放補碼表示的乘數(shù)</p><p> reg[3:0] n;//n作為臨時變量,用來存放循環(huán)次數(shù)</p><p> reg p,q;//p用于負(fù)數(shù)移位補1操作,q用于存放添加的Cn+1</p
59、><p> always @ (Mx,My)</p><p><b> begin</b></p><p> if((Mx==0)||(My==0))</p><p><b> Mout=0;</b></p><p><b> else</b>&l
60、t;/p><p><b> begin </b></p><p> a=6'b000000; </p><p> n=4'b1111;</p><p><b> p=1'b1;</b></p><p><b> q=1'b0
61、;</b></p><p><b> b=Mx;</b></p><p><b> c=My;</b></p><p> c={c[4:0],q};</p><p><b> while(n)</b></p><p><b>
62、; begin</b></p><p><b> n=n>>1;</b></p><p> if(((c[0]==0)&&(c[1]==0))||((c[0]==1)&&(c[1]==1)))//如果Cn+1和Cn同為0或1,則只進行移位</p><p><b> beg
63、in</b></p><p><b> c=c/2;</b></p><p> c[5]=a[0];</p><p><b> a=a/2;</b></p><p> if(a[4]==1)</p><p> a={p,a[4:0]};</p>
64、;<p><b> else</b></p><p><b> a=a;</b></p><p><b> end</b></p><p> else if((c[0]==1)&&(c[1]==0))//如果Cn=0,Cn+1=1,則先加上被乘數(shù)的補碼,再移位&l
65、t;/p><p><b> begin</b></p><p><b> a=a+b;</b></p><p><b> c=c/2;</b></p><p> c[5]=a[0];</p><p><b> a=a/2;</b&g
66、t;</p><p> if(a[4]==1)</p><p> a={p,a[4:0]};</p><p><b> else</b></p><p><b> a=a;</b></p><p><b> end </b></p
67、><p> else if((c[0]==0)&&(c[1]==1))//如果Cn=1,Cn+1=0,則先減去被乘數(shù)的補碼,再移位</p><p><b> begin</b></p><p><b> a=a-b;</b></p><p><b> c=c/2;<
68、;/b></p><p> c[5]=a[0];</p><p><b> a=a/2;</b></p><p> if(a[4]==1)</p><p> a={p,a[4:0]};</p><p><b> else</b></p><
69、p><b> a=a;</b></p><p><b> end</b></p><p><b> end</b></p><p> //四次循環(huán)后,進行最后一步,此步不移位,用來處理符號位</p><p> if((c[0]==1)&&(c[1
70、]==0))</p><p><b> begin</b></p><p><b> a=a+b;</b></p><p><b> end</b></p><p> else if((c[0]==0)&&(c[1]==1))</p>&l
71、t;p><b> begin</b></p><p><b> a=a-b;</b></p><p><b> end</b></p><p> Mout={a,c[5:2]};</p><p><b> end </b></p>
72、;<p><b> end</b></p><p><b> endmodule</b></p><p> 2.4.2規(guī)格化模塊設(shè)計</p><p> 設(shè)計思想:當(dāng)雙符號位為00時,說明沒有產(chǎn)生溢出,原尾數(shù)為正值,此時若尾數(shù)最高位數(shù)值為0,說明其絕對值小于1/2,應(yīng)該進行左移規(guī)格化,尾數(shù)左移,階碼減1
73、。其他情況尾數(shù)和階碼均不改變,按原值輸出;</p><p> 當(dāng)雙符號位為01時,產(chǎn)生正溢,說明由于尾數(shù)最高位數(shù)值相加產(chǎn)生進位進而產(chǎn)生溢出,使得尾數(shù)絕對值大于1,應(yīng)該進行右移規(guī)格化,尾數(shù)右移1位,階碼加1。其他情況尾數(shù)和階碼均不改變,按原值輸出;</p><p> 當(dāng)雙符號位為11時,說明沒有產(chǎn)生溢出,原尾數(shù)為負(fù)值,此時若尾數(shù)最高位數(shù)值為1,說明其絕對值小于1/2,應(yīng)該進行左移規(guī)格化,
74、尾數(shù)左移,階碼減1。其他情況尾數(shù)和階碼均不改變,按原值輸出;</p><p> 當(dāng)雙符號位為10時,產(chǎn)生負(fù)溢,說明由于尾數(shù)最高位數(shù)值相加產(chǎn)生進位進而產(chǎn)生溢出,使得尾數(shù)絕對值大于1,應(yīng)該進行右移規(guī)格化,尾數(shù)右移1位,階碼加1.其他情況尾數(shù)和階碼均不改變,按原值輸出;</p><p> 其他雙符號位及尾數(shù)最高數(shù)值位情況下,不進行規(guī)格化,按原值進行輸出。</p><p&g
75、t;<b> 代碼如下:</b></p><p> module SPEC( EIn,MIn,EOut,MOut);</p><p> input [3:0] EIn; //規(guī)格化之前的階數(shù)</p><p> input [9:0] MIn; //規(guī)格化之前的尾數(shù)</p><p> output
76、 [3:0] EOut; //規(guī)格化之后的階數(shù)</p><p> output [9:0] MOut; //規(guī)格化之后的尾數(shù)</p><p> reg p;//臨時變量p,用于補充溢出處理補0操作。</p><p> reg q; /臨時變量q,用于補充溢出處理補1操作。</p><p> reg[3:0] t
77、mp1;//臨時變量tmp1,用于運算、存儲階碼</p><p> reg[9:0] tmp2;//臨時變量tmp2,用于運算、存儲尾數(shù)</p><p> always @ (EIn or MIn)</p><p><b> begin </b></p><p><b> p=1'b0;&l
78、t;/b></p><p> q=1'b1; </p><p> if(MIn[9:8]==2'b01)</p><p> //有正溢情況下應(yīng)右移,相應(yīng)階數(shù)加1</p><p><b> begin</b></p><p> tmp2={p,MIn[9
79、:1]};</p><p> tmp1=EIn+1;</p><p><b> end</b></p><p> else if(MIn[9:8]==2'b10)</p><p><b> begin</b></p><p> tmp2={q,MIn[9:1
80、]};</p><p> tmp1=EIn+1;</p><p><b> end</b></p><p> else if((MIn[9:8]==2'b00&&MIn[7]==0)||(MIn[9:8]==2'b11&&MIn[7]==1))</p><p> /
81、/無溢出情況下,若尾數(shù)絕對值小于1/2均應(yīng)左移,相應(yīng)階數(shù)減1</p><p><b> begin</b></p><p> tmp2={MIn[9:8],MIn[6:0],p};</p><p> tmp1=EIn-1;</p><p><b> end</b></p>&l
82、t;p><b> else</b></p><p><b> begin</b></p><p><b> tmp2=MIn;</b></p><p><b> tmp1=EIn;</b></p><p><b> end<
83、/b></p><p> //輸出最終結(jié)果的規(guī)格化后的尾數(shù)和階數(shù)</p><p><b> end</b></p><p> assign EOut=tmp1;</p><p> assign MOut=tmp2;</p><p><b> endmodule</b
84、></p><p> 2.4.3控制模塊及加法模塊設(shè)計</p><p> 2.4.3.1加法模塊設(shè)計</p><p> 設(shè)計思想:輸入兩個線網(wǎng)型變量的階碼,采用電平觸發(fā)的always語句相加后輸出結(jié)果。</p><p> module adder(EX,EY,EOUT);//加法模塊,實現(xiàn)階碼相加</p><
85、p> input [3:0] EX,EY;//輸入兩個階碼</p><p> output reg[3:0] EOUT;//輸出階碼</p><p> always @ (EX or EY or EOUT)</p><p> EOUT<=EX+EY;</p><p><b> endmodule</b&g
86、t;</p><p> 2.4.3.2控制模塊設(shè)計</p><p> 設(shè)計思想:將待進行乘法運算的兩個浮點數(shù)的尾數(shù)和階碼分別作為輸入(階底默認(rèn)為2),輸出運算結(jié)果的尾數(shù)與階碼。運算過程先后調(diào)用加法模塊計算階碼相加結(jié)果,乘法模塊計算尾數(shù)相乘結(jié)果,規(guī)格化模塊對前兩個模塊得到的結(jié)果進行規(guī)格化,最后輸出。</p><p><b> 代碼如下:</b&g
87、t;</p><p> module run(Mx,My,E_X,E_Y,M_out,E_out);//運行控制模塊</p><p> input [5:0] Mx,My;//六位浮點數(shù)尾數(shù)輸入,其中前兩位為符號位</p><p> input [3:0] E_X,E_Y;//四位無符號階碼輸入</p><p> output [9:
88、0] M_out;//十位尾數(shù)結(jié)果輸出,其中前兩位為符號位</p><p> output [3:0] E_out;//四位無符號階碼輸出</p><p> wire [3:0] E;//中間變量E,用于階碼加法模塊,輸出到規(guī)格化模塊</p><p> wire [9:0] M;//中間變量M,用于乘法模塊,輸出到規(guī)格化模塊</p><p&
89、gt; adder u1(.EX(E_X),.EY(E_Y),.EOUT(E));</p><p> multiply u2(.Mx(Mx),.My(My),.Mout(M));</p><p> SPEC u3(.EIn(E),.MIn(M),.EOut(E_out),.MOut(M_out));</p><p><b> endmodule&l
90、t;/b></p><p> 第三章 仿真測試</p><p><b> 3.1仿真測試環(huán)境</b></p><p> Mentor公司的ModelSim是業(yè)界最優(yōu)秀的HDL語言仿真軟件,它能提供友好的仿真環(huán)境,是業(yè)界唯一的單內(nèi)核支持VHDL和Verilog混合仿真的仿真器。它采用直接優(yōu)化的編譯技術(shù)、Tcl/Tk技術(shù)、和單一內(nèi)
91、核仿真技術(shù),編譯仿真速度快,編譯的代碼與平臺無關(guān),便于保護IP核,個性化的圖形界面和用戶接口,為用戶加快調(diào)錯提供強有力的手段,是FPGA/ASIC設(shè)計的首選仿真軟件。</p><p><b> 主要特點:</b></p><p> · RTL和門級優(yōu)化,本地編譯結(jié)構(gòu),編譯仿真速度快,跨平臺跨版本仿真;</p><p>
92、83; 單內(nèi)核VHDL和Verilog混合仿真;</p><p> · 源代碼模版和助手,項目管理;</p><p> · 集成了性能分析、波形比較、代碼覆蓋、數(shù)據(jù)流ChaseX、Signal Spy、虛擬對象Virtual Object、Memory窗口、Assertion窗口、源碼窗口顯示信號值、信號條件斷點等眾多調(diào)試功能;</p><p&g
93、t; · C和Tcl/Tk接口,C調(diào)試;</p><p> · 對SystemC的直接支持,和HDL任意混合;</p><p> · 支持SystemVerilog的設(shè)計功能;</p><p> · 對系統(tǒng)級描述語言的最全面支持,SystemVerilog,SystemC,PSL;</p><p&g
94、t; · ASIC Sign off。</p><p> 基于此,本設(shè)計采用ModelSim軟件對源代碼進行仿真測試,仿真步驟如下:</p><p> 1.啟動modelsim軟件</p><p> 先在磁盤中建立工作文件夾,在modelsim中選擇File -> Change Directory,在彈出的Choose folder對話框中
95、設(shè)置目錄路徑為工作文件夾路徑。</p><p><b> 2.建立工程</b></p><p> 在modelsim中建立project,選擇File ->New ->Project.</p><p> 在Project Name欄中填寫項目名字,建議和你的頂層文件名字一致。Project Location是工作目錄,可通過B
96、rose按鈕來選擇或改變。Ddfault Library Name可以采用工具默認(rèn)的work。Workspace窗口的library中就會出現(xiàn)work庫。 </p><p><b> 3.為工程添加文件</b></p><p> 工程建立后,選擇Add Exsiting File后,根據(jù)相應(yīng)提示將文件加到該Project中</p><p>
97、<b> 4.編譯文件</b></p><p> 編譯(包括源代碼和庫文件的編譯)。編譯可點擊ComlileComlile All來完成。 </p><p><b> 5.裝載文件</b></p><p> (1)雙擊libray 中work中的裝載測試代碼文件(例中為count_tp)</p>&l
98、t;p> (2)點擊simulate – start simulation</p><p><b> 設(shè)置好之后點擊ok</b></p><p><b> 6.開始仿真</b></p><p> 點擊workspace下的sim,點擊測試代碼文件(count_tp),選擇add add to wave<
99、;/p><p> 然后點run –all,開始仿真</p><p><b> 7.退出仿真</b></p><p> 在仿真調(diào)試完成后退出仿真,在主窗口中選擇simulate end simulation</p><p> 圖3-1 ModelSim測試環(huán)境使用界面</p><p><
100、b> 3.2模塊仿真測試</b></p><p> 3.2.1(補碼一位)乘法模塊仿真測試</p><p> module multiply_tp;</p><p> reg[5:0] Mx,My;//測試尾數(shù)輸入</p><p> wire[9:0] Mout;//測試尾數(shù)輸出</p><p&
101、gt; parameter DElY=100;//時延量定義</p><p> multiply test(Mx,My,Mout);</p><p><b> initial </b></p><p><b> begin</b></p><p> #DElY Mx=6'b110
102、011;My=6'b110101;</p><p> #DElY Mx=6'b001010;My=6'b000011;</p><p> #DElY Mx=6'b110011;My=6'b001001;</p><p> #DElY Mx=6'b001111;My=6'b111111;</p>
103、<p> #DElY $finish;</p><p><b> end</b></p><p><b> endmodule</b></p><p> 圖3-2 (補碼一位)乘法模塊編譯情況</p><p> 圖3-3(補碼一位)乘法模塊仿真波形圖</p>&
104、lt;p> 表3-1 (補碼一位)乘法模塊測試用例</p><p> 考慮測試的全面完整性,本測試將輸入的Mx(被乘數(shù)變量),My(乘數(shù)變量)依次設(shè)置為負(fù)數(shù)與負(fù)數(shù)、正數(shù)與正數(shù)、負(fù)數(shù)與正數(shù)、正數(shù)與負(fù)數(shù)。測試結(jié)果表明,結(jié)果正確,乘法模塊功能實現(xiàn)。</p><p> 3.2.2規(guī)格化模塊仿真測試</p><p> `timescale 1ns/1ns<
105、/p><p> module SPEC_tp;</p><p> reg[9:0] MIn; //測試尾數(shù)輸入</p><p> reg[3:0] EIn;//測試階碼輸入</p><p> wire[3:0] EOut; //測試階碼輸出</p><p> wire[9:0] MOut; //測試尾數(shù)輸出<
106、;/p><p> parameter DELY=100;//時延量定義</p><p> initial begin</p><p> EIn=4'd0;MIn=10'b0;</p><p> #DELY EIn =4'b0100; MIn =10'b0010101010;</p><p
107、> #DELY EIn =4'b1001; MIn =10'b0111010100; </p><p> #DELY EIn =4'b0110; MIn =10'b1000110100; </p><p> #DELY EIn =4'b0011; MIn =10'b1110011010;</p><p>
108、 #DELY $finish;</p><p><b> end</b></p><p> SPEC m(.EIn(EIn),.MIn(MIn),.EOut(EOut),.MOut(MOut));</p><p><b> endmodule</b></p><p> 圖3-4 規(guī)格化模塊編
109、譯情況</p><p> 圖3-5 規(guī)格化模塊仿真波形圖</p><p> 表3-2 規(guī)格化模塊測試用例</p><p> 本模塊分別輸入尾數(shù)符號為01,10的兩組數(shù)據(jù),測試規(guī)格化模塊對正溢情況的處理能力。此外輸入一組初始全零模塊測試規(guī)格化模塊對邊界情況的處理能力,以及一組不需要規(guī)格化操作的數(shù)據(jù),測試規(guī)格化模塊功能是否正常。仿真結(jié)果表明,本模塊功能正常實現(xiàn)。&
110、lt;/p><p> 3.2.3加法模塊仿真測試</p><p> module adder_tp;</p><p> reg [3:0] EX,EY;//測試階碼輸入</p><p> wire [3:0] EOUT;//測試階碼輸出</p><p> parameter DELY=100;//時延量定義<
111、;/p><p> adder a_t(EX,EY,EOUT);</p><p><b> initial</b></p><p><b> begin</b></p><p> EX=4’b0000;EY=4’b0000;</p><p> #DELY EX={$ran
112、dom}%16;EY={$random}%16;</p><p> #DELY EX={$random}%16;EY={$random}%16;</p><p> #DELY EX={$random}%16;EY={$random}%16;</p><p> #DELY $finish;</p><p><b> end&l
113、t;/b></p><p><b> endmodule</b></p><p> 圖3-6 (階碼)加法模塊編譯情況</p><p> 圖3-7 (階碼)加法模塊仿真波形圖</p><p> 表3-3 (階碼)加法模塊測試用例</p><p> 本測試調(diào)用系統(tǒng)函數(shù),產(chǎn)生四組隨機輸
114、入,保證測試的可靠性。仿真結(jié)果表明,本模塊功能正常實現(xiàn)。</p><p> 3.3總測試(控制模塊測試)</p><p> module run_tp;</p><p> reg [5:0] Mx,My;//測試浮點數(shù)尾數(shù)輸入</p><p> reg [3:0] E_X,E_Y;//測試浮點數(shù)階碼輸入</p><
115、p> wire [9:0] M_out;//測試浮點數(shù)尾數(shù)輸出</p><p> wire [3:0] E_out;//測試浮點數(shù)階碼輸出</p><p> parameter DElY=100;//時延量定義</p><p> run floatx(Mx,My,E_X,E_Y,M_out,E_out);</p><p><
116、;b> initial </b></p><p><b> begin</b></p><p> #DElY Mx=6'b110011;My=6'b110101;E_X =4'b0100;E_Y =4'b0110; </p><p> #DElY Mx=6'b001010;My
117、=6'b001011;E_X =4'b0001;E_Y =4'b0101; </p><p> #DElY Mx=6'b110011;My=6'b001001;E_X =4'b0010;E_Y =4'b0100; </p><p> #DElY Mx=6'b001111;My=6'b110111;E_X =4&
118、#39;b0110;E_Y =4'b1000; </p><p> #DElY $finish;</p><p><b> end</b></p><p><b> endmodule</b></p><p> 圖3-8 控制模塊編譯情況</p><p>
119、圖3-9 控制模塊仿真波形圖</p><p> 圖3-10 總測試數(shù)據(jù)流圖</p><p> 表3-4 控制模塊(總模塊)測試用例</p><p> 本模塊測試輸入的被乘數(shù)與乘數(shù)分別為負(fù)數(shù)與負(fù)數(shù),正數(shù)與正數(shù),負(fù)數(shù)與正數(shù),正數(shù)與負(fù)數(shù),涵蓋四種乘數(shù)可能性。仿真結(jié)果表明,本浮點乘法運算器設(shè)計功能成功實現(xiàn)!</p><p> 第四章 總
120、結(jié)與展望</p><p> 4.1問題及解決方案總結(jié)</p><p> 4.1.1乘法模塊編寫問題</p><p> 編寫問題:這個模塊編寫的主要問題集中在兩點,一個是變量賦值問題,一個是運算符使用問題。</p><p> ?。?)變量賦值部分,由于變量某些位數(shù)有特殊用途,最開始我們使用的是逐位賦值來給特定位賦值,導(dǎo)致代碼臃腫,可讀性較
121、差。后來經(jīng)過對verilog語法的仔細(xì)分析,我們該用位拼接運算符,有效地解決了這個問題。</p><p> ?。?)運算符使用問題是一個細(xì)節(jié)性問題,在進行或運算時,我們在需要使用按位或運算符的地方不慎使用了一個邏輯或運算符,導(dǎo)致仿真結(jié)果一直不對。在沒有找到問題所在的情況下,我們先后采用了單步仿真(將循環(huán)次數(shù)設(shè)置為1)和單句仿真(只保留一句功能語句)的方法,找到了問題之所在,解決了這個難題。</p>
122、<p> 4.1.2規(guī)格化模塊編寫問題</p><p> 編寫問題:這個模塊編寫的主要問題是對溢出情況的處理問題。最開始我們的設(shè)計只考慮到尾數(shù)大小的規(guī)格化,所以本模塊測試時沒有問題,但是總體測試時就有結(jié)果異常的情況發(fā)生。經(jīng)過仔細(xì)地分析,我們認(rèn)為乘法運算結(jié)束后,可能有數(shù)值位溢出到了符號位的低位,所以規(guī)格化模塊應(yīng)該對溢出情況做判斷處理。加入這個判斷模塊后,本模塊功能得到了完善。</p>&
123、lt;p><b> 4.2結(jié)論及展望</b></p><p> 本次課程設(shè)計,通過使用硬件描述語言編寫硬件程序,并進行仿真測試,我們證實,基于補碼一位乘法的浮點乘法運算原理是正確的。</p><p> 在本次課程設(shè)計中,我們收獲了很多,具體集中在以下幾點:</p><p> 即使編寫代碼的整個邏輯是很清晰的,但是實際中要編寫一段能
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)電課程設(shè)計報告---運算器
- 基于fpga的浮點運算器設(shè)計
- 基于fpga的浮點運算器設(shè)計
- 課程設(shè)計--設(shè)計一個矩陣運算器
- 基于cpld的64位乘法運算器的設(shè)計
- 基于FPGA的浮點運算器設(shè)計.pdf
- 課程設(shè)計---稀疏矩陣加法運算器
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計報告--稀疏矩陣運算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告--稀疏矩陣運算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 稀疏矩陣運算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 稀疏矩陣運算器設(shè)計
- eda課程設(shè)計--2位十進制四則運算器電路四則運算器
- 課程設(shè)計-單片機課程設(shè)計論文-4位數(shù)加法運算器的設(shè)計
- 基于FPGA浮點運算器的研究.pdf
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--稀疏矩陣運算器
- eda課程設(shè)計之2位十進制四則運算器電路四則運算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--基本稀疏矩陣運算的運算器
- 基于參數(shù)化IP核的浮點運算器設(shè)計.pdf
- eda課程設(shè)計--2位十進制四則運算器電路
- 數(shù)字邏輯課程設(shè)計---基于fpga的簡單運算器
評論
0/150
提交評論