版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 畢業(yè)設(shè)計(論文)</b></p><p> 題 目: 基于單片機的智能 </p><p><b> 電子計數(shù)器的設(shè)計 </b></p><p> 學(xué) 院:電信學(xué)院 </p><p> 專 業(yè):電子科學(xué)與技術(shù) </p>&
2、lt;p> 學(xué)生姓名: </p><p> 指導(dǎo)教師: </p><p><b> 摘 要</b></p><p> 數(shù)字頻率計是電子測量領(lǐng)域中最常見的測量儀器之一。它可以測量方波和正弦波的頻率、周期和脈沖寬度等時間參數(shù)。</p><p> 本
3、設(shè)計是由單片機控制的數(shù)字頻率計設(shè)計。本文在討論頻率測量的常用方法與原理的基礎(chǔ)上,闡述了等精度測頻系統(tǒng)的設(shè)計。系統(tǒng)包括穩(wěn)壓電源電路、信號放大整形電路、測頻電路、單片機電路模塊、標(biāo)準(zhǔn)頻率信號源、鍵盤模塊、數(shù)碼顯示模塊等。采用軟硬件結(jié)合的方法,頻率、周期、脈寬和占空比的計算由單片機89C51完成,外圍電路其數(shù)字電路部分使用了CPLD,并采用VHDL語言進行設(shè)計描述,其輸入通道由模擬電路來實現(xiàn)。</p><p> 系統(tǒng)
4、將單片機89C51的控制靈活性及CPLD芯片的現(xiàn)場可編程性相結(jié)合,不但大大縮短了開發(fā)研制周期,而且使本系統(tǒng)具有結(jié)構(gòu)緊湊、體積小、可靠性高、測頻范圍寬、精度高等優(yōu)點。</p><p> 關(guān)鍵詞: 頻率計 單片機 CPLD 等精度</p><p><b> Abstract</b></p><p> Digital cymometer
5、is one of the most common instruments of electronic measurement. It can measure time parameters such as the square wave and the sine wave frequency, cycle and pulse width, and so on.</p><p> The design is t
6、he digital cymometer based on the signal chip computer control. Based on the discussion of the commonly used method of measuring frequency and on the basis of principle, it describes the design of frequency measurement s
7、ystem with the same accuracy including the power supply system circuit, signal amplification plastic circuit, measuring frequency circuits, MCU circuit module, the standard frequency signal source, keyboard module, the d
8、igital display module, and so on. It takes th</p><p> Key Words: cymometer; signal chip computer; CPLD; equal precision</p><p><b> 目錄</b></p><p><b> 第一章 引言1&l
9、t;/b></p><p> 1.1 課題研究的現(xiàn)狀與發(fā)展趨勢1</p><p> 1.2 課題研究的意義與作用1</p><p> 1.3 數(shù)字頻率計的基本原理1</p><p> 1.4 系統(tǒng)設(shè)計技術(shù)指標(biāo)2</p><p> 1.4.1 基本指標(biāo)2</p><p>
10、 1.4.2 發(fā)揮部分2</p><p> 第二章 系統(tǒng)硬件設(shè)計3</p><p> 2.1 頻率測量的方法的研究3</p><p> 2.1.1 數(shù)字化直接測量頻率的原理3</p><p> 2.1.2 數(shù)字化直接測量周期的原理4</p><p> 2.1.3 組合法測量頻率的原理5</
11、p><p> 2.1.4 多周期同步等精度測量的原理6</p><p> 2.2 系統(tǒng)硬件設(shè)計8</p><p> 2.2.1 穩(wěn)壓電源電路9</p><p> 2.2.2 信號放大整形電路10</p><p> 2.2.3 單片機控制電路11</p><p> 2.2.4 標(biāo)
12、準(zhǔn)頻率信號源13</p><p> 2.2.5 數(shù)碼管顯示模塊13</p><p> 第三章 系統(tǒng)軟件設(shè)計15</p><p> 3.1 CPLD測頻專用模塊的設(shè)計15</p><p> 3.1.1 頻率計CPLD部分的VHDL程序16</p><p> 3.1.2 頻率計CPLD部分的仿真22&
13、lt;/p><p> 3.2 單片機控制與運算程序的設(shè)計24</p><p> 3.2.1 單片機主程序的設(shè)計24</p><p> 3.2.2 頻率、周期計數(shù)子程序的設(shè)計25</p><p> 3.2.3 脈寬、占空比子程序的設(shè)計18</p><p> 3.2.4 鍵盤掃描及數(shù)碼管顯示子程序的設(shè)計30
14、</p><p> 第四章 仿真方法及調(diào)試32</p><p> 4.1 系統(tǒng)調(diào)試的環(huán)境32</p><p> 4.2 軟硬件的調(diào)試32</p><p> 4.3 系統(tǒng)的硬件驗證32</p><p><b> 4.4 小結(jié)32</b></p><p>
15、 4.5 系統(tǒng)擴展思路32</p><p><b> 參考文獻33</b></p><p><b> 致謝33</b></p><p><b> 第一章 引言</b></p><p> 1.1 課題研究的現(xiàn)狀與發(fā)展趨勢</p><p>
16、 隨著大規(guī)模集成電路技術(shù)的發(fā)展及電子產(chǎn)品市場運作節(jié)奏的進一步加快,涉及諸如計算機應(yīng)用、通信、智能儀表、醫(yī)用設(shè)備、軍事、民用電器等領(lǐng)域的現(xiàn)代電子設(shè)計技術(shù)已邁入一個全新的階段。</p><p> 頻率是反映信號特性的基本參量之一,頻率測量在應(yīng)用電子技術(shù)領(lǐng)域有著重要的地位。</p><p> 在電子測量中,頻率的測量精確度是非常高的。利用計數(shù)法測量頻率具有精度高、使用方便、容易實現(xiàn)測量過程自
17、動化等一系列突出優(yōu)點,已成為目前頻率測量的重要方法。人們將許多參數(shù)的測量轉(zhuǎn)換為頻率量來測量和處理。</p><p> 傳統(tǒng)的頻率計通常采用組合電路和時序電路等大量的硬件電路構(gòu)成,在使用過程中存在電路結(jié)構(gòu)復(fù)雜,測量精度低、故障率高、維護不易等問題,其產(chǎn)品不但體積較大,運行速度慢,而且測量低頻信號時不宜直接使用。頻率測量在科技研究和實際應(yīng)用中的作用日益重要。測量的數(shù)字化、智能化是當(dāng)前測量技術(shù)發(fā)展的趨勢。</p
18、><p> 1.2 課題研究的意義與作用</p><p> 數(shù)字頻率計數(shù)器又稱通用計數(shù)器,是電子測量領(lǐng)域中最常見的測量儀器之一。它可以測量正弦波的頻率(周期),脈沖波的頻率(周期),脈沖寬度等時間參數(shù)。</p><p> 隨著單片機技術(shù)的不斷發(fā)展,用單片機通過軟件設(shè)計,采用適當(dāng)?shù)乃惴ㄈ〈@部分電路不僅能彌補上述不足,而且性能也將大有提高。針對普通頻率計存在讀數(shù)難、
19、測量精度不高等問題, 目前采用單片機控制的數(shù)字頻率計, 用于測量方波、正弦波或其它脈沖信號的頻率, 并用數(shù)字顯示, 具有精度高、測量迅速、讀數(shù)方便等優(yōu)點, 已經(jīng)在電子測量領(lǐng)域里得到了廣泛應(yīng)用。</p><p> MCS—51系列單片機具有體積小,功能強,性能價格比較高等特點,因此被廣泛應(yīng)用于工業(yè)控制和智能化儀器,儀表等領(lǐng)域。本次設(shè)計的數(shù)字頻率計以89C51單片機為核心,具有性能優(yōu)良,精度高,可靠性好等特點。&l
20、t;/p><p> 1.3 數(shù)字頻率計的基本原理</p><p> 頻率計的基本原理是用一個頻率穩(wěn)定度高的頻率源作為基準(zhǔn)時鐘,對比測量其他信號的頻率。通常情況下計算每秒內(nèi)待測信號的脈沖個數(shù),此時我們稱閘門時間為1秒。閘門時間也可以大于或小于一秒。閘門時間越長,得到的頻率值就越準(zhǔn)確,但閘門時間越長,則每測一次頻率的間隔就越長。閘門時間越短,測的頻率值刷新就越快,但測得的頻率精度就受影響。&l
21、t;/p><p> 數(shù)字頻率計是用數(shù)字顯示被測信號頻率的儀器,被測信號可以是正弦波,方波或其它周期性變化的信號。如配以適當(dāng)?shù)膫鞲衅?,可以對多種物理量進行測試,比如機械振動的頻率,轉(zhuǎn)速,聲音的頻率以及產(chǎn)品的計件等等。</p><p> 1.4 系統(tǒng)設(shè)計技術(shù)指標(biāo)</p><p> 基于傳統(tǒng)測頻原理的頻率計的測量精度將隨被測信號頻率的下降而降低,在實用中有較大的局限性,
22、而等精度頻率計不但具有較高的測量精度,而且在整個測頻區(qū)域內(nèi)保持恒定的測試精度。</p><p> 課題要求運用單片機或者CPLD技術(shù),結(jié)合傳統(tǒng)直接測量頻率方法和等精度測量頻率的方法,實現(xiàn)高頻和低頻的測量,本系統(tǒng)設(shè)計的基本指標(biāo)如下。</p><p> 1.4.1 基本指標(biāo)</p><p> (1) 頻率:10Hz~30MHz</p><p&g
23、t; (2) 精度:《10-6</p><p> (3) 閘門時間為0.1秒、1秒</p><p> ?。?)實現(xiàn)對頻率、周期和時間間隔的測量功能</p><p> 1.4.2 發(fā)揮部分</p><p> (1) 信號:方波、正弦波</p><p> (2) 幅度:0.02V~0.5V</p>
24、<p> (3) 周期脈沖寬度幅度(0.5V~5V、頻率1Hz~1KHz)的占空比,占空比變化范圍為10%~90%,測試誤差≤1%。</p><p> 第二章 系統(tǒng)硬件設(shè)計</p><p> 2.1 頻率測量的方法的研究</p><p> 頻率的測量實際上就是在1s時間內(nèi)對信號進行計數(shù),計數(shù)值就是信號頻率。實現(xiàn)對頻率量測量的方法有許多種。測量方法大
25、致可分為如下幾類:</p><p> 表2-1 頻率測量方法</p><p> 直讀法又稱無源網(wǎng)絡(luò)頻率特性測量法;</p><p> 比較法是將被測頻率信號與已知頻率信號相比較 ,通過觀、聽比較結(jié)果 ,獲得被測信號的頻率;</p><p> 電容充放電式計數(shù)法是利用電子電路控制電容器充放電的次數(shù) ,再用電磁式儀表測量充放電電流的大小
26、,從而測出被測信號的頻率值;</p><p> 電子計數(shù)法是根據(jù)頻率定義進行測量的一種方法 ,它是用電子計數(shù)器顯示單位時間內(nèi)通過被測信號的周期個數(shù)來實現(xiàn)頻率的測量。</p><p> 利用電子計數(shù)式測量頻率具有精度高、測量范圍寬、顯示醒目直觀、測量迅速 ,以及便于實現(xiàn)測量過程自動化等一系列優(yōu)點 ,所以下面將重點介紹電子計數(shù)式測量頻率的幾種方法。</p><p>
27、 2.1.1 數(shù)字化直接測量頻率的原理</p><p> 無論頻率、周期還是時間間隔的數(shù)字化測量,均是基于主門加計數(shù)器的結(jié)構(gòu)而實現(xiàn)的,圖2.1(a)示出了這種計數(shù)式直接測頻的原理框圖。其中主門具有“與門”的邏輯功能。主門的一個輸入端送入的是頻率為的窄脈沖,它是由被測信號經(jīng)A通道放大整形后得到的。主門的另一個輸入端送來的是來自門控雙穩(wěn)的閘門時間信號Ts。因為門控雙穩(wěn)是受時基(標(biāo)準(zhǔn)頻率)信號控制的,所以Ts即準(zhǔn)確
28、又穩(wěn)定。設(shè)計時通過晶體震蕩器和分頻器的配合,可以獲得10S、1S、0.1S等閘門時間。由</p><p> 于主門的“與”功能,它的輸出端只有在閘門信號Ts有效時間才有頻率的窄脈沖輸出,并送到計數(shù)器去計數(shù)。設(shè)計數(shù)器的值為N,由頻率定義式可以計算得到被測信號頻率為=N/Ts (2-1)</p><p> 各種中規(guī)模計數(shù)器集成電路就非常適合于這種場合的應(yīng)用,如CD4518、CD4017等
29、。其原理框圖和時序圖如圖2.1所示。</p><p> 直接測頻法原理框圖
30、
31、 </p><p> ?。╞) 直接測頻法時序圖</p><p> 圖2.1 (a)直接測頻法原理框圖; (b)直接測頻法時序圖</p><p> 由式(2-1
32、)可知,當(dāng)閘門時間T為1S時,N值即為被測量信號的頻率。該測量方法由于主門的開啟時間與被測信號之間不同步,而使計數(shù)值N帶有±1量化誤差;且當(dāng)被測信號頻率越低時,該量化誤差的影響越大。若再考慮由晶體振蕩器引起的閘門時間誤差,對式(2-1)進行誤差的累積與合成運算后,可以得到直接測量測頻率誤差的計算公式如下:</p><p><b> ?。?-2)</b></p><
33、;p> 上式右邊第一項為量化誤差的相對值,其中=±1;第二項為閘門時間的相對誤差,數(shù)值上等于晶體振蕩器基準(zhǔn)頻率的相對不確定度。在一定時,閘門時</p><p> 間T越長,測量準(zhǔn)確度越高。而當(dāng)T選定后,越高,由于±1誤差對測量結(jié)果的影響減小,測量準(zhǔn)確度越高。但是隨著±1誤差的影響的減小,閘門時間(也即基準(zhǔn)頻率)自身的準(zhǔn)確度對測量結(jié)果的影響不可忽略,這時可以認(rèn)為是計數(shù)式直接測
34、頻率準(zhǔn)確度的極限。</p><p> 2.1.2 數(shù)字化直接測量周期的原理</p><p> 雖然直接測頻法可以測出單位時間內(nèi)脈沖的個數(shù)即頻率,但是對于較低頻率的信號其檢測誤差會大大增大,解決辦法就是改直接測頻法為直接測周期法。圖2.2(a)為計數(shù)式直接測周期的原理框圖。與測頻原理框圖相比,其中門控雙穩(wěn)改由輸入信號放大、整形和分頻后的脈沖控制,所以閘門時間的寬度就等于k倍被測信號的周期
35、k;而主門的另一個輸入端,送入由晶體震蕩器和分頻器產(chǎn)生的周期為T0的時標(biāo)脈沖信號。由于主門的“與”功能,它的輸出端只有在閘門信號k期間有時標(biāo)脈沖輸出,并送到計數(shù)器去計數(shù),計數(shù)器的值為N。不難看出,被測信號的周期為: (2-3) 其原理框圖和時序圖如圖2.2所示:</p><p><b> 測周期法原理框圖</b></p><p> (b)測周期法時序圖&l
36、t;/p><p> 圖2.2 (a)測周期法原理框圖; (b)測周期法時序圖</p><p> 與計數(shù)式測頻率相似,由于和T0之間也不是同步的,所以計數(shù)值N也帶有±1量化誤差;此外由于晶振的不確定度,時標(biāo)的周期T0也存在誤差;最后,由于被測輸入信號噪聲的影響,使經(jīng)B通道放大整形后的脈沖周期中還引入了一種觸發(fā)誤差。對式(2-3)進行誤差的積累和合成運算,可以得到測周期誤差的計算公式
37、如下:</p><p> (2-4) </p><p> 上式右邊第一項為量化誤差的相對值,其中計數(shù)誤差Δ=±1;第二項為時標(biāo)的相對誤差;第三項為觸發(fā)誤差θ,其中R為被測信號與噪聲比,可由公式R=20㏒計算(單位為dB)。要降低觸發(fā)誤差就必須增大信噪比R,并采用多周期測量,還可以在整形電路中采用具有滯回特性電路來減小噪聲的影響。 </p>
38、<p> 在倍率k和時標(biāo)T0固定時,與測頻率相反,測量周期的誤差隨被測信號的頻率升高而增大,此外由于有限的信噪比,使觸發(fā)誤差成為影響測量周期準(zhǔn)確度的主要因素。采用多周期測量可以有效的降低觸發(fā)誤差的影響。 </p><p> 2.1.3 組合法測量頻率的原理</p><p> 組合測頻法是指在低頻時采用直接測量周期法測信號周期,然后換算成頻率。經(jīng)以上分析可知,直接測周期法在
39、低頻段精度高,直接測頻法在高頻段有著很高的精度。由此可見,為了獲得較高的測量精度,在高頻段,宜采用直接測頻法;在低頻段,宜采用直接測周期法。根據(jù)式(2-3)、(2-4)可以導(dǎo)出計算中界頻率的公式如下:</p><p> (2-5) 為了獲得較高的測量準(zhǔn)確度,當(dāng)≥時,直接測頻,間接測周期;當(dāng)≤時,直接測周期,間接測頻。</p><p> 2.1.4 多周期同步等精度測量的原理</p
40、><p> 無論是直接測頻法還是測周期法,都無法保證閘門信號和另一信號的首尾實現(xiàn)同步,這就難以保證獲得較高的測量精度,其誤差在一個脈沖之內(nèi)。由此,當(dāng)引入多周期同步等精度測量法時,可以較好的解決這個問題。</p><p> 多周期同步等精度測量法的原理是:電路需引入一個比被測信號頻率高若干倍的內(nèi)部時基信號,測量結(jié)果的誤差范圍便在這一個時基信號范圍內(nèi)。首先由相應(yīng)的控制電路給出閘門開啟信號,此時
41、計數(shù)器并不開始計數(shù),而是等到被測信號的上升沿到來時才真正開始</p><p> 計數(shù)。然后,兩組計數(shù)器分別對被測信號和時基信號脈沖計數(shù),當(dāng)控制電路給出閘門關(guān)閉信號,此時計數(shù)器并不停止計數(shù),而是等到被測信號的上升沿到來時才真正停止計數(shù)。圖2.3中為輸入信號頻率,為時鐘脈沖的頻率。A、B兩個計數(shù)器在同一閘門時間T內(nèi)分別對和進行計數(shù),計數(shù)器A的計數(shù)值,計數(shù)器B的計數(shù)值為。由于,則被測頻率和周期分別為:</p&g
42、t;<p> (2-6) (2-7)</p><p> 式(2-6)中=1/,為時鐘的周期。圖2.3中同步電路(D觸發(fā)器)的作用在于使計數(shù)閘門信號與被測信號同步,實現(xiàn)同步開門,并且開門時間T準(zhǔn)確地等于被測信號周期的整數(shù)倍,故式(2-6)、(2-7)中的計數(shù)沒有±1量化誤差。計數(shù)器雖然有量化誤差,但由于很高,遠大于1,所以的±1量化誤差的相對值(±
43、1/)很小,且該誤差與被測頻率無關(guān),因此在整個測頻范圍內(nèi),多周期同步等精度測量法能夠?qū)崿F(xiàn)等精度的測量。該測試方法需要的除法功能運算,對于使用微處理器的儀器來說,是不難實現(xiàn)的。</p><p> 考慮計數(shù)值的±1量化誤差、時鐘的不確定度和同步門的觸發(fā)誤差時,根據(jù)式(2-6)和式(2-7)可以推導(dǎo)出倒數(shù)計數(shù)器的測頻、測周期誤差的計算公式:</p><p><b> (2
44、-8)</b></p><p> 上式中R=20㏒,為被測信號與噪聲比,k為多周期倍率。與式(2-2)、(2-4)相比較,式(2-8)中沒有對被測信號計數(shù)引起的±1量化誤差,只有計數(shù)器在同步門T周期的±1計數(shù)誤差/,而且與被測量信號的頻率無關(guān),即在整個測量頻段上是等精度的。假定,輸入通道放大器的制作工藝較高,它所產(chǎn)生的噪聲可以忽略,這時觸發(fā)誤差僅由被測量信號本身的質(zhì)量所決定,即由
45、外因決定。在評價測量方法時只應(yīng)考慮內(nèi)因,而不考慮外因,也即不考慮上式中的第三項。以典型數(shù)據(jù)為例,頻率的不確定度通常為~,假定時鐘頻率為10MHZ,則等于0.1,若閘門時間選為1S,則的±1計數(shù)誤差/僅為,由此可見,這時多周期同步等精度測量法的測頻、測周期的精度在整個測量頻段上均可達到量級。</p><p> 其原理框圖和時序圖如圖2.3所示。</p><p> ?。╝)多周期同
46、步等精度測量法原理框圖</p><p> ?。╞)多周期同步等精度測量法時序圖</p><p> 圖2.3 (a)多周期同步等精度測量法原理框圖; (b) 多周期同步等精度測量法時序圖</p><p> 2.2 系統(tǒng)硬件設(shè)計</p><p> 根據(jù)頻率計的設(shè)計要求,我們可將整個電路系統(tǒng)劃分為幾個基本模塊,組成模塊框圖如圖2.5所示。&
47、lt;/p><p> 圖2.5 頻率計組成模塊框圖</p><p> 其主要由以下幾個部分構(gòu)成:</p><p> (1) 信號整形電路。用于對待測信號進行放大和整形,以便作為CPLD的輸入信號。</p><p> (2) 測頻電路。是測頻的核心電路模塊,由CPLD器件擔(dān)任。</p><p> (3) 單片機電路
48、模塊。用于控制CPLD的測頻操作和讀取測頻數(shù)據(jù),并作出相應(yīng)數(shù)據(jù)處理。</p><p> (4) 50MHz的標(biāo)準(zhǔn)頻率信號源。本模塊采用高頻率穩(wěn)定度和高精度的晶振作為標(biāo)準(zhǔn)頻率發(fā)生器,產(chǎn)生50MHz的標(biāo)準(zhǔn)頻率信號直接進入CPLD。</p><p> (5) 鍵盤模塊??梢杂?個鍵執(zhí)行測試控制,一個是復(fù)位鍵,其余是命令鍵。</p><p> (6) 數(shù)碼顯示模塊。可
49、以用7個數(shù)碼管顯示測試結(jié)果,最高可表示百萬分之一的精度。</p><p> 2.2.1 穩(wěn)壓電源電路</p><p> 本項設(shè)計要求的電源均為±5V的直流穩(wěn)壓電源。7905空載時測量輸出在6V左右.加上負(fù)載,輸出正常。7805驅(qū)動電流可達1A,運行時電流200~300mA,7805溫度有50度左右。</p><p> 頻率計穩(wěn)壓電源電路圖如圖2.6所
50、示。</p><p> 圖2.6 頻率計穩(wěn)壓電源電路</p><p> 2 2.2 信號放大整形電路</p><p> 信號放大整形電路包括放大級和整形級兩部分。</p><p> 放大級的設(shè)計主要考慮增益和帶寬的指標(biāo)。因為后面的整形級采用了電壓比較器,所以放大級的增益應(yīng)根據(jù)頻率計指標(biāo)提出的最小輸入信號幅度(0.02V)和電壓比較器所
51、要求的輸入電壓的最小壓擺率來決定。由Maxim公司的集成電路手冊上查得Max902電壓比較器在過零比較時所要求的輸入電壓的最小壓擺率為0.5V/s,如果壓擺率的值低于此值,輸出就會引起震蕩,這是應(yīng)當(dāng)避免的。因為在本通道中,電壓比較器整形級是設(shè)計過零觸發(fā)方式的,因此必須對輸入信號過零處的壓擺率予以審查。眾所周知,當(dāng)輸入信號為峰值的正弦波時,其過零處的壓擺率可有公式計算,其中的為被測信號的頻率,發(fā)揮指標(biāo)要求其最低值為0.1HZ。將和SR=0
52、.5V/s代入上式可以求出。這個結(jié)果表明,當(dāng)加到電壓比較器輸入端的信號頻率為0.1Hz,只要其幅度大于0.8V,它的過零壓擺率就能滿足大于0.5V/s的要求,顯然所有的頻率大于0.1Hz的信號其過零壓擺率無疑將大于0.5V/s。若再考慮頻率設(shè)計指標(biāo)提出的 最小輸入信號幅度的峰值,不難求出所要求的放大級的增益。整形級用TTL器件時,起正常工作的最小輸入電壓為2V,由此可估算前置放大器的增益為2/0.02=</p><p
53、> 慮。圖2.6中用雙運放MAX4016中的兩個運放構(gòu)成相互級聯(lián)的兩級反相放大器。第一級反相放大器期的增益1、10 兩種值,由開關(guān)S2切換,第二級反相放大器的增益4,因此級聯(lián)后的增益4、40兩種值。當(dāng)被測信號較大時(0.5~5V),選用4倍的增益,當(dāng)被測信號為小信號時(0.02~0.5V),選用40倍的增益。集成運放MAX4016在閉環(huán)增益為1時的帶寬為150MHz,當(dāng)A2增益為4、10時帶寬分別約為37.5MHz(150MHz
54、/4)和15MHz(150MHz/10)。綜合起來,從輸入級到第二放大級其帶寬大于10MHz的指標(biāo)要求完全可以達到的。</p><p> 因為模擬通道部分所用的器件都是帶寬高速器件,為了防止寄生振蕩,在每個器件的電源引腳附近到地之間均需要加上去耦電容,每組去耦電容由兩種電容并聯(lián)起來,以取得良好的寬頻帶寬去耦效果。其中容量小的(0.1μF)用陶瓷電容,對高頻分量有良好的去耦作用;容量大的(6.8μF)用鉭電解電容
55、,對低頻分量有良好的去耦作用。</p><p> 整形級選用輸出為TTL電平的高速集成雙壓比較器MAX902來構(gòu)成,它比TTL電路有觸發(fā)靈敏度高、因而可降低放大級增益的優(yōu)點;上面已討論過,根據(jù)手冊提示,使用高速電壓比較器時必須保證輸入信號的壓擺率大于手冊上所給的最小容許值,以免在比較器輸出信號的前后沿部位產(chǎn)生振蕩。此外電源引腳附近也需要加接良好的去耦電容,布線短,數(shù)字電源和模擬電源的接地要分開,以免比較器輸出端
56、的數(shù)字信號干擾模擬電路部分的工作。</p><p> 為了防止輸入信號過大而損壞后面的元器件,在輸入端加上由一個470電阻和兩個二極管組成的限幅保護電路。限幅二極管應(yīng)選用結(jié)電容小,開關(guān)時間短,容許的正向電流大且正向壓降小的管子,2DK17A開關(guān)二極管是符合上述要求的一種。有時被測信號中含有較高的直流分量,為了保證通道放大器正常工作,輸入信號應(yīng)通過隔直流電容耦合到輸入級的輸入端,為此還要加上交、直流耦合切換開關(guān)S
57、1。</p><p> 圖2.7 信號放大整形電路</p><p> 2.2.3 單片機控制電路</p><p> 對單片機這部分的主要指標(biāo)考慮如下:①由+5V電源供電,I/O口與TTL電平兼容,并有足夠數(shù)目的I/O口;②要有豐富的四則算術(shù)運算和邏輯運算指令,指令執(zhí)行速度要快;③片內(nèi)除RAM外還要有EPROM;④至少有兩個16位的定時器/計數(shù)器;⑤有外部中斷輸
58、入引腳;⑥具有串行通信口;⑦價格要低廉。</p><p> 根據(jù)以上條件,查閱相關(guān)資料,發(fā)現(xiàn)8位單片機89C51的指標(biāo)已經(jīng)能夠滿足要求。</p><p> 而對于實驗環(huán)境的限制,能選擇的CPLD有限,所以根據(jù)實驗室的情況選用了XILINX公司的XC9572。</p><p> 由于等精度數(shù)字頻率計涉及到的計算包括加、減、乘、除,耗用的資源比較大。因此,我們選擇
59、單片機和CPLD的結(jié)合來實現(xiàn)。單片機控制電路如圖2.8所示,其中單片機完成整個測量電路的測試控制、數(shù)據(jù)處理和顯示輸出;CPLD完成各種測試功能;鍵盤信號由89C51單片機進行處理,它從CPLD讀回計數(shù)器數(shù)據(jù)并進行運算,然后向顯示電路輸出測量結(jié)果。等精度數(shù)字頻率計電路系統(tǒng)原理框圖如圖2.8所示。</p><p> 系統(tǒng)的基本工作方式如下:</p><p> (1) P2口是單片機與CPL
60、D的數(shù)據(jù)傳送通信口,P0口為雙向控制口。P3口利用鍵盤顯示管理芯片ZLG7289作為數(shù)碼管顯示,實現(xiàn)數(shù)據(jù)顯示。系統(tǒng)的P1口設(shè)置5個功能鍵:占空比、脈寬、周期、頻率、自檢,進行各測試功能的轉(zhuǎn)換。</p><p> (2) 7個LED數(shù)碼管組成測量數(shù)據(jù)顯示器,另一個獨立的數(shù)碼管用于狀態(tài)顯示。</p><p> (3) Fs為測頻標(biāo)準(zhǔn)頻率50MHz信號輸入端,由晶體振蕩源電路提供。</
61、p><p> (4) Fx為被測信號輸入,此待測信號是經(jīng)放大整形后輸入CPLD的。</p><p> 圖2.8 等精度數(shù)字頻率計電路系統(tǒng)原理框圖</p><p> 2.2.4 標(biāo)準(zhǔn)頻率信號源</p><p> 本設(shè)計采用50MHZ的晶體振蕩器產(chǎn)生標(biāo)準(zhǔn)頻率方波信號(頻標(biāo))供數(shù)字測量電路使用。由公式(2-8)及其討論可知,多周期同步等精度測
62、量法所達到的測量精度和系統(tǒng)時鐘源的精度量級相近。晶體振蕩器采用恒溫晶振,穩(wěn)定度可以達到為:2.0×107/24小時。這樣,完成所要求的測量誤差已經(jīng)綽綽有余。</p><p> 2.2.5 數(shù)碼管顯示模塊</p><p> 從實驗條件等實際出發(fā)考慮,數(shù)碼管顯示模塊采用了ZLG7289。</p><p> ZLG7289是一片具有串行接口的,可同時驅(qū)動8
63、位共陰式數(shù)碼管的顯示驅(qū)動芯片,同時還可連接多達64鍵的鍵盤矩陣,單片即可完成LED顯示的全部功能。ZLG7289具有的特點和豐富的指令系統(tǒng),使得由其組成的LED顯示和鍵盤電路具有外圍電路簡單,功能強大,使用方便,可靠性高,與MCU接口簡單等特點,是LED顯示和鍵盤電路的首選器件。</p><p> ZLG7289與單片機的連接如下圖2.9所示。 </p><p> 圖2.9 ZLG72
64、89與單片機的連接</p><p> 因為本設(shè)計用高精度恒誤差的頻率和周期測試方法,預(yù)置門時間為1s,在標(biāo)準(zhǔn)頻率信號為50MHz的情況下,根據(jù)上文討論的高精度恒誤差的頻率和周期測試方法相對誤差計算公式可以算出測量精度為</p><p> 1/(1×50×106)=2×10-8</p><p> 即能夠顯示接近8位有效數(shù)字,所以,電
65、路中采用了8位LED顯示器.</p><p> 其中7個LED數(shù)碼管組成測量數(shù)據(jù)顯示器,另一個獨立的數(shù)碼管用于狀態(tài)顯示。</p><p> 當(dāng)測頻率時,有顯示指示,為了保證頻率計有足夠的顯示時間,并且在打開門控信號之前,要先清零,以使測量數(shù)字計數(shù)器每次從零開始計數(shù)。</p><p> 第三章 系統(tǒng)軟件設(shè)計</p><p> 設(shè)計包括頻
66、率計的測頻模塊和利用對單片機的編程。單片機的編程又由三部分構(gòu)成:對CPLD的數(shù)據(jù)讀取及控制信號輸出,鍵盤電路的掃描以及數(shù)碼管顯示輸出。</p><p> 3.1 CPLD測頻專用模塊的設(shè)計</p><p> 利用VHDL設(shè)計的測頻模塊主邏輯結(jié)構(gòu)如圖3.1所示:</p><p> 圖3.1 等精度頻率計主邏輯結(jié)構(gòu)圖</p><p> 圖
67、3.1中,預(yù)置門控信號CL可由單片機發(fā)出,可以證明,在1秒至0.1秒間選擇的范圍內(nèi),CL的時間寬度對測頻精度幾乎沒有影響,在此設(shè)其寬度為Tpr。BZH和TF模塊是兩個可控的32位高速計數(shù)器,BENA和ENA分別是他們的允許信號端,高電平有效。標(biāo)準(zhǔn)頻率信號從BZH的時鐘輸入端BLCK輸入,設(shè)其頻率為Fs;經(jīng)整形后的被測信號從與BZH相似的32位計數(shù)器TF的時鐘輸入端TCLK輸入,設(shè)其真實頻率值為,被測量頻率為。測頻原理說明如下:</
68、p><p> 測頻開始前,首先發(fā)出一個清零信號CLR,使兩個計數(shù)器和D的觸發(fā)器置零,同時通過信號ENA,禁止兩個計數(shù)器計數(shù)。這是一個初始化的操作。然后由單片機發(fā)出允許測頻命令,即令預(yù)置門控信號CL為高電平,這時D觸發(fā)器要一直等到被測信號的上升沿通過時Q端才被置1(即令START為高電平),與此同時,將同時啟動計數(shù)器BZH和TF,進入計數(shù)允許周期。在此期間,BZH和TF分別對被測信號(頻率為)和標(biāo)準(zhǔn)頻率信號(頻率為F
69、s)同時計數(shù)。當(dāng)Tpr秒后,預(yù)置門信號被單片機置為低電平,但此時兩個計數(shù)器并沒有停止計數(shù),一直等到被測信號的上升沿到來時,才通過D觸發(fā)器將這兩個計數(shù)器同時關(guān)閉。 </p><p> 由圖3.2可見,CL的寬度和發(fā)生的時間都不會影響計數(shù)使能信號(START)允許計數(shù)的周期總是恰好等于待測信號TLCK的完整周期數(shù),這正是確保TLCK在任何頻率條件下都能保持恒定精度的關(guān)鍵。而且,CL寬度的改變以及隨機的出現(xiàn)時間造成的
70、誤差最多只有BCLK信號的一個時鐘周期,如果BCLK由精確穩(wěn)定的晶體振蕩器發(fā)出,則任何時刻的絕對測量誤差只有億分之一秒。這樣就達到了技術(shù)要求的標(biāo)準(zhǔn)。</p><p> 圖3.2 頻率計測控時序</p><p> 被測頻率值為,標(biāo)準(zhǔn)頻率值為Fs,設(shè)在一次預(yù)置門時間Tpr中對被測信號計數(shù)值為Nx,對標(biāo)準(zhǔn)頻率信號的計數(shù)值為Ns,則下式成立:</p><p><
71、b> (3-1)</b></p><p> 不難得到測得的頻率為: (3-2)</p><p> 最后通過控制SEL選擇信號和64位至8位的多路選擇器MUX,將計數(shù)器BHZ和TF中的兩個32位數(shù)據(jù)按照SEL[2..0]的編碼次序,分8次依次讀入單片機,并按照各個模塊的計算公式進行計算和顯示。</p><p>
72、 3.1.1 頻率計CPLD部分的VHDL程序</p><p> 根據(jù)圖3.1的主邏輯結(jié)構(gòu)圖和圖3.2的測控時序,以及測頻原理,可以寫出相應(yīng)的VHDL功能描述。相應(yīng)的RTL電路圖如圖3.3。</p><p> 頻率計CPLD部分的VHDL程序設(shè)計如下:</p><p> LIBRARY IEEE;
73、 --等精度頻率計CPLD設(shè)計部分</p><p> USE IEEE.STD_LOGIC_1164.ALL; </p><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL; </p><p> ENTITY etester IS </p><p> PORT(BCLK:IN STD_LOGIC;
74、 --標(biāo)準(zhǔn)頻率時鐘信號clock2,50MHZ</p><p> TCLK:IN STD_LOGIC; --待測頻率時鐘信號</p><p> CLR:IN STD_LOGIC; --
75、清零和初始化信號</p><p> CL:IN STD_LOGIC; --當(dāng)SPUL為高電平時,CL為預(yù)置門控信號,用于測頻計數(shù)</p><p> --時間控制當(dāng)SPUL為低電平時,CL為測脈寬控制信號</p><p> --CL高電平時測高電平脈寬而當(dāng)CL為低電平時,測低電平脈寬</p><p> SPUL:IN
76、STD_LOGIC; --測頻或測脈寬控制</p><p> START:OUT STD_LOGIC; --起始計數(shù)標(biāo)志信號</p><p> EEND:OUT STD_LOGIC; --由低電
77、平變到高電平時指示脈寬計數(shù)結(jié)束</p><p> SEL:IN STD_LOGIC_VECTOR(2 DOWNTO 0); --數(shù)據(jù)讀出選同控制</p><p> DATA:OUT STD_LOGIC_VECTOR(7 DOWNTO 0)); --8位數(shù)據(jù)讀出</p><p
78、> END etester; </p><p> ARCHITECTURE behav OF etester IS </p><p> SIGNAL BZQ : STD_LOGIC_VECTOR(31 DOWNTO 0); --標(biāo)準(zhǔn)計數(shù)器</p><p> SIGNAL TSQ : STD_LOGIC_VEC
79、TOR(31 DOWNTO 0); --測頻計數(shù)器</p><p> SIGNAL ENA : STD_LOGIC; --計數(shù)使能</p><p> SIGNAL MA, CLK1, CLK2, CLK3: STD_LOGIC; </p>&
80、lt;p> SIGNAL Q1, Q2, Q3, BENA, PUL: STD_LOGIC;</p><p> SIGNAL SS: STD_LOGIC_VECTOR (1 DOWNTO 0); </p><p><b> BEGIN </b></p><p> START <= ENA; </p><p
81、> DATA <= BZQ(7 DOWNTO 0) WHEN SEL="000" ELSE --標(biāo)準(zhǔn)頻率計數(shù)低8位輸出</p><p> BZQ (15 DOWNTO 8) WHEN SEL="001" ELSE </p><p> BZQ (23 DOWNTO 16) WHEN SEL="010&qu
82、ot; ELSE </p><p> BZQ(31 DOWNTO 24) WHEN SEL="011" ELSE --標(biāo)準(zhǔn)頻率計數(shù)值最高8位輸出</p><p> TSQ(7 DOWNTO 0) WHEN SEL="100" ELSE --待測頻率計數(shù)值最低8位輸出</p><
83、;p> SQ (15 DOWNTO 8) WHEN SEL="101" ELSE </p><p> TSQ (23 DOWNTO 16) WHEN SEL="110" ELSE </p><p> TSQ(31 DOWNTO 24) WHEN SEL="111" ELSE --待測頻率計數(shù)值最
84、高8位輸出</p><p> TSQ (31 DOWNTO 24); </p><p> BZH : PROCESS(BCLK, CLR) --標(biāo)準(zhǔn)頻率測試計數(shù)器,標(biāo)準(zhǔn)計數(shù)器</p><p><b> BEGIN </b></p><p> IF CLR = '1
85、' THEN BZQ <= (OTHERS=>'0');</p><p> ELSIF BCLK'EVENT AND BCLK = '1' THEN</p><p> IF BENA = '1' THEN BZQ <= BZQ + 1; END IF;</p><p><b&
86、gt; END IF; </b></p><p> END PROCESS; </p><p> TF : PROCESS(TCLK, CLR, ENA) --待測頻率計數(shù)器,測頻計數(shù)器</p><p><b> BEGIN </b></p><p> IF
87、 CLR = '1' THEN TSQ <= (OTHERS=>‘0’); </p><p> ELSIF TCLK'EVENT AND TCLK = '1' THEN </p><p> IF ENA = '1' THEN TSQ <= TSQ + 1; END IF; </p><p>
88、;<b> END IF; </b></p><p> END PROCESS; </p><p> PROCESS (TCLK, CLR) </p><p><b> BEGIN </b></p><p> IF CLR = '1' THEN ENA <= ‘0’;
89、 </p><p> ELSIF TCLK'EVENT AND TCLK='1' THEN ENA <= CL; END IF; </p><p> END PROCESS; </p><p> MA<=(TCLK AND CL) OR NOT(TCLK OR CL) ;
90、 --測脈寬邏輯</p><p> CLK1<=NOT MA ; CLK2<=MA AND Q1 ; CLK3<=NOT CLK2; SS<=Q2 & Q3;</p><p> DD1: PROCESS (CLK1, CLR) </p><p><b> BEGIN</b></p><p
91、> IF CLR = '1' THEN Q1 <= ‘0’;</p><p> ELSIF CLK1'EVENT AND CLK1 = '1' THEN Q1 <= ‘1’; </p><p><b> END IF; </b></p><p> END PROCESS; <
92、;/p><p> DD2: PROCESS (CLK2, CLR) </p><p><b> BEGIN </b></p><p> IF CLR = '1' THEN Q2 <= ‘0’; </p><p> ELSIF CLK2'EVENT AND CLK2 = '1
93、39; THEN Q2 <= ‘1’; END IF; </p><p> END PROCESS; </p><p> DD3: PROCESS (CLK3, CLR) </p><p><b> BEGIN </b></p><p> IF CLR = '1' THEN Q3 <=
94、 ‘0’; </p><p> ELSIF CLK3'EVENT AND CLK3 = '1' THEN Q3 <= ‘1’; END IF; </p><p> END PROCESS; </p><p> PUL<='1' WHEN SS="10" ELSE</p>&l
95、t;p> --當(dāng)SS=“10”時,PUL高電平,允許標(biāo)準(zhǔn)計數(shù)器計數(shù)</p><p> '0' ; --禁止計數(shù)</p><p> EEND<='1' WHEN SS="11" ELSE </p&
96、gt;<p> --EEND為低電平時,表示正在計數(shù),由低電平變到高電平</p><p> '0'; --時,表示計數(shù)結(jié)束,可以從標(biāo)準(zhǔn)計數(shù)器中讀數(shù)據(jù)了</p><p> BENA<=ENA WHEN SPUL='1' ELSE </p><p> --標(biāo)準(zhǔn)
97、計數(shù)器時鐘使能控制信號,當(dāng)SPUL為1時,測頻率</p><p> PUL WHEN SPUL='0' ELSE --當(dāng)SPUL為0時,測脈寬和占空比</p><p><b> PUL; </b></p><p> END behav;</p><p>
98、; 利用VHDL設(shè)計的測頻模塊其中有關(guān)的接口信號規(guī)定如下:</p><p> 1、BCLK:標(biāo)準(zhǔn)頻率輸入信號,50MHz。 </p><p> 2、TCLK:待測頻率輸入信號,0.1Hz–10MHz。最高可以為50MHZ。 </p><p> 3、CLR:全局清0和初始化輸入,高電平有效,由單片機向CPLD發(fā)出。 </p><p>
99、 4、CL:預(yù)置門控制輸入,時間為1s,高電平有效,由單片機向CPLD發(fā)出。 </p><p> 5、SPUL:高電平測頻率,低電平測脈寬,由單片機向CPLD發(fā)出。 </p><p> 6、START:此信號由單片機讀取。在測頻時,高電平時表示進入計數(shù)周期,低電平時表示計數(shù)結(jié)束,單片計可以讀取CPLD中的計數(shù)。 </p><p> 7、EEND:在測脈寬期間(
100、SPUL=‘0’),由低電平變?yōu)楦唠娖剑硎久}寬計數(shù)結(jié)束,EEND信號由單片機讀取。 </p><p> 8、DATA:計數(shù)數(shù)據(jù)輸出,8位,由單片機根據(jù)SEL選擇信號分別讀取。 </p><p> 9、SEL:計數(shù)數(shù)據(jù)讀出控制,3位,由單片機輸出控制。 </p><p> 當(dāng)SEL分別等于:“000”、“001”、“010”、“011”;可由DATA分別讀出:
101、BZQ[7..0]、[15..8]、[23..16]、[31..24]共32位。 </p><p> 當(dāng)SEL分別等于:“100”、“101”、“110”、“111”;可由DATA分別讀出:TSQ[7..0]、[15..8]、[23..16]、[31..24]共32位。</p><p> 圖3.3 RTL電路圖</p><p> 3.1.2 頻率計CPLD部分
102、的仿真</p><p> 圖3.4和圖3.5分別是頻率測試仿真波形和脈寬測試仿真波形。</p><p> 從圖3.4可以看出,SPUL='1'時,系統(tǒng)進行等精度測頻。這時,CLR一個正脈沖后,系統(tǒng)被初始化。然后CL被置為高電平,但這時兩個計數(shù)器并未開始計數(shù)(START='0'),直到此后被測信號TCLK出現(xiàn)一個上升沿,START=‘1’時2個計數(shù)器同時啟
103、動分別對被測信號和標(biāo)準(zhǔn)信號開始計數(shù),其中BZQ和TSQ分別為標(biāo)準(zhǔn)頻率計數(shù)器和被測頻率計數(shù)器的計數(shù)值。由圖可見,在CL變?yōu)榈碗娖胶?,計?shù)仍未停止,直到TCLK出現(xiàn)一個上升沿為止,這時START='0',可作為單片機了解計數(shù)結(jié)束的標(biāo)志信號。</p><p> 仿真波形中TCLK和BCLK的周期分別設(shè)置為10μs和500ns。由圖可見,計數(shù)結(jié)果是,對TCLK的計數(shù)值是5,對BCLK的計數(shù)值是64(十六
104、進制)。通過控制SEL就能按照8個8位將兩個計數(shù)器中的32位數(shù)讀入單片機中進行計算。從圖中的波形可以看出,VHDL部分描述的測頻的功能完全正確。</p><p> 圖3.4 頻率/周期測量仿真圖</p><p> 圖3.5 脈寬/占空比測量仿真圖</p><p> 圖3.5中,取SPUL='0'時,則系統(tǒng)進行脈寬測試。為了便于觀察,圖中仿真波形
105、中的TCLK和BCLK的周期分別設(shè)置為75μs和500ns。由VHDL程序和RTL電路圖可以分析,CL和CLR的功能都發(fā)生了變化,前者為'1'時測信號高電平的脈寬,為'0'時測低電平的脈寬;而后者CLR變?yōu)椤?’時作系統(tǒng)初始化,由‘1’變?yōu)椤?’后啟動電路系統(tǒng)的標(biāo)準(zhǔn)信號計數(shù)器BZQ準(zhǔn)備對標(biāo)準(zhǔn)頻率進行計數(shù)。而允許計數(shù)的條件是此后出現(xiàn)的第一個脈寬的寬度。由圖3.5可見,當(dāng)CL=‘1’,TCLK的高電平脈沖到來
106、時,即啟動了BZQ進行計數(shù),而在TCLK的低電平到來時停止計數(shù),狀態(tài)信號EEND則由低電平變?yōu)楦唠娖?,告訴單片機計數(shù)結(jié)束。計數(shù)值可以通過SEL讀出,這里是4BH。</p><p> 由此不難算出,TCLK的高電平脈寬應(yīng)該等于4BH乘以BCLK的周期。改變CL為‘0’,又能測出TCLK的低電平脈寬,從而可以獲得TCLK的周期和占空比。</p><p> 3.2 單片機控制與運算程序的設(shè)計
107、</p><p> 完成VHDL硬件語言編程,系統(tǒng)內(nèi)CPLD芯片中的邏輯資源尚缺一點即可大功告成,系統(tǒng)需要單片機為它實現(xiàn)控制,運算,顯示等功能。所以,采用89C51單片機控制模塊對各種信號進行處理并顯示。</p><p> 與單片機可以按照如下方式接口:</p><p> (1) 單片機的P0口接八位數(shù)據(jù)DATA[7..0],負(fù)責(zé)讀取測頻數(shù)據(jù)。</p&g
108、t;<p> (2) 單片機可以通過信號START(P2.7),指示計數(shù)是否結(jié)束,以確定何時可以讀取數(shù)據(jù)。</p><p> (3) P2.0、P2.1、P2.2與SEL[2..0]相接,用于控制多路通道的數(shù)據(jù)選擇。當(dāng)SEL分別為“000”、“001”、“010”、“011”時,由低八位到高八位讀出標(biāo)準(zhǔn)頻率計數(shù)值;當(dāng)SEL分別為“100”、“101”、“110”、“111”;由低八位到高八位讀出
109、待測頻率計數(shù)值。</p><p> (4) EEND(P2.3)與START功能基本相同,當(dāng)其由低電平變到高電平使指示脈沖寬度計數(shù)結(jié)束。</p><p> (5) P2.5和P2.6分別接控制信號CL和SPUL。CL和SPUL協(xié)同控制測試操作。即當(dāng)為‘1’時,CL作為測脈寬控制信號。這時,CL若為‘1’,測TCLK的高電平脈寬,而當(dāng)CL為‘0’,則測TCLK的低電平脈寬。然后分別從DA
110、TA數(shù)據(jù)口讀出BZH對標(biāo)準(zhǔn)頻率的計數(shù),即只需令SEL的取值分別為 “000”、 “001”、 “010”、 “011” 即可。</p><p> (6) P0.0接清零信號CLR,高電平有效。每一測頻周期開始時,都應(yīng)該首先清零。</p><p> 3.2.1 單片機主程序的設(shè)計</p><p> 當(dāng)系統(tǒng)通過5V電源供電時,自動進入自檢狀態(tài),由單片機發(fā)出按鍵掃描
111、信號對各個按鍵進行掃描。系統(tǒng)進行初始化后,此時當(dāng)某鍵按下時,程序跳轉(zhuǎn)到相應(yīng)的子程序執(zhí)行功能,然后返回繼續(xù)執(zhí)行鍵盤掃描主程序。</p><p> 單片機控制主程序流程圖如圖3.6。</p><p> 圖3.6 單片機主程序流程圖</p><p> 3.2.2 頻率、周期計數(shù)子程序的設(shè)計</p><p> 如果按下測頻鍵,則開始測量過程:
112、首先,由單片機的P2.4發(fā)出一個清零信號P2.4=1,把計數(shù)使能信號START的預(yù)置門控信號CL置成0。然后P2.5(CL控制端)給出一個高電平的脈沖,長度控制在0.1秒至1秒之間。在此過程中,CPLD部分已經(jīng)完成測頻的任務(wù)。P2.5(CL控制端)下跳成0后,要有一個延遲時間單片機再開始讀取CPLD信息,這個延遲由單片機控制,長度要大于等于待測量信號的一個周期。然后就是讀取待測頻率的過程了,P0口負(fù)責(zé)讀取數(shù)據(jù)。 P2.0、P2.1、P2
113、.2與SEL[2..0]相接,用于控制多路通道的數(shù)據(jù)選擇。當(dāng)SEL分別為“000”、“001”、“010”、“011”時,由低八位到高八位讀出標(biāo)準(zhǔn)頻率計數(shù)值;當(dāng)SEL分別為“100”、“101”、“110”、“111”;由低八位到高八位讀出待測頻率計數(shù)值。然后單片機計算(Fs/Ns)·Nx的</p><p> 值,通過ZLG7289傳給LED顯示。</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è)計畢業(yè)論文
- 智能電子計數(shù)器的畢業(yè)論文
- 機械電子工程畢業(yè)論文-基于單片機的生產(chǎn)線成品計數(shù)器設(shè)計
- 基于單片機的紅外計數(shù)器畢業(yè)設(shè)計論文
- 基于單片機的紅外計數(shù)器畢業(yè)設(shè)計論文
- 基于單片機的計數(shù)器畢業(yè)設(shè)計
- 基于單片機的紅外計數(shù)器畢業(yè)設(shè)計論文.doc
- 畢業(yè)論文--基于51單片機的流水線產(chǎn)品計數(shù)器設(shè)計
- 畢業(yè)論文--基于51單片機的流水線產(chǎn)品計數(shù)器設(shè)計
- 基于at89s52單片機的紅外計數(shù)器畢業(yè)論文
- 基于單片機的紅外自動計數(shù)器設(shè)計
- 電子秒表畢業(yè)論文--基于單片機的電子秒表的設(shè)計
- 基于單片機的電子計算器設(shè)計【畢業(yè)論文】
- 基于單片機的智能小車設(shè)計-電子信息工程畢業(yè)論文
- 基于單片機的智能小車設(shè)計-電子信息工程畢業(yè)論文
- 單片機多功能計數(shù)器的方案畢業(yè)方案論文
- 畢業(yè)論文范文——單片機手動計數(shù)器
- 畢業(yè)論文范文——單片機手動計數(shù)器
- 電子專業(yè)畢業(yè)論文--led流水燈單片機的設(shè)計
- 基于單片機的電子時鐘設(shè)計畢業(yè)論文
評論
0/150
提交評論