版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 計(jì)算機(jī)課程設(shè)計(jì)論文</b></p><p> 題 目: 基于FPGA的漏磁檢測(cè)電路設(shè)計(jì)</p><p> 學(xué) 院: 測(cè)試與光電工程學(xué)院 </p><p> 專業(yè)名稱: 電子科學(xué)與技術(shù)</p><p>
2、班級(jí)學(xué)號(hào): </p><p> 學(xué)生姓名: </p><p> 指導(dǎo)教師: </p><p><b> 二零一二年六月 </b></p><p> 基于FPGA漏磁檢測(cè)電路設(shè)計(jì)</
3、p><p> 摘要: 鐵磁材料缺陷的漏磁檢測(cè)是一種有效的無(wú)損檢測(cè)技術(shù),能夠在不影響和破壞材料的屬性的情況下,完成對(duì)設(shè)備和材料存在的缺陷檢測(cè)。它在提高生產(chǎn)安全性、防止事故的發(fā)生、減小經(jīng)濟(jì)損失中發(fā)揮非常重要的作用。傳統(tǒng)的集成電路設(shè)計(jì)中,傳感器的控制通常由MCU(以C51單片機(jī)為代表)來(lái)完成。以往的傳感器,其精度比較低,采樣周期較長(zhǎng),MCU尚且可以勝任。但是隨著對(duì)檢測(cè)速度、精度的要求越來(lái)越高,檢測(cè)過(guò)程會(huì)產(chǎn)生非常大的數(shù)據(jù),
4、處理和保存這些數(shù)據(jù)就超出了MCU的能力,因此很有必要對(duì)檢測(cè)技術(shù)進(jìn)行改進(jìn)。</p><p> FPGA(Field-Programmable Gate Array現(xiàn)場(chǎng)可編程門(mén)陣列)具有高速、高集成度和在線可編程等優(yōu)點(diǎn),在設(shè)計(jì)過(guò)程中具有極大的靈活性和可靠性,本設(shè)計(jì)中采用Altera 公司的Cyclone ii系列EP2C5T144C8N。</p><p> 本次設(shè)計(jì)根據(jù)漏磁檢測(cè)原理,設(shè)計(jì)了
5、基于FPGA的漏磁檢測(cè)硬件電路控制模塊,克服傳統(tǒng)的以MCU作為控制器帶來(lái)的采樣速度和效率上的瓶頸。這些模塊主要包括磁場(chǎng)信號(hào)采集、通道選擇、模數(shù)轉(zhuǎn)換、串口通信等4個(gè)模塊。其中磁場(chǎng)信號(hào)采集利用霍爾傳感器UGN3503,通道選擇用CD4052BE實(shí)現(xiàn),模數(shù)轉(zhuǎn)換用ADC0809實(shí)現(xiàn);串口通信模塊實(shí)現(xiàn)FPGA與PC機(jī)通信。在設(shè)計(jì)過(guò)程中,用VHDL語(yǔ)言來(lái)編寫(xiě)總體控制部分實(shí)現(xiàn)對(duì)各模塊的控制,包括控制通道選擇的地址信號(hào)、控制模數(shù)轉(zhuǎn)換的開(kāi)始與停止及控制F
6、PGA的串口發(fā)送。從QUARTUS II軟件仿真結(jié)果可以看出,F(xiàn)PGA作為總體控制模塊,能夠?qū)崿F(xiàn)數(shù)據(jù)的實(shí)時(shí)采集,體現(xiàn)了其對(duì)外圍電路的良好控制性。從調(diào)試結(jié)果可以得出,基于FPGA的漏磁檢測(cè)系統(tǒng)及控制具備相當(dāng)?shù)目尚行约皩?shí)用性。</p><p> 關(guān)鍵字:漏磁檢測(cè) FPGA 信號(hào)采集 串口通信</p><p><b> 目 錄</b></p&g
7、t;<p><b> 1 引言3</b></p><p> 2 系統(tǒng)的軟件設(shè)計(jì)3</p><p> 2.1 設(shè)計(jì)平臺(tái)Quartus II4</p><p> 2.2 通道選擇控制模塊4</p><p> 2.3 A/D轉(zhuǎn)換控制模塊5</p><p>
8、 2.4 串口通信模塊6</p><p> 2.5 分頻與倍頻模塊8</p><p> 3 仿真與調(diào)試9</p><p> 3.1 FPGA調(diào)試簡(jiǎn)介9</p><p> 3.2 通道選擇控制模塊仿真及調(diào)試9</p><p> 3.3 A/D轉(zhuǎn)換控制模塊仿真及調(diào)試10</p>
9、;<p> 3.4 串口通信模塊仿真及調(diào)試11</p><p> 3.5 頂層設(shè)計(jì)仿真及調(diào)試12</p><p> 4 設(shè)計(jì)結(jié)果與總結(jié)13</p><p> 4.1 結(jié)果與總結(jié)13</p><p><b> 參考文獻(xiàn)14</b></p><p><
10、b> 致謝14</b></p><p><b> 1.引言</b></p><p> 管道作為一種經(jīng)濟(jì)、高效而安全的物料傳輸手段,在石油化工及天然氣等產(chǎn)業(yè)中具有不可替代的作用。但鐵磁性油氣輸送管道因長(zhǎng)時(shí)間的腐蝕、磨損及意外的機(jī)械損傷等原因會(huì)形成機(jī)械裂紋和腐蝕穿孔等各種缺陷。如果不能及時(shí)發(fā)現(xiàn)、修理這些缺陷,將導(dǎo)致輸送效率降低、輸送介質(zhì)泄露等惡性
11、事故。因此研究高效、經(jīng)濟(jì)可行的管道長(zhǎng)距離無(wú)損檢測(cè)技術(shù)及研發(fā)高精度在線管道漏磁檢測(cè)系統(tǒng)具有極大的現(xiàn)實(shí)意義和經(jīng)濟(jì)效益。 </p><p> 管道檢測(cè)技術(shù)的研究已有近四十年歷史,它是一個(gè)涉及多學(xué)科領(lǐng)域的研究項(xiàng)目,具有大量的理論研究問(wèn)題和大量的工程技術(shù)問(wèn)題。六十年代初,美英率先將無(wú)損檢測(cè)技術(shù)(NDT)應(yīng)用于清管器(PIG)上,將原來(lái)用于清管作業(yè)的PIG改進(jìn)為具有信息采集、處理、存儲(chǔ)等功能的智能檢測(cè)PIG。隨后,各國(guó)
12、先后研制出漏磁型、超聲型、渦流型的智能檢測(cè)PIG。目前應(yīng)用于管道無(wú)損檢測(cè)的方法包括有超聲檢測(cè)、射線檢測(cè)、渦流檢測(cè)、漏磁檢測(cè)及滲透檢測(cè),這五種方法就是人們常說(shuō)的五大常規(guī)無(wú)損檢測(cè)技術(shù)。除此以外,還包括有微波檢測(cè)技術(shù)、激光檢測(cè)技術(shù)、紅外檢測(cè)技術(shù)等非常規(guī)檢測(cè)手段,在這些方法中漏磁檢測(cè)技術(shù)是應(yīng)用最廣泛、技術(shù)最成熟的鐵磁性管道缺陷檢測(cè)技術(shù),它適于多種傳輸介質(zhì),對(duì)鐵損失等最常見(jiàn)的管道缺陷有非常好的檢測(cè)效果。</p><p>&
13、lt;b> 2 系統(tǒng)的軟件設(shè)計(jì)</b></p><p> 2.1 設(shè)計(jì)平臺(tái)Quartus II</p><p> FPGA中軟件設(shè)計(jì)的平臺(tái)是Altera公司的Quartus II開(kāi)發(fā)系統(tǒng),Quartus II是綜合性的PLD開(kāi)發(fā)軟件,支持原理圖,各種硬件描述語(yǔ)言以及多種設(shè)計(jì)輸入形式,自身帶有綜合器和仿真器,可以完成從硬件設(shè)計(jì),軟件設(shè)計(jì),仿真到硬件配置的完整設(shè)計(jì)流程。
14、Quartus II同時(shí)支持Altera公司的IP核,包含了各種宏功能模塊庫(kù),使用戶可以直接利用已經(jīng)經(jīng)過(guò)編譯的成熟模塊,如本設(shè)計(jì)中用到的雙口RAM模塊,簡(jiǎn)化了設(shè)計(jì)中的復(fù)雜性,并且可以縮短設(shè)計(jì)的周期。Quartus II的設(shè)計(jì)輸入方法有很多種,可以靈活的運(yùn)用,主要方法有三種,簡(jiǎn)要介紹如下:第一種方法就是原理圖輸入法,這種方法是最為直接的方法,由用Quartus II提供的各種原理圖庫(kù)進(jìn)行設(shè)計(jì)輸入。為提高效率,采用這種方法輸入的時(shí)候應(yīng)采用自
15、頂向下邏輯分塊,即把大規(guī)模的電路劃分成若干小塊的方法。一般如果對(duì)系統(tǒng)了解很深,并且系統(tǒng)速率的要求較高,或這系統(tǒng)中如果時(shí)間特性要求較高,就可以采用這種方法。原理圖輸入的缺點(diǎn)雖然仿真容易但是效率很低,但是這樣的方法便于信號(hào)觀察以及電路的調(diào)整,看起來(lái)也很直觀。第二種方法就是硬件描述語(yǔ)言輸入:Quartus II</p><p> 2.2通道選擇控制模塊</p><p> 本次設(shè)計(jì)的漏磁檢測(cè)系
16、統(tǒng)在實(shí)際應(yīng)用時(shí)運(yùn)用到的傳感器量很大,管道軸向和徑向一般都要放置傳感器。比如說(shuō)100個(gè)傳感器的話我們就可以用8個(gè)十六選一和1個(gè)八選一的數(shù)據(jù)選擇器,這樣就需要通道選擇控制信號(hào)去與這些芯片的地址信號(hào)相連,從而選中100個(gè)傳感器。但是考慮到實(shí)驗(yàn)室條件和成本,我只用了四個(gè)霍爾傳感器,但還是需要通道選擇控制模塊去選中傳感器。系統(tǒng)每隔0.2ms采樣一個(gè)傳感器,所以通道選擇模塊輸出的地址信號(hào)的周期為0.2ms(頻率為5khz)。而系統(tǒng)用到的EP2C5T
17、144C8芯片的系統(tǒng)時(shí)鐘為50Mhz,因此需要系統(tǒng)將時(shí)鐘分頻處理。最終得到了實(shí)現(xiàn)目標(biāo)要求的代碼。部分代碼如下所示:</p><p> --designed by G_XW the address block</p><p> entity address is </p><p><b> port(</b></p>&l
18、t;p> clk:in std_logic;</p><p> address_signal:out std_logic_vector(1 downto 0));</p><p><b> end ;</b></p><p> architecture one of address is </p><p>
19、<b> begin</b></p><p> process(clk)</p><p> variable q :integer range 0 to 3;</p><p><b> begin</b></p><p> if clk'event and clk='1
20、39; then </p><p> if(q=3) then </p><p><b> q:=0;</b></p><p> else q:=q+1;</p><p><b> end if;</b></p><p><b> end if;</
21、b></p><p> address_signal<=conv_std_logic_vector(q,2);</p><p> end process;</p><p> 2.3 A/D轉(zhuǎn)換控制模塊</p><p> ADC0809采樣原理比較簡(jiǎn)單:首先我們給START一個(gè)有效的上升沿使0809復(fù)位,接著給它一個(gè)下降沿,
22、隨后狀態(tài)信號(hào)EOC隨即變成低電平。此時(shí)、進(jìn)入轉(zhuǎn)換狀態(tài),周期約為100µs。轉(zhuǎn)換結(jié)束后,EOC變?yōu)楦唠娖剑甘続/D轉(zhuǎn)換結(jié)束,結(jié)果數(shù)據(jù)已存入鎖存器,此時(shí)外部可以控制OE由低電平變?yōu)楦唠娖?,進(jìn)入有效輸出階段。下圖是ADC0809的采樣狀態(tài)圖。</p><p> 圖3.1 ADC0809采樣狀態(tài)圖</p><p> 由狀態(tài)圖我們可以發(fā)現(xiàn),運(yùn)用狀態(tài)機(jī)來(lái)控制ADC0809模塊無(wú)疑是最佳
23、選擇。其核心代碼如下:</p><p> --designed by G_XW</p><p> CASE current_state IS</p><p> WHEN st0=>ALE<='0';START<='0';LOCK<='1';OE<='0';next_s
24、tate<=st1; </p><p> WHEN st1=>ALE<='1';START<='1';LOCK<='1';OE<='0';next_state<=st2; </p><p> WHEN st2=>ALE<='0';START<=
25、39;0';LOCK<='0';OE<='0';</p><p> IF (EOC='1') THEN next_state<=st3; </p><p> ELSE next_state<=st2; </p><p><b> END IF;</b>&l
26、t;/p><p> WHEN st3=>ALE<='0';START<='0';LOCK<='0';OE<='1';next_state<=st4; </p><p> WHEN st4=>ALE<='0';START<='0';LOCK&l
27、t;='1';OE<='1';next_state<=st0; </p><p> WHEN OTHERS=>next_state<=st0;</p><p><b> END CASE;</b></p><p> END PROCESS COM;</p><p&
28、gt; REG: PROCESS(CLK)</p><p><b> BEGIN</b></p><p> IF(CLK'EVENT AND CLK='1') THEN current_state<=next_state;</p><p><b> END IF;</b></p&
29、gt;<p> END PROCESS REG;</p><p> LATCH1: PROCESS(LOCK) </p><p><b> BEGIN</b></p><p> IF LOCK='1' AND LOCK'EVENT THEN DOUT<=REG_0;</p>&l
30、t;p><b> END IF;</b></p><p> END PROCESS LATCH1;</p><p> END behav;</p><p> 由于ADC0809采用通用串口通信方式。此種通信方式比較簡(jiǎn)單,并且 FPGA的IO口也支持此種通信協(xié)議。因此ADC0809在與FPGA通信時(shí),無(wú)需再對(duì)IO口進(jìn)行編程,它的數(shù)據(jù)
31、總線可以直接與FPGA的IO口連接,進(jìn)行數(shù)據(jù)交換。</p><p><b> 2.4串口通信模塊</b></p><p> 異步串行通信要求的傳輸線少,可靠性高,傳輸距離遠(yuǎn),被廣泛應(yīng)用于微機(jī)和外設(shè)的數(shù)據(jù)交換。實(shí)現(xiàn)串口通信主要需要完成兩部分工作:將串口電平轉(zhuǎn)換為設(shè)備電路板的工作電平,即實(shí)現(xiàn)RS-232電平和TTL/CMOS電平的轉(zhuǎn)換;接收并且檢驗(yàn)串行的數(shù)據(jù),將數(shù)據(jù)變
32、成并行的并提供給處理器處理。</p><p> 實(shí)現(xiàn)RS-232電平和TTL/CMOS電平轉(zhuǎn)換可以用接口芯片來(lái)實(shí)現(xiàn),實(shí)現(xiàn)數(shù)據(jù)的串行到并行轉(zhuǎn)換用的是UART,它們是實(shí)現(xiàn)串行通信必不可少的兩個(gè)部分。雖然目前大部分處理器芯片中都集成了UART,但是一般FPGA芯片卻沒(méi)有這個(gè)特點(diǎn),所以使用FPGA作為處理器可以有兩個(gè)選擇,第一個(gè)選擇是使用UART芯片進(jìn)行串并轉(zhuǎn)換,第二個(gè)選擇是在FPGA內(nèi)部實(shí)現(xiàn)UART功能。</p
33、><p> 異步串行通訊是一幀一幀進(jìn)行傳輸,幀與幀之間的間隙不固定,間隙處用空閑位(高電平)填補(bǔ),每幀傳輸總是以邏輯"(低電平)狀態(tài)的起始位開(kāi)始,停止位結(jié)束。信息傳輸可隨時(shí)地或間斷地進(jìn)行,不受時(shí)間的限制。因此,異步通訊簡(jiǎn)單、靈活,對(duì)同步時(shí)鐘要求可低些。異步通訊方式規(guī)定了傳輸格式,都以相同的幀格式傳送。每幀信息由起始位、數(shù)據(jù)位、奇偶校驗(yàn)位和停止位組成。幀與幀之間用高電平分開(kāi)。根據(jù)串行通信的協(xié)議,發(fā)送串行數(shù)據(jù)
34、一般是:1個(gè)起始位,1個(gè)數(shù)據(jù)位,1個(gè)或多個(gè)停止位,這樣,發(fā)送起始位以后表明傳輸開(kāi)始。傳送與接受的雙方設(shè)定好同樣的傳輸位數(shù),直到1個(gè)數(shù)據(jù)位送完以后,送停止位。此時(shí)我們便可以開(kāi)始針對(duì)FPGA和上位機(jī)進(jìn)行編程。</p><p><b> 部分代碼如下所示:</b></p><p> --designed by G_XW</p><p> arc
35、hitecture behavior of transfer is</p><p> type state_type is (xidle,xstart,xwait,xshift); --狀態(tài)機(jī)</p><p> signal state : state_type:=xidle;</p><p> signal txds : st
36、d_logic; </p><p> signal tx_reg:std_logic_vector(9 downto 0); --輸出數(shù)據(jù)</p><p><b> begin</b></p><p> --tx_reg<='1'& txbuf & '0
37、';</p><p> tx_reg<="1011110010";</p><p> process(bclk,reset,w_en,txbuf)</p><p> variable cnt16:integer range 0 to 3:=0; --計(jì)數(shù)器,用來(lái)發(fā)送</p><
38、;p> variable bitcnt: integer range 0 to 9 :=0; --控制發(fā)送位數(shù)</p><p><b> begin</b></p><p> if rising_edge(bclk) then</p><p> if reset='0' then<
39、/p><p> state<=xidle; --異步初始化,狀態(tài)機(jī)設(shè)置為空閑狀態(tài)</p><p> txds<='1'; --輸出初始化是1</p><p><b> else </b></p><p&
40、gt; case state is</p><p> when xidle =></p><p> if w_en='1' then --開(kāi)始發(fā)送信號(hào)觸發(fā)</p><p> state<=xstart; --跳轉(zhuǎn)到發(fā)送初始位狀態(tài)</p>
41、<p><b> else </b></p><p> state<=xidle;</p><p><b> end if;</b></p><p> when xstart =></p><p> if cnt16=2 then --計(jì)數(shù)
42、器到16就狀態(tài)跳轉(zhuǎn)到輸出狀態(tài)</p><p> state<=xshift;</p><p><b> cnt16:=0;</b></p><p><b> else</b></p><p> cnt16:=cnt16+1;</p><p> state<
43、;=xstart;</p><p><b> end if;</b></p><p> txds<='0'; --開(kāi)始位輸出</p><p> when xwait=> </p><p> i
44、f cnt16 =3 then --計(jì)數(shù)器計(jì)數(shù)到15跳轉(zhuǎn)到下一狀態(tài)</p><p> if bitcnt=10 then --如果輸出8位完成,就轉(zhuǎn)到結(jié)束傳輸狀態(tài)</p><p> state<=xidle;</p><p> bitcnt:=0;</p><p><b> cnt16:
45、=0;</b></p><p><b> else</b></p><p> state<=xshift; --如果還沒(méi)有輸出8位,那么跳轉(zhuǎn)到輸出狀態(tài)</p><p><b> end if;</b></p><p> cnt16 :=0;</p><p
46、><b> else </b></p><p> cnt16:=cnt16+1;</p><p> state<=xwait;</p><p><b> end if;</b></p><p> when xshift=></p><p> tx
47、ds<=tx_reg(bitcnt); bitcnt:=bitcnt+1; --輸出數(shù)據(jù)位的序號(hào)自動(dòng)加1</p><p> state<=xwait; --轉(zhuǎn)到保持?jǐn)?shù)據(jù)的狀態(tài)</p><p> when oth
48、ers => --容錯(cuò)設(shè)計(jì),其他情況一律跳轉(zhuǎn)到空閑狀態(tài)</p><p> state<=xidle;</p><p><b> end case;</b></p><p><b> end if;</b></p><p><b> end if;&
49、lt;/b></p><p> txd<=txds; --輸出數(shù)據(jù)</p><p> end process;</p><p> end behavior;</p><p><b> 2.5分頻模塊</b></p><p&
50、gt; 前面所介紹的通道選擇控制、A/D轉(zhuǎn)換控制、串口通信模塊所需的時(shí)鐘都需要將系統(tǒng)時(shí)鐘50Mhz進(jìn)行分頻,分別是10000分頻、100分頻、1250分頻。因?yàn)榉诸l原理是一樣,所以這里只給出100分頻模塊的部分代碼,其它分頻不再贅述了。</p><p> --designed by G_XW the fenpin100 block</p><p> architecture one
51、of fenpin100 is </p><p> constant m:integer:=50;</p><p><b> begin</b></p><p> process(clk_in)</p><p> variable count:integer range 0 to 99;</p
52、><p><b> begin</b></p><p> if(clk_in'event and clk_in='1')then</p><p> if(count=99)then </p><p><b> count:=0;</b></p><p&
53、gt;<b> else</b></p><p> count:=count+1;</p><p><b> end if;</b></p><p> if(count<m)then</p><p> clk_out<='0';</p><p
54、><b> else</b></p><p> clk_out<='1';</p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process;</p>
55、<p><b> 3 仿真與調(diào)試</b></p><p> 3.1 FPGA調(diào)試簡(jiǎn)介</p><p> 在FPGA硬件語(yǔ)言設(shè)計(jì)完成之后需要對(duì)其進(jìn)行仿真與調(diào)試,成功之后才能制板。在這里用到的調(diào)試工具為Altera公司自己推出的Quartus II,該軟件集FPGA設(shè)計(jì),仿真,調(diào)試于一體。仿真采用嵌入在軟件中的SignalTap II。在FPGA的仿真中
56、進(jìn)行功能仿真有兩種激勵(lì)的輸入方式,一種是傳統(tǒng)的波形輸入,另一種則是使用Testbench。后者是指驗(yàn)證平臺(tái),它通過(guò)編寫(xiě)代碼,對(duì)輸入產(chǎn)生預(yù)定的激勵(lì),然后有選擇的觀察輸出,并可以驗(yàn)證輸出是否符合設(shè)計(jì)要求。在本次設(shè)計(jì)中我們采用傳統(tǒng)的波形輸入法對(duì)系統(tǒng)各模塊,包括頂層模塊進(jìn)行仿真。并通過(guò)仿真來(lái)驗(yàn)證我們?cè)诘谌?jié)所設(shè)計(jì)模塊的正確性。</p><p> 3.2 通道選擇控制模塊仿真及調(diào)試</p><p>
57、; 將3.2節(jié)所設(shè)計(jì)的模塊代碼通過(guò)Quartus II軟件進(jìn)行編譯,順利通過(guò)編譯后生成模塊圖。模塊圖如圖3.1所示,</p><p> 圖3.1通道選擇控制模塊</p><p> 其仿真結(jié)果如圖3.2所示:</p><p> 圖3.2通道選擇控制模塊仿真結(jié)果</p><p> 由圖3.2可知,clk為系統(tǒng)時(shí)鐘經(jīng)5000分頻后的時(shí)鐘信
58、號(hào),address[1..0]為地址信號(hào)輸出,它輸出給通道選擇芯片hcf4052的連個(gè)地址信號(hào)管腳。從圖中可以看到,地址信號(hào)address以0.1ms的周期依次輸出0、1、2、3,使得hcf4052可以周期性地選中四個(gè)傳感器。由此我們可以判斷,通道選擇控制模塊設(shè)計(jì)成功。</p><p> 3.3 A/D轉(zhuǎn)換控制模塊仿真及調(diào)試</p><p> 將3.3節(jié)所設(shè)計(jì)的模塊代碼通過(guò)Quart
59、us II軟件進(jìn)行編譯,順利通過(guò)編譯后生成模塊圖。模塊圖如圖3.3所示。</p><p> 圖3.3 ADC0809模塊</p><p> 仿真結(jié)果如下圖所示: </p><p> 圖3.4 ADC0809仿真結(jié)果</p><p> 由仿真圖形我們可以看到:clk為ADC0809工作時(shí)序,通過(guò)對(duì)系統(tǒng)時(shí)鐘分頻得到。在第一個(gè)時(shí)鐘上升沿
60、ALE和START變?yōu)楦唠娖?,此時(shí)ADC0809將地址信號(hào)鎖存,并且將復(fù)位。第二個(gè)上升沿時(shí)ALE和START變?yōu)榈碗娖剑藭r(shí)ADC0809開(kāi)始模數(shù)轉(zhuǎn)換,同時(shí)檢測(cè)EOC的狀態(tài),當(dāng)其為高電平時(shí)表示轉(zhuǎn)換結(jié)束,所以在第三次和第四次上升沿OE均輸出高電平,第四個(gè)上升沿時(shí)ADC0809將轉(zhuǎn)換好的數(shù)據(jù)傳給fpga,因此我們看到這時(shí)DOUT為71H。綜上所述,A/D轉(zhuǎn)換控制模塊設(shè)計(jì)成功。</p><p> 3.4串口通信模塊仿
61、真及調(diào)試</p><p> 將3.4節(jié)所設(shè)計(jì)的模塊代碼通過(guò)Quartus II軟件進(jìn)行編譯,順利通過(guò)編譯后生成模塊圖。模塊圖如圖3.4所示。 </p><p> 圖3.4串口通信模塊</p><p> 圖中bclk為串口發(fā)送數(shù)據(jù)的時(shí)鐘信號(hào),需要對(duì)系統(tǒng)時(shí)鐘進(jìn)行倍頻再分頻得到。由通信協(xié)議我們知道:下位機(jī)頻率與上位機(jī)波特率要對(duì)應(yīng)。由于漏磁檢測(cè)系統(tǒng)一般數(shù)據(jù)量大,所以上
62、位機(jī)設(shè)置的波特率為56000bps,故fpga串口發(fā)送的頻率為56000。串口通信本系統(tǒng)串口通信只用到了發(fā)送功能,因此為了檢驗(yàn)程序的正確與否,我們?cè)诔绦蛑邢劝l(fā)常數(shù),然后發(fā)給pc,借助串口調(diào)試助手進(jìn)行調(diào)試。</p><p> 3.5 頂層設(shè)計(jì)仿真及調(diào)試</p><p> 系統(tǒng)頂層設(shè)計(jì)圖如下所示</p><p> 圖3.6頂層設(shè)計(jì)示意圖</p>&l
63、t;p> 在Quartus II中將前面介紹過(guò)的通道選擇控制模塊、A/D轉(zhuǎn)換控制模塊、串口通信模塊、分頻與倍頻模塊結(jié)合起來(lái),用原理圖的輸入方法設(shè)計(jì)出了頂層原理圖。最后我們將設(shè)計(jì)好的頂層綜合編譯,通過(guò)下載器下載到目標(biāo)板上,經(jīng)測(cè)試表明,本次設(shè)計(jì)所設(shè)定的要求基本得以實(shí)現(xiàn)。綜合器綜合的結(jié)果如圖3.7所示。從中我們可以看出,系統(tǒng)占用的IO口不多,而底層的邏輯門(mén)電路占用的也不大,這表明我們的設(shè)計(jì)還較合理。</p><p&
64、gt; 圖3.7頂層設(shè)計(jì)綜合結(jié)果</p><p><b> 5設(shè)計(jì)結(jié)果與總結(jié)</b></p><p><b> 5.1結(jié)果與總結(jié)</b></p><p> 通過(guò)Altera數(shù)據(jù)手冊(cè)提供的關(guān)于Quartusll JTAG配置步驟將編譯并且仿真好的程序代碼文件通過(guò)JTAG接口燒寫(xiě)進(jìn)FPGA的SRAM中.這里不是先將程序
65、燒寫(xiě)迸配置芯片EPCS4,目的是為了防止程序不能達(dá)到預(yù)期的目的時(shí),方便在線調(diào)試(CPLD具有帶電擦寫(xiě)功能,因此CPLD同樣具備此優(yōu)勢(shì))。FPGA的優(yōu)點(diǎn)就是更改程序代碼后可以實(shí)時(shí)地下載給FPGA觀察運(yùn)行情況。經(jīng)過(guò)幾次調(diào)試后修改,終于得到了讓我們比較滿意的結(jié)果。前面說(shuō)道過(guò),這個(gè)實(shí)驗(yàn)如果能在一根有缺陷的管道中進(jìn)行,那么就能看到某個(gè)位置的曲線與周圍曲線有明顯不同,技術(shù)人員就能分析出管道的缺陷在哪。并且隨著科技的發(fā)展,新傳感器的發(fā)明,新技術(shù)的應(yīng)用
66、,在漏磁檢測(cè)上,也一定會(huì)有新的創(chuàng)新出現(xiàn)。因此本次設(shè)計(jì)存在著相當(dāng)?shù)那熬?。在做?jì)算機(jī)課程設(shè)計(jì)的過(guò)程中,必須做到有一個(gè)大綱,做到各個(gè)模塊的功能的實(shí)現(xiàn),這樣才容易實(shí)現(xiàn)整個(gè)的功能的實(shí)現(xiàn)。</p><p><b> 參考文獻(xiàn)</b></p><p> [1].蔣奇,王太勇.鋼管漏磁檢測(cè)信號(hào)的時(shí)頻分析[J].機(jī)電設(shè)備,2002(2):16-20.</p><
67、p> [2].邢燕好.基于FPGA的漏磁檢測(cè)系統(tǒng)設(shè)計(jì)[D].沈陽(yáng):沈陽(yáng)工業(yè)大學(xué),2005.</p><p> [3].廖超平.EDA技術(shù)與VHDL實(shí)用教程[M]。北京:高等教育出版社,2007.</p><p> [4].李莉,路而紅.電子設(shè)計(jì)自動(dòng)化(EDA)[D].北京:中國(guó)電力出版社,2009.</p><p> [5].林敏,方穎立.VHDL數(shù)字
68、系統(tǒng)設(shè)計(jì)與高層次組合[M].北京:電子工業(yè)出版社,2002.</p><p><b> 致謝</b></p><p> 經(jīng)過(guò)幾個(gè)星期的學(xué)習(xí),與組員的討論,終于在此完成了計(jì)算機(jī)課程設(shè)計(jì)。由于自己以前接觸過(guò)VHDL硬件描述語(yǔ)言,所以相對(duì)來(lái)說(shuō)容易一些。但是依然要感謝我的指導(dǎo)老師柴老師,組員以及各位同學(xué)的幫助。如果沒(méi)有他們的幫助,我不可能完成的這么快,也不可能考慮的如現(xiàn)在
69、全面。在這里首先我要感謝柴明鋼老師,他的認(rèn)真教導(dǎo),他的耐心鼓勵(lì),他的認(rèn)真負(fù)責(zé),都使我感覺(jué)到這幾周受益匪淺,在以后的學(xué)習(xí)和生活中,他都是我的榜樣。</p><p> 其次,我也必須謝謝王鵬同學(xué)的幫助,他給予了我們的模塊思想與思路。還有吳青云同學(xué),他是一個(gè)虛心接受別人建議的組員,我們合作很愉快,希望以后還有一起做課程設(shè)計(jì)或?qū)W習(xí)的機(jī)會(huì)。他們之中有的比我有經(jīng)驗(yàn),懂得比我多,當(dāng)碰到難題我們就一起討論,有不懂的地方他們也是
70、不遺余力地教我。所以非常感謝這些人的幫助,以使得我掌握了更多的知識(shí),我也將再接再厲,不辜負(fù)給的期望。</p><p><b> 附錄——源程序代碼</b></p><p> 1.Transfer模塊</p><p> --這段程序是串口通信的發(fā)送部分</p><p> --時(shí)鐘頻率是串口通信波特率的15倍<
71、/p><p> --計(jì)數(shù)器計(jì)數(shù)滿16才進(jìn)行下一位的輸出</p><p> --數(shù)據(jù)輸出變化占一個(gè)周期,保持?jǐn)?shù)據(jù)占14個(gè)周</p><p> library IEEE;</p><p> use IEEE.STD_LOGIC_1164.ALL;</p><p> use IEEE.STD_LOGIC_ARITH.A
72、LL;</p><p> use IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p> entity transfer is</p><p> PORT( txbuf:in std_logic_vector(7 downto 0); --發(fā)送十六進(jìn)制代碼</p><p> bclk:in std_logic;&
73、lt;/p><p> reset:in std_logic; --復(fù)位</p><p> w_en:in std_logic; --發(fā)送使能</p><p> txd:out std_logic); --發(fā)送端</p><p> end
74、 transfer;</p><p> architecture behavior of transfer is</p><p> type state_type is (xidle,xstart,xwait,xshift); --狀態(tài)機(jī)</p><p> signal state : state_type:=xidle;</p><p&
75、gt; signal txds : std_logic; </p><p> signal tx_reg:std_logic_vector(9 downto 0); --輸出數(shù)據(jù)</p><p><b> begin</b></p><p> --tx_reg<='1'&am
76、p; txbuf & '0';</p><p> tx_reg<="1011110010";</p><p> process(bclk,reset,w_en,txbuf)</p><p> variable cnt16:integer range 0 to 3:=0; --計(jì)數(shù)器,用來(lái)發(fā)送<
77、/p><p> variable bitcnt: integer range 0 to 9 :=0; --控制發(fā)送位數(shù)</p><p><b> begin</b></p><p> if rising_edge(bclk) then</p><p> if reset='0' then</
78、p><p> state<=xidle; --異步初始化,狀態(tài)機(jī)設(shè)置為空閑狀態(tài)</p><p> txds<='1'; --輸出初始化是1</p><p><b> else </b></p&
79、gt;<p> case state is</p><p> when xidle =></p><p> if w_en='1' then --開(kāi)始發(fā)送信號(hào)觸發(fā)</p><p> state<=xstart; --跳轉(zhuǎn)到發(fā)送初始位狀態(tài)<
80、/p><p><b> else </b></p><p> state<=xidle;</p><p><b> end if;</b></p><p> when xstart =></p><p> if cnt16=2 then
81、 --計(jì)數(shù)器到16就狀態(tài)跳轉(zhuǎn)到輸出狀態(tài)</p><p> state<=xshift;</p><p><b> cnt16:=0;</b></p><p><b> else</b></p><p> cnt16:=cnt16+1;</p><
82、;p> state<=xstart;</p><p><b> end if;</b></p><p> txds<='0'; --開(kāi)始位輸出</p><p> when xwait=> </p&g
83、t;<p> if cnt16 =3 then --計(jì)數(shù)器計(jì)數(shù)到15跳轉(zhuǎn)到下一狀態(tài)</p><p> if bitcnt=10 then --如果輸出8位完成,就轉(zhuǎn)到結(jié)束傳輸狀態(tài)</p><p> state<=xidle;</p><p> bitcnt:=0;</p&
84、gt;<p><b> cnt16:=0;</b></p><p><b> else</b></p><p> state<=xshift; --如果還沒(méi)有輸出8位,那么跳轉(zhuǎn)到輸出狀態(tài)</p><p><b> end if;</b>
85、;</p><p> cnt16 :=0;</p><p><b> else </b></p><p> cnt16:=cnt16+1;</p><p> state<=xwait;</p><p><b> end if;</b></p>&
86、lt;p> when xshift=></p><p> txds<=tx_reg(bitcnt); --數(shù)據(jù)位輸出,只有這個(gè)狀態(tài)決定輸出,然后跳轉(zhuǎn)狀態(tài)保持?jǐn)?shù)據(jù)位</p><p> bitcnt:=bitcnt+1; --輸出數(shù)據(jù)位的序號(hào)自動(dòng)加1</p><p>
87、 state<=xwait; --轉(zhuǎn)到保持?jǐn)?shù)據(jù)的狀態(tài)</p><p> when others => --容錯(cuò)設(shè)計(jì),其他情況一律跳轉(zhuǎn)到空閑狀態(tài)</p><p> state<=xidle;</p><p><b> end
88、 case;</b></p><p><b> end if;</b></p><p><b> end if;</b></p><p> txd<=txds; --輸出數(shù)據(jù)</p><p> end proces
89、s;</p><p> end behavior;</p><p> 2.fenpin500模塊</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> entity fenpin500 is</p><p
90、><b> port(</b></p><p> clk_in:in std_logic;</p><p> clk_out:out std_logic</p><p><b> );</b></p><p> end fenpin500;</p><p>
91、 architecture one of fenpin500 is --if system clock is60MHz,THEN 1250fenpin</p><p> constant m:integer:=625;</p><p><b> begin</b></p><p> process(clk_in)</p>
92、<p> variable count:integer range 0 to 1249;</p><p><b> begin</b></p><p> if(clk_in'event and clk_in='1')then</p><p> if(count=1249)then </p>
93、;<p><b> count:=0;</b></p><p><b> else</b></p><p> count:=count+1;</p><p><b> end if;</b></p><p> if(count<m)then<
94、/p><p> clk_out<='0';</p><p><b> else</b></p><p> clk_out<='1';</p><p><b> end if;</b></p><p><b> end
95、 if;</b></p><p> end process;</p><p><b> end one;</b></p><p> 3.fenpin100模塊</p><p> library ieee;</p><p> use ieee.std_logic_1164.al
96、l;</p><p> entity fenpin100 is</p><p><b> port(</b></p><p> clk_in:in std_logic;</p><p> clk_out:out std_logic</p><p><b> );</b&g
97、t;</p><p> end fenpin100;</p><p> architecture one of fenpin100 is --after fen pin ,the period is 2us(500khz) </p><p> constant m:integer:=50;</p><p><b&
98、gt; begin</b></p><p> process(clk_in)</p><p> variable count:integer range 0 to 99;--if system clock is 20MHz,then 20000 fenpin</p><p><b> begin</b></p>
99、<p> if(clk_in'event and clk_in='1')then</p><p> if(count=99)then </p><p><b> count:=0;</b></p><p><b> else</b></p><p> c
100、ount:=count+1;</p><p><b> end if;</b></p><p> if(count<m)then</p><p> clk_out<='0';</p><p><b> else</b></p><p>
101、clk_out<='1';</p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process;</p><p><b> end one;</b></p>&
102、lt;p> 4.fenpin模塊</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> entity fenpin is</p><p><b> port(</b></p><p> clk_
103、in:in std_logic;</p><p> clk_out:out std_logic);</p><p> end fenpin;</p><p> architecture one of fenpin is --after fen pin ,the period is 0.2ms(5khz) </p><p&g
104、t; constant m:integer:=5000;</p><p><b> begin</b></p><p> process(clk_in)</p><p> variable count:integer range 0 to 9999;--if system clock is 20MHz,then 20000 fenpin
105、</p><p><b> begin</b></p><p> if(clk_in'event and clk_in='1')then</p><p> if(count=9999)then </p><p><b> count:=0;</b></p>
106、<p><b> else</b></p><p> count:=count+1;</p><p><b> end if;</b></p><p> if(count<m)then</p><p> clk_out<='0';</p>
107、;<p><b> else</b></p><p> clk_out<='1';</p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process;<
108、;/p><p><b> end one;</b></p><p> 5.address模塊</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_arith.all;
109、</p><p> entity address is </p><p><b> port(</b></p><p> clk:in std_logic;</p><p> address_signal:out std_logic_vector(1 downto 0));</p><p>
110、;<b> end ;</b></p><p> architecture one of address is </p><p><b> begin</b></p><p> process(clk)</p><p> variable q :integer range 0 to 3;&
111、lt;/p><p><b> begin</b></p><p> if clk'event and clk='1' then </p><p> if(q=3) then </p><p><b> q:=0;</b></p><p> els
112、e q:=q+1;</p><p><b> end if;</b></p><p><b> end if;</b></p><p> address_signal<=conv_std_logic_vector(q,2);</p><p> end process;</p>
113、;<p><b> end one ;</b></p><p> 6.AD_CTRL模塊</p><p> LIBRARY IEEE;</p><p> USE IEEE.STD_LOGIC_1164.ALL;</p><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL;&l
114、t;/p><p> ENTITY AD_CTRL IS</p><p><b> PORT(</b></p><p> CLK,EOC:IN STD_LOGIC;</p><p> D:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p> ALE,START,O
115、E:OUT STD_LOGIC;</p><p> DOUT:OUT STD_LOGIC_VECTOR(7 DOWNTO 0));</p><p> END AD_CTRL;</p><p> ARCHITECTURE behav OF AD_CTRL IS</p><p> TYPE states is (st0,st1,st2,s
116、t3,st4); </p><p> SIGNAL current_state,next_state:states:=st0; </p><p> SIGNAL LOCK:STD_LOGIC;</p><p> SIGNAL REG_0:STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p><b> B
117、EGIN</b></p><p><b> REG_0<=D;</b></p><p> COM: PROCESS(current_state,EOC) </p><p><b> BEGIN</b></p><p> CASE current_state IS</
118、p><p> WHEN st0=>ALE<='0';START<='0';LOCK<='1';OE<='0';next_state<=st1; </p><p> WHEN st1=>ALE<='1';START<='1';LOCK<=
119、'1';OE<='0';next_state<=st2; </p><p> WHEN st2=>ALE<='0';START<='0';LOCK<='0';OE<='0';</p><p> IF (EOC='1') THEN ne
120、xt_state<=st3; </p><p> ELSE next_state<=st2; </p><p><b> END IF;</b></p><p> WHEN st3=>ALE<='0';START<='0';LOCK<='0';OE&l
121、t;='1';next_state<=st4; </p><p> WHEN st4=>ALE<='0';START<='0';LOCK<='1';OE<='1';next_state<=st0; </p><p> WHEN OTHERS=>next_sta
122、te<=st0;</p><p><b> END CASE;</b></p><p> END PROCESS COM;</p><p> REG: PROCESS(CLK)</p><p><b> BEGIN</b></p><p> IF(CLK
123、9;EVENT AND CLK='1') THEN current_state<=next_state;</p><p><b> END IF;</b></p><p> END PROCESS REG;</p><p> LATCH1: PROCESS(LOCK) </p><p><
124、;b> BEGIN</b></p><p> IF LOCK='1' AND LOCK'EVENT THEN DOUT<=REG_0;</p><p><b> END IF;</b></p><p> END PROCESS LATCH1;</p><p> E
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 計(jì)算機(jī)課程設(shè)計(jì)報(bào)告
- 計(jì)算機(jī)課程設(shè)計(jì)
- 微型計(jì)算機(jī)課程設(shè)計(jì)報(bào)告
- vf計(jì)算機(jī)課程設(shè)計(jì)
- 計(jì)算機(jī)課程設(shè)計(jì)---冒泡排序
- 計(jì)算機(jī)課程設(shè)計(jì)----銷售管理系統(tǒng)
- 計(jì)算機(jī)課程設(shè)計(jì)--人事管理系統(tǒng)
- 基于fpga的樂(lè)曲演奏電路設(shè)計(jì)課程設(shè)計(jì)
- 計(jì)算機(jī)課程設(shè)計(jì)----實(shí)用網(wǎng)絡(luò)考試系統(tǒng)
- 計(jì)算機(jī)課程設(shè)計(jì)——水箱水位控制系統(tǒng)設(shè)計(jì)
- 電加熱爐計(jì)算機(jī)溫度測(cè)控系統(tǒng)設(shè)計(jì)-計(jì)算機(jī)課程設(shè)計(jì)
- 計(jì)算機(jī)課程設(shè)計(jì)--交通燈模擬控制
- 中學(xué)計(jì)算機(jī)課程的教學(xué)設(shè)計(jì)
- 計(jì)算機(jī)課程設(shè)計(jì)-----電子政務(wù)網(wǎng)站的設(shè)計(jì)
- 微型計(jì)算機(jī)課程設(shè)計(jì)--數(shù)據(jù)采集系統(tǒng)
- 計(jì)算機(jī)課程設(shè)計(jì)報(bào)告---網(wǎng)上書(shū)店訂單管理子系統(tǒng)
- 流量檢測(cè)電路設(shè)計(jì)課程設(shè)計(jì)
- 微型計(jì)算機(jī)課程設(shè)計(jì)---數(shù)字錄音機(jī)
- 計(jì)算機(jī)硬件課程設(shè)計(jì)報(bào)告---簡(jiǎn)單計(jì)算機(jī)的設(shè)計(jì)
- 計(jì)算機(jī)課程分析
評(píng)論
0/150
提交評(píng)論