一、實驗目的 ??? ? ?? ?? ? ?? ?? ? ?? ?? ?? ? ?? ?? ?? ?? ? ?? ? ?? ?? ?? ? ?? ?? ?? ? ? ? ?? ?? ?? ? ?? ? ?? ?? ? ?? ?? ?? ? 返回
1.理解實用信號源設計的基本原理。
2.掌握實用信號源的軟件設計方法。
1.外接示波器觀察數字合成信號源產生的波形,設定不同的幅度和頻率,觀察所得波形的變化。
2.用信號源高級設置設定波形輸出。
3.使用鍵盤試驗板上的按鍵,作為信號源的控制和數字按鍵。
4.輸出要求的復雜組合波形的信號。
1.計算機?????? ?? ??? ??? ??? ???????? 1臺
2.SJ-8002B電子測量實驗箱???? ??? ?? ?? 1臺
3.鍵盤實驗板??? ??? ?? ??? ??? ?? ???? 1塊
4.數字示波器???? ?? ?? ?? ??? ?? ????? 1臺
四、實驗原理
1.直接數字合成基本原理
(1)DDS組成原理
?? 直接數字合成(Direct Digital Synthesis)的基本原理是基于取樣技術和計算技術,通過數字合成來生成頻率和相位對于固定的參考頻率可調的信號。其完整的DDS原理框圖如圖1所示。
?????? ? ?? ? ? ?? ? ?? ? ? 圖1?? DDS組成原理
?? 主要由:相位累加器、ROM波形存儲器、DAC數模轉換器以及低通濾波器組成。整體的工作原理如下:首先相位累加器根據輸入的頻率控制碼輸出相位序列,并作為波形存儲器RAM的地址,RAM里面可以是預先存放的固定波形的一個周期的幅值編碼,也可以是用戶在使用過程中存入的任意波形的幅度編碼,這樣RAM的數據線上就產生了一系列的幅度編碼數字信號,然后把該編碼經過D/A轉換得到模擬的階梯電壓,最后經過低通濾波器使其平滑后即得到所需要的模擬波形。
?? 頻率控制字和時鐘頻率共同決定著DDS輸出信號的頻率,頻率分辨率正比于系統的時鐘,而反比于相位累加器的位數。
它們之間的關系滿足:??????? ????????? ?????????????? (公式1)
相應的,其頻率分辨率為:??? ??? ??????????????????????? (公式2)
? (2)相位累加器原理
?? 如果改變地址計數器計數步進值(即以值來進行累加),則在保持時鐘頻率和ROM數據不變的情況下,可以改變每周期采樣點數,從而實現輸出頻率的改變。例如:設存儲器中存儲了個數據(一個周期的采樣數據),則地址計數器步進為1時,輸出頻率,如果地址計數步進為,則每周期取樣點數為,輸出頻率
? (3)DDS的性能
??? DDS信號源輸出的信號實際上是以時鐘的速率對波形進行取樣,從獲得的樣本值中恢復出來的。根據取樣定理,所以。實際中一般取。當時,輸出頻率最小,。輸出頻率的分辨率由相位累加器的位數決定,即 。
??? 例如:參考時鐘頻率為1GHz,累加器相位為32位,則頻率分辨力為0.233Hz。而改變時,其頻率分辨力不會發生變化,因此DDS可以解決快捷變換與小步進之間的矛盾。由于D/A、存儲器等器件的限制,DDS輸出頻率的上限不高,目前仍只能達到幾十MHz。
?? 2.信號源硬件原理圖
? ? ???? ???? ???? ??? ???? ??? ???? ???? 圖 2 ??? 硬件原理圖
?? 3.程序中高級設置輸出波形原理
?? 信號源高級設置包括波形,頻率相關(時鐘頻率,步進),幅度相關(幅度初調,幅度微調)等幾部分的設置。
?? ①頻率設置
?? 頻率設置
?????? ? ? ???
? ——輸出信號頻率。
? ——時鐘頻率,可取值80M,40M,20M,10M,5M,1.25M,625K,156.25K。
?? N——SJ—8002B主板的相位累加器是24位,故N=24。
?? K——頻率控制字,其大小? 0≤K<2N-4 。
??
?? H——步進高4位,取值范圍0~15。
?? M——步進中8位,取值范圍0~255。
?? L——步進低8位,取值范圍0~255。????????? ????
?? 例如:選擇“時鐘頻率”=80MHz,“步進高位”H=0,“步進中位”M=5,“步進低位”L=25,則可以得到頻率控制字 ,再由公式得到。
? 注意:設置的步進高位范圍是0~15,步進中位范圍是0~255,步進低位范圍是0~255。
? ②幅度設置
?? 依據公式
?? V——輸出的峰值幅度。
?? M——幅度初調(幅度分辨率),取值0.005,0.01,0.02,0.04。
?? N——幅度微調,取值范圍50~250。
?? 例如:“幅度初調”選擇為0.01N,則幅度分辨率M=0.01;“幅度微調”設定N=150,則可得輸出信號的峰值幅度? ?
? 4.矩陣式鍵盤的原理
?(1)矩陣式鍵盤
?? 鍵盤是由若干按鍵組合而成的,常采用矩陣式連接,稱為矩陣式鍵盤,即每條水平線和垂直線在交叉處通過一個按鍵加以連接。當需要的鍵數比較多時,采用矩陣連接可以減少I/O口的占用。
? (2)矩陣式鍵盤的編程
?? 矩陣式鍵盤連接可分為編碼式和非編碼式兩種。對于非編碼式連接的鍵盤,其應用編程可分為:判鍵、識鍵部分和鍵處理部分。
?? ①判鍵和識鍵
?? 即指判斷是否有鍵按下和確認所按下鍵的位置。確定矩陣式鍵盤上何鍵被按下采用一種“行掃描法”。行掃描法又稱為逐行(或列)掃描查詢法,是一種最常用的按鍵識別方法。
?? 無鍵按下時,矩陣式鍵盤的行,列線通過上拉電阻均為高電平(見圖4)。然后,依次將鍵盤逐行置低,同時取出輸入列線狀態,若此時輸入不為全高(0xFF),則表明該行有鍵被按下。因為行線輸出有低電平,一旦該行有鍵按下,則輸入線就會被拉低。這樣,就可得判斷出是否有鍵按下了。同時,可根據置低的行線和讀入的輸入線的狀態,找出被按下的鍵位置。
在判鍵過程中,還要加入按鍵去抖動處理。一次按鍵的完整過程如圖3所示(按鍵按下時,鍵盤輸入線上呈現的波形),按鍵的抖動
???????????????????? 圖3 按鍵抖動波形
包括前沿抖動(剛按下時)和后沿抖動(釋放時)兩個過程,抖動持續時間與按鍵彈簧的機械特性有關,通常為幾ms至幾十ms,可采用軟件延時的辦法進行處理。
??? ②鍵處理
??? 鍵處理即在識別到某鍵按下后,作出不同的處理。在應用上,一般將鍵盤分為功能鍵和數字鍵(也可兩者復用),功能鍵一般采用散轉的辦法,讓程序執行不同的操作。
??? 實際上,鍵盤處理是很復雜的,它往往占到一個應用程序的大部份代碼,但這種復雜不來自于設備的本身,而是來自于操作者的習慣等等問題。因此,在編寫鍵盤處理程序之前,應先把它從邏輯上理清,然后用適當的算法表示出來,最后再編寫代碼。
?? 5.矩陣式鍵盤的實驗電路
???????????????????????? ?????? 圖4?? 矩陣式鍵盤連接圖
??? 實驗電路是采用2×8的矩陣鍵盤電路,鍵盤的行線通過由74LS273鎖存器構成的輸出接口(端口地址為70H)輸出,列線通過74LS245總線接收器構成的輸入接口(端口地址為74H)輸入。鍵盤共16個鍵,定義了功能鍵:F1、F2、F3、F4、CR鍵共五個;數字鍵:0~9及小數點共十一個(如圖4所示),使用者可以自己定義每個鍵功能和相應的處理。
?? ? ?? ???? ???? ???? ??圖5 鍵盤端口地址
?右圖5為判鍵和識鍵過程中所需要用到的鍵盤地址和控制字。 本實驗共用到三個端口地址:70H:通過74LS273鎖存器,控制掃描鍵盤的行線。 74H:通過74LS245總線接收器,讀取控制掃描鍵盤的列線狀態。73H:控制鍵盤面板上的LED指示燈。
五、設計指導
?? 1.信號源高級設置部分
?? 1)結構流程圖
??????? ????????????????? 圖6??? 高級設置部分結構流程圖
??? 2)樹形圖
???? ?? ?? ?? ?? ?? ? ?? ?? ?? ?? ? 圖7?? 高級設置部分調用結構
??? 3)功能與前面板設計
? ???? ?????? ?????? ????? ????? ????? ?????? 圖8?? 高級設置前面板
表1 ? 高級設置控鍵及顯示鍵匯總
編號 |
名稱 |
功能 |
位置 |
備注 |
1 |
時鐘頻率 |
All controls>Ring&Enum>Enum |
||
2 |
步進高位 |
步進值高4位 |
All controls>Numeric>Numeric Control |
取值范圍0~15 |
3 |
步進中位 |
步進值中8位 |
All controls>Numeric>Numeric Control |
取值范圍0~255 |
4 |
步進低位 |
步進值低8位 |
All controls>Numeric>Numeric Control |
取值范圍0~255 |
5 |
幅度微調 |
All controls>Numeric>Numeric Control |
取值范圍50~250 | |
6 |
幅度初調 |
All controls>Ring&Enum>Enum |
||
7 |
啟動 |
依據參數啟動信號 |
All controls>Boolean>OK Button |
按下后依據面板上設定的值,啟動相關信號源。 |
8 |
波形選擇 |
選擇輸出的波形 |
All controls>Ring&Enum>Menu Ring |
選擇16種波形中1種。 |
9 |
圖形框 |
顯示所選波形示意圖 |
All controls>Graph>Waveform Graph |
設置參數:X軸:0~502,Y軸:-10~266。 |
??? 注:2通道的情況與1通道類似。
?? 4)動態調用鏈接
??? 本程序設計的主要實現已經做成底層fp函數(用Labwindows/CVI實現),在程序實現時可直接調用實驗箱提供的驅動函數動態鏈接(即.dll函數),驅動函數原型及常數和變量在cvidll.prj中。
?? ??? ??? ??? ??? ??? ??? ?? ???? 表2?? 高級設置中動態調用說明
fp函數 |
實現功能 |
輸入參數 |
輸出參數 |
參數說明 |
動態鏈接圖標 |
void inti_wave1 |
初始化信號源,把波形數據寫入SRAM |
int DDS_channle |
無 |
||
void profession_source |
依據相關參數,啟動信號源 |
int DDS_channle |
無 |
Clk_cw:時鐘選擇的控制字。 |
?
?? 2.信號源鍵盤控制部分
圖12 信號源鍵盤控制部分結構流程圖
??? 2)樹形圖
?????? ???? ????? ???? ????? ????? 圖13? 信號源鍵盤控制部分結構樹形圖
???? 3)功能與前面板設計
圖14??? 信號源鍵盤控制部分前面板
表3?? 信號源鍵盤控制部分控鍵及顯示鍵匯總
編號 |
名稱 |
功能 |
位置 |
備注 |
1 |
波形選擇 |
選擇輸出的波形 |
All controls>Ring&Enum>Menu Ring |
選擇16種波形中1種。 |
2 |
波形指示燈 |
顯示正在通過鍵盤板設置波形 |
All controls>Boolean>Round LED |
|
3 |
峰值幅度 |
設置波形幅度 |
All controls>Numeric>Numeric Control |
|
4 |
幅度指示燈 |
顯示正在通過鍵盤板設置幅度 |
All controls>Boolean>Round LED |
|
5 |
信號頻率 |
設置信號頻率 |
All controls>Numeric>Numeric Control |
|
6 |
頻率指示燈 |
顯示正在通過鍵盤板設置信號頻率 |
All controls>Boolean>Round LED |
|
7 |
啟動 |
依據參數啟動信號 |
All controls>Boolean>OK Button |
按下后依據面板上設定的值,啟動相關信號源。 |
8 |
頻率按鍵輸入 |
通過鍵盤板輸入的字串,來給頻率賦值。 |
All controls>string & path>String Indicator |
|
9 |
啟動指示燈 |
顯示鍵盤板上啟動鍵已經按下 |
All controls>Boolean>Round LED |
|
10 |
幅度按鍵輸入 |
通過鍵盤板輸入的字串,來給幅度賦值。 |
All controls>string & path>String Indicator |
|
11 |
圖形框 |
顯示所選波形示意圖 |
All controls>Graph>Waveform Graph |
設置參數:X軸:0~502,Y軸:-10~266。 |
12 |
退出 |
退出整個程序 |
All controls>Boolean>OK Button |
?? 4)動態調用鏈接
?? 本程序設計的主要實現已經做成底層fp函數(用Labwindows/CVI實現),在程序實現時可直接調用實驗箱提供的驅動函數動態鏈接(即.dll函數),驅動函數原型及常數和變量在cvidll.prj中。
????????? ??? ?? ?? ?? ???? 表4?? 信號源鍵盤控制部分使用的動態調用一覽
fp函數 |
實現功能 |
輸入參數 |
輸出參數 |
參數說明 |
動態鏈接圖標 |
void epp_init |
初始化EPP接口 |
無 |
無 |
||
void epp_write_data |
將數據data輸出(寫入)到sj8002的端口地址sj8002addr。 |
Unsigned char sj8002addr, unsigned char data |
sj8002addr: sj8002的端口地址。 |
||
void easy_source |
依據相關參數,啟動信號源 |
int DDS_channle |
無 |
Amp:信號幅值,單位V。 |
void inti_wave1 |
初始化信號源,把波形數據寫入SRAM |
int DDS_channle |
無 |
?? 3.信號源公式輸入部分
??????? 圖22????? 信號源公式輸入部分結構流程圖
2)樹形圖
????????? 圖23? 信號源公式輸入部分結構樹形圖
?? 3)功能與前面板設計
圖24??? 信號源公式輸入部分前面板
表5?? 信號源公式輸入部分控鍵及顯示鍵匯總
編號 |
名稱 |
功能 |
位置 |
備注 |
1 |
公式錯指示燈 |
公式編輯窗口公式輸入錯誤。 |
All controls>Boolean>Round LED |
|
2 |
波形公式輸入 |
通過鍵盤板輸入的字串,來給幅度賦值。 |
All controls>string & path>String Control |
|
3 |
頻率f |
設置信號頻率 |
All controls>Numeric>Numeric Control |
|
4 |
峰值幅度 |
設置波形幅度 |
All controls>Numeric>Numeric Control |
|
5 |
頻率系數k |
設置頻率系數 |
All controls>Numeric>Numeric Control |
若公式為周期函數,則輸出信號頻率為“頻率”ד頻率系數”。否則輸出信號頻率就等于“頻率”。 |
6 |
啟動 |
依據參數啟動信號 |
All controls>Boolean>OK Button |
若公式輸入正確,按下后依據相關參數,啟動1通道信號源。 |
7 |
圖形框 |
顯示所選波形示意圖 |
All controls>Graph>Waveform Graph |
橫坐標為時間t:0~1 |
注:公式編輯器設定的采樣頻率FT=4096,采樣點數為4096。
?? 4)動態調用鏈接
??? 本程序設計的主要實現已經做成底層fp函數(用Labwindows/CVI實現),在程序實現時可直接調用實驗箱提供的驅動函數動態鏈接(即.dll函數),驅動函數原型及常數和變量在cvidll.prj中。
????????? ????????? ?????? 表6?? 信號源鍵盤控制部分使用的動態調用一覽
fp函數 |
實現功能 |
輸入參數 |
輸出參數 |
參數說明 |
動態鏈接圖標 |
void double_to_int |
歸一化數組:double數據組變為 最大值為4000的int數組 |
double doublein[], int points, |
int inout[] |
doublein[]:輸入的double型數組。 |
|
void easy_source |
依據相關參數,啟動信號源 |
int DDS_channle |
無 |
Amp:信號幅值,單位V。 |
|
void inti_wave1 |
初始化信號源,把波形數據寫入SRAM |
int DDS_channle |
無 |
?
?? 在執行過程中寫入SRAM的文件為二進制文件形式。面板上顯示所調用的文件是由數組生成的波形文件。其中,各寫入SRAM的波形資料見下表:
?????????? ?????????? ???????????? 表7?? 波形存儲一覽
波形 |
存儲編號 |
文件名 |
正弦波 |
1 |
寫入波形文件1.bin |
方波 |
2 |
寫入波形文件1.bin |
鋸齒波 |
3 |
寫入波形文件1.bin |
全波整流 |
4 |
寫入波形文件1.bin |
調幅波 |
5 |
寫入波形文件1.bin |
調頻波 |
6 |
寫入波形文件1.bin |
窄脈沖波 |
7 |
寫入波形文件1.bin |
臺階波 |
8 |
寫入波形文件2.bin |
三角波 |
1 |
寫入波形文件2.bin |
梯形波 |
2 |
寫入波形文件2.bin |
M波 |
3 |
寫入波形文件2.bin |
對數波 |
4 |
寫入波形文件2.bin |
鐘形波 |
5 |
寫入波形文件2.bin |
辛克波 |
6 |
寫入波形文件2.bin |
高斯噪聲 |
7 |
寫入波形文件2.bin |
直流 |
8 |
寫入波形文件2.bin |
? 注:各種波形存儲位置:4096×(存儲編號-1)~ 4095×存儲編號。
六、調試與測試
?? 1、信號源高級設置部分
??? ①按如圖方式,進行硬件連線。
????????????????????
?????????????????????????
? ?????????????????????????? 圖28? 信號源高級設置實驗時的硬件連線
?? ②依據前面描述的原理,分別設定1通道各參數,點擊啟動,觀察示波器顯示的值是否與計算的一致。
?? ③對于2通道,重做②描述的過程。
?? ④完成下面的表格
??????? ?????? ??????????? ??? ???? 表8?? 信號源高級設置的數據觀察記錄表
要求信號頻率 (Hz) |
信號幅度(峰值)V |
選擇 |
步進 |
步進 |
步進 |
測試輸出信號頻率(KHz) |
幅度初調 |
幅度微調 |
輸出信號幅度峰值(V) |
100 |
1 |
1.25M |
|||||||
2K |
2.5 |
20M |
|||||||
2K |
4 |
5M |
|||||||
80K |
6 |
20M |
?? 2、鍵盤控制部分
?? 鍵盤板在控制波形產生時的格鍵含義
表9?? 鍵盤各鍵復用一覽
按鍵名稱 |
復用功能 |
備注 |
F1 |
波形設置 |
|
F2 |
幅度設置 |
|
F3 |
頻率設置 |
|
F4 |
啟動信號源 |
|
CR |
輸入確認 |
表明幅度,頻率輸入結束或波形已經選定。 |
。 |
小數點 |
頻率或幅度輸入時代表小數點 |
0 |
數字0和正弦波 |
波形設置時代表選取正弦波 |
1 |
數字1和方波 |
波形設置時代表選取方波 |
2 |
數字2和鋸齒波 |
波形設置時代表選取鋸齒波 |
3 |
數字3和全波整流 |
波形設置時代表選取全波整流 |
4 |
數字4和窄脈沖波 |
波形設置時代表選取窄脈沖波 |
5 |
數字5和三角波 |
波形設置時代表選取三角波 |
6 |
數字6和梯形波 |
波形設置時代表選取梯形波 |
7 |
數字7和M波 |
波形設置時代表選取M波 |
8 |
數字8和鐘形波 |
波形設置時代表選取鐘形波 |
9 |
數字9和辛克波 |
波形設置時代表選取辛克波 |
- ??????
- 按如圖方式,進行硬件連線。
?????????????????????? 圖29?? 鍵盤輸入實驗時的硬件連線
?? ②按下F1鍵選擇波形,觀察“波形設置”燈亮后,通過按鍵選擇波形,確定后,按下CR鍵,燈熄滅,表示波形選擇結束。
?? ③按下F2鍵準備輸入幅度,觀察“幅度設置”燈亮后,通過按鍵輸入幅度值,此時輸入顯示在“幅度按鍵輸入”框,并同時由字串轉化為數字,顯示在“峰值幅度”框(注意字串不要輸錯)。若輸入結束,按下CR鍵,燈熄滅,表示幅度設定。
?? ④按下F3鍵準備輸入頻率,觀察“頻率設置”燈亮后,通過按鍵輸入幅度值,此時輸入顯示在“頻率按鍵輸入”框,并同時由字串轉化為數字,顯示在“頻率”框(注意字串不要輸錯)。若輸入結束,按下CR鍵,燈熄滅,表示頻率設定。
?? ⑤按下F4鍵啟動信號源,此時“啟動指示”燈亮,然后熄滅,觀察此時波形顯示框的波形是否與選定波形一致,同時觀察外部的示波器,檢查頻率、幅度、波形是否與設定的值相同。
?? ⑥直接在程序面板上輸入波形、幅度、頻率,然后點擊啟動按鍵,觀察此時波形顯示框的波形是否與選定波形一致,同時觀察外部的示波器,檢查頻率、幅度、波形是否與設定的值相同。
?? ⑦完成下表
????????????????????????????????? 表10? 鍵盤控制波形輸出的數據觀察記錄表
輸出波形 |
設定信號幅度(V) |
設定信號頻率(kHz) |
輸出是否正確 |
正弦波 |
2 |
100 |
|
三角波 |
3 |
40 |
|
鐘形波 |
5 |
50 |
|
辛克波 |
4 |
60 |
?? 3、公式輸入部分
??? ①按如圖方式,進行硬件連線。
???????????????????????????
??????????????????????????????????????? 圖30?? 公式輸入實驗時的硬件連線
?? ②在波形公式框輸入任意周期信號,例如cos(w×t),設置峰值幅度、頻率和頻率系數,,按下啟動按鍵,觀察示波器的頻率是否為頻率×頻率系數,峰值幅度,波形是否與設定的一致。
?? ③在波形公式框輸入任意周期信號,例如t+t^2,設置峰值幅度、頻率和頻率系數,,按下啟動按鍵,觀察示波器的頻率、峰值幅度、波形是否與設定的一致。
?? ④完成下表。
??????? ???? ????? ????? ???? ??? 表11?? 通過公式產生波形的數據觀察記錄表
設定的波形 |
設定信號幅度(V) |
設定信號頻率(kHz) |
設定的頻率系數 |
輸出信號頻率(KHZ) |
輸出是否正確 |
Sin(w*t) |
2 |
10 |
2 |
20 |
|
cos(3*w*t) |
3 |
4 |
5 |
60 |
|
sin(w*t)*sin(2*pi(1)*t) |
4 |
3 |
20 |
60 |
|
T+t^4 |
1 |
60 |
1 |
60 |
七、備注
?? 注意:數字合成信號源的輸出信號頻率范圍:正弦在1Hz~2MHz,方波在1Hz~500KHz,其它波形在1Hz~200KHz范圍內。峰值幅度范圍0.1V~8V,設定各參數時需保證輸出信號在此范圍內。同時調幅波載波頻率為輸入頻率的16倍,調頻波載波頻率為輸入頻率的7~25倍。
評論
查看更多