基于C8051F340數(shù)據采集系統(tǒng)的設計
圖2 數(shù)據采集硬件原理圖。
4 軟件設計
系統(tǒng)的軟件部分包括單片機固件和上位PC 機客戶端程序。單片機固件主要負責單片機初始化及與上位機的通信準備, 而客戶端程序則負責對固件中相應控制的調用, 實現(xiàn)數(shù)據的傳輸控制、數(shù)據保存以及故障的預警。
4. 1 單片機固件( firmw are)
單片機固件采用K eil uV ision3軟件進行編寫,由主程序, AD數(shù)據轉換, USB通訊三個模塊組成。
主程序負責初始化單片機的各個端口和功能模塊, 設置相應的IO 端口為數(shù)據輸入端口, 完成各項初始化后通過vo id USB_API_TEST _ISR ( void)函數(shù)進入USB中斷服務, 在中斷服務中通過調用Get_Interrupt_Source( )函數(shù)獲得USB 中斷源。然后根據不同的入口情況, 來進行相應的處理。比如收到初始化命令時, 復位單片機內的各個狀態(tài)參數(shù)。
AD數(shù)據轉換模塊主要負責AD轉換時的轉換時間間隔、采樣精度的設置。C8051F340單片機的AD轉換啟動有6 種觸發(fā)方式, 由ADC0CN 中的ADC0轉換啟動方式位( AD0CM2..0)的狀態(tài)決定采用哪一種方式。本系統(tǒng)則是是通過單片機中的定時器2的每次計時溢出來觸發(fā)AD 轉換。為確保每次定時器觸發(fā)AD 轉換時上一次數(shù)據轉換完全結束, 因此定時器2溢出后到下一次計時溢出的時間間隔( Tcon t)必須要大于AD 轉換時間, 才能保證每次AD轉換的完整進行。AD 轉換時間由建立轉換時間( Tsettle)和采樣時間( Tsample)構成。圖3所示為在差分方式下等效的AD 轉換的輸入電路。對于一個給定的建立精度( SA ) 的系統(tǒng)中, 所需要的ADC 建立時間( Tsettle)可以用方程1來確定。而采樣時間( Tsamp le)通過查詢技術手冊得知需要10個SAR 時鐘。Tcon t則必須要滿足式( 2)和式( 3), 才能滿足設計要求。
![](http://editerupload.eepw.com.cn/fetch/20130823/162542_2_0.jpg)
圖3 AD 轉換等效輸入電路。
![](http://editerupload.eepw.com.cn/fetch/20130823/162542_2_1.jpg)
其中: SA 是建立精度, 用一個LSB 的分數(shù)表示(例如, 建立精度0. 25對應1 /4LSB ); t為所需要的建立時間( Tsettle), 以秒為單位; n為ADC 的分辨率,用比特表示。Rtota l為AMUX 電阻與外部信號源電阻之和; C samp le為ADC采樣電容:
![](http://editerupload.eepw.com.cn/fetch/20130823/162542_2_2.jpg)
其中: K 為定時器2溢出后重載的計數(shù)數(shù)值; clk 為系統(tǒng)時鐘頻率。
![](http://editerupload.eepw.com.cn/fetch/20130823/162542_2_3.jpg)
USB通訊模塊則設置單片機與主機的數(shù)據傳輸模式。根據USB 通信協(xié)議要求, 設置相應寄存器來配置USB中端點0與端點2跟上位主機進行數(shù)據通信, 其中端點0負責與主機的控制命令接收與響應, 端點2 負責將采集的數(shù)據傳輸?shù)缴衔恢鳈C, 同時配置端點2在U SB0的FIFO 分配中256字節(jié)使用空間全部為數(shù)據輸出。由于C8051F340 整合的是10位ADC控制器, 采集到的數(shù)據填充為16位數(shù)據, 以先低8 位, 后高8位將數(shù)據保存到系統(tǒng)的RAM 中, 而一次AD 轉換能得到2個字節(jié)的數(shù)據, 因此為了每次數(shù)據上傳時充分利用端點2的使用空間, 在ADC中斷響應函數(shù)中添加一個變量i來檢測進行轉換的次數(shù), 在進行完128次AD轉換后通過調用B lock_W rite( )函數(shù)向主機發(fā)送數(shù)據。部分代碼如下:
評論