掃描二維碼
隨時(shí)隨地手機(jī)看文章
1 引 言
發(fā)射光譜層析(EST)技術(shù)是一種不干擾原待測(cè)場(chǎng)分布的測(cè)量診斷技術(shù),他在熱物理量測(cè)試、等離子體診斷等方面顯示出了極大的優(yōu)越性,尤其是在場(chǎng)分布測(cè)量方面,幾乎是其他方法不可替代的,是測(cè)量三維流場(chǎng)內(nèi)部物理量分布的一種常用方法。
傳統(tǒng)的層析重建技術(shù),通常是利用軟件編程在計(jì)算機(jī)上直接完成,這要花費(fèi)很長(zhǎng)的時(shí)間,無(wú)法滿足實(shí)時(shí)重建時(shí)對(duì)速度的要求,現(xiàn)在已有研究者開(kāi)始著手研究在硬件(例如FPGA和DSP)上來(lái)實(shí)現(xiàn)層析重建技術(shù),例如:在FPGA上實(shí)現(xiàn)ART算法。但是,由于ART算法在重建圖像時(shí)對(duì)噪聲的抑制能力較差,迭代格式復(fù)雜,且有除法運(yùn)算,用FPGA實(shí)現(xiàn)起來(lái)較為復(fù)雜。同時(shí)迭代重建算法--SIRT能夠有效抑制測(cè)量誤差的影響,迭代格式簡(jiǎn)單,得到廣泛應(yīng)用,但該法用FPGA(現(xiàn)場(chǎng)可編程邏輯門陣列)來(lái)實(shí)現(xiàn)時(shí),牽涉到小數(shù)運(yùn)算問(wèn)題。因?yàn)樵贔PGA中數(shù)據(jù)都是以二進(jìn)制形式參與存儲(chǔ)、運(yùn)算的,小數(shù)計(jì)算問(wèn)題是FPGA應(yīng)用中的一大難點(diǎn),目前業(yè)界用FPGA來(lái)處理小數(shù)大都采用定點(diǎn)處理,這種方法行之有效,但應(yīng)用范圍很有限,對(duì)于在層析重建中的小數(shù),采用定點(diǎn)運(yùn)算是無(wú)法處理的。
本文提出一種處理小數(shù)的方法,即把將要參與運(yùn)算的數(shù)據(jù)轉(zhuǎn)化為IEEE標(biāo)準(zhǔn)754的二進(jìn)制單精度浮點(diǎn)數(shù),然后調(diào)用Altera開(kāi)放的浮點(diǎn)數(shù)運(yùn)算IP核對(duì)數(shù)據(jù)進(jìn)行運(yùn)算,Altera提供的IP核是Altera公司經(jīng)過(guò)嚴(yán)格測(cè)試和優(yōu)化過(guò)的電路功能模塊,在設(shè)計(jì)項(xiàng)目時(shí)調(diào)用IP核既減少了設(shè)計(jì)中的工作量,又在一定程度上節(jié)省了芯片資源,為迭代層析實(shí)時(shí)重建提供了可能。SIRT算法較ART算法迭代格式簡(jiǎn)單,且更易減小重建誤差,提高重建速度,更適用于實(shí)時(shí)重建。FPGA在設(shè)計(jì)時(shí)采用Verilog編程和調(diào)用Altera的開(kāi)放IP核相結(jié)合的方法來(lái)實(shí)現(xiàn),軟件設(shè)計(jì)和綜合模擬仿真在QuartusⅡ5.1開(kāi)發(fā)平臺(tái)中完成,最后給出了一些模塊仿真的波形。
2 SIRT算法
SIRT算法的迭代格式為:
4小數(shù)的預(yù)處理
IP核來(lái)計(jì)算數(shù)據(jù)時(shí),輸入數(shù)據(jù)和輸出數(shù)據(jù)都應(yīng)為IEEE標(biāo)準(zhǔn)754的二進(jìn)制單精度浮點(diǎn)數(shù),這樣就要求在進(jìn)行浮點(diǎn)數(shù)運(yùn)算之前,先要對(duì)數(shù)據(jù)進(jìn)行處理使測(cè)量值P和投影矩陣W的值轉(zhuǎn)化為IEEE標(biāo)準(zhǔn)的二進(jìn)制浮點(diǎn)數(shù)。
預(yù)處理步驟如下:
(1)對(duì)于測(cè)量數(shù)據(jù)P,他是由CCD采集并經(jīng)10位A/D轉(zhuǎn)換,使測(cè)量數(shù)據(jù)轉(zhuǎn)換為10位二進(jìn)制整數(shù),然后經(jīng)過(guò)數(shù)據(jù)預(yù)處理模塊,把數(shù)據(jù)處理轉(zhuǎn)化為IEEE標(biāo)準(zhǔn)754的二進(jìn)制單精度浮點(diǎn)數(shù),輸入到外部寄存器P等待調(diào)用。
(2)對(duì)于投影矩陣W,如果圖像大小一定,則投影矩陣W也是固定的,可先由Matlab仿真生成并處理轉(zhuǎn)化為IEEE標(biāo)準(zhǔn)754的二進(jìn)制單精度浮點(diǎn)數(shù),然后存到W寄存器,等待調(diào)用。
在此只討論由FPGA處理的部分,即只討論對(duì)測(cè)量數(shù)據(jù)P的預(yù)處理,而對(duì)于W矩陣的值則可由Matlab編程處理完成,在此不再贅述。
流程圖如圖2所示。
![]() |
5.1預(yù)處理P的模塊
測(cè)量數(shù)據(jù)P為二進(jìn)制整數(shù),將其轉(zhuǎn)化為IEEE標(biāo)準(zhǔn)754形式,只需要先對(duì)數(shù)據(jù)進(jìn)行檢測(cè),若數(shù)據(jù)為正則符號(hào)位S=0,否則S=1;然后找出為"1"的最高位,設(shè)為"1"的最高位為第L位,則保留P[L-1:0]作為IEEE標(biāo)準(zhǔn)754的尾數(shù)M的高位,然后在其后補(bǔ)"0"至23位,即得尾數(shù)M;而L的值即為指數(shù)e,則E=e+127。假設(shè)P[9:0]=0001011011,則為"1"的最高位為P[6],保留P[5:0]作為尾數(shù)M[22:0]的高位,然后在后面補(bǔ)"0",即得尾數(shù)M,在此M=01101100000000000000000,而指數(shù)e為6,則E[7:0]的大小為E=e+127,在此即為133,即為二進(jìn)制的10000101,此處為S=0,則P轉(zhuǎn)化后的值為Pout[31:0]=01000010101101100000000000000000,仿真結(jié)果如圖3所示。
顯然仿真結(jié)果是正確的。
按照IEEE標(biāo)準(zhǔn)754形式,把測(cè)量所得數(shù)據(jù)P和投影矩陣W的值預(yù)處理轉(zhuǎn)化為IEEE標(biāo)準(zhǔn)754形式以后,即可進(jìn)行運(yùn)算。
![]() |
![]() |
5.3 浮點(diǎn)乘法器的實(shí)現(xiàn)
兩浮點(diǎn)數(shù)相乘,設(shè)兩數(shù)均為01000000011000000000000000000000,即為十進(jìn)制的3.5,調(diào)用浮點(diǎn)數(shù)乘法IP核,進(jìn)行仿真。仿真結(jié)果如圖5所示。
由仿真波形圖可見(jiàn)兩數(shù)相乘結(jié)果為01000001010001000000000000000000,為十進(jìn)制數(shù)的12.25,即結(jié)果是正確的。
![]() |
FPGA的應(yīng)用領(lǐng)域包羅萬(wàn)象,我們今天來(lái)看看在音樂(lè)科技領(lǐng)域及醫(yī)療照護(hù)的智能巧思。
關(guān)鍵字: FPGA 科技領(lǐng)域 智能強(qiáng)大的產(chǎn)品可降低信號(hào)噪音并提高分辨率與動(dòng)態(tài)
關(guān)鍵字: Spectrum儀器 數(shù)字化儀 FPGA計(jì)算機(jī)網(wǎng)絡(luò)編程中一個(gè)非?;镜膯?wèn)題:該怎樣表示client與server之間交互的數(shù)據(jù),在往下看之前先想一想這個(gè)問(wèn)題。
關(guān)鍵字: 計(jì)算機(jī) 二進(jìn)制本篇是FPGA之旅設(shè)計(jì)的第十二例,在前面的例程中,完成了DS18B20溫度傳感器數(shù)據(jù)的采集,并且將采集到的數(shù)據(jù)顯示在數(shù)碼管上。由于本例將對(duì)溫濕度傳感器DHT11進(jìn)行采集,而且兩者的數(shù)據(jù)采集過(guò)程類似,所以可以參考一下前面的...
關(guān)鍵字: FPGA DS18B20溫度傳感器第八例啦,本例將介紹如何通過(guò)FPGA采集DS18B20傳感器的溫度值。
關(guān)鍵字: FPGA DS18B20傳感器