<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          關 閉

          新聞中心

          EEPW首頁 > 工控自動化 > 設計應用 > 基于FPGA和USB 2.0的高速CCD聲光信號采集系統(tǒng)

          基于FPGA和USB 2.0的高速CCD聲光信號采集系統(tǒng)

          作者: 時間:2009-09-22 來源:網絡 收藏

          3 軟件設計
          軟件設計包括:
          固件程序(Firmware)設計 設備固件的主要功能是控制CY7C68013A接收并處理驅動程序的請求。如請求設備描述符,請求或設置設備狀態(tài),請求或設置設備接口等 2.0標準請求;輔助硬件完成設備的重新枚舉、端點配置、控制和監(jiān)測的活動,根據PC主機的命令與外圍電路進行數據交換等。Cy-press公司為用戶提供了一個固件程序框架,是通用性強的模塊化程序。在框架的基礎上,用戶只需要編寫Function.c文件即可完成USB功能開發(fā)。主要包括:Slave FIFO模式的初始化和用戶自定義請求。
          驅動程序開發(fā) 包括兩個USB驅動程序:一個驅動專用于下載芯片的固件程序ccdloader.sys,另一個通用驅動程序ccdusb.sys用來實現USB設備與應用程序的通信和控制。芯片固件程序在主機上,當系統(tǒng)上電時,前者將其下載到芯片的RAM中,并由增強型8051微處理器執(zhí)行。當固件下載完成后,模擬一次斷開重新連接,此時下載的固件響應USB枚舉,并加載USB設備通用驅動程序。USB的驅動程序是WDM類型,可以使用Windows DDK,WinDriver,DriverStudio開發(fā)。
          應用程序開發(fā) 它的主要任務是與USB驅動程序通信,控制過程。在此用Visual C++6.0進行程序設計。CyAPI控制函數類為FX2LP系列USB接口芯片提供了十分精細的控制接口,只需在應用程序中加頭文件CyAPI.h和庫文件CyAPI.lib即可調用相應的控制函數,打開USB設備讀取數據并存儲到主機硬盤中的CcdData.txt文件。

          4 實驗數據分析
          使用TEKTRONIX公司的示波器,對經過隔直處理后的RL2048P輸出在各種實驗條件下進行了測試和分析。如圖2所示,VOUT為像元輸出,每一個像元輸出信號的開始都有一個同步參考信號,后面部分才為有效信號輸出,由于輸出信號為負極性信號,所以有效信號值相對于參考信號為負。
          圖5為全暗條件RL2048P的輸出,由于光敏面上沒有光,只有暗電平信號輸出,所以像元的輸出有效信號幾乎為零。圖6為弱光條件RL2048P的輸出,有效信號幅值發(fā)生了變化。圖7為全亮條件RL2048P的輸出,有效信號到達了飽和值。RL2048P的實際輸出和理論分析一致,工作正常。信號通過中間有孔的不透光遮擋板照在上,使用應用軟件進行數據。從 Data.txt數據文件中連續(xù)提取8 192個像元點即四幀CCD數據,Matlab軟件分析如圖8所示。

          有光照射的位置對應為高,實測數據和理論值吻合。在其他條件下也做相關實驗,結果與理論基本一致。由于篇幅所限,本文不做詳細介紹。實驗結果表明,系統(tǒng)功能完整,可以實現信號的、傳輸及儲存。

          5 結 語
          系統(tǒng)采用現場作為硬件設計核心,使用Veritog語言。進行硬件描述,使系統(tǒng)更靈活,可在線編程,便于擴展和升級。這里的CCD驅動時序采用狀態(tài)機與分頻相結合的新方法,實際測試驅動波形穩(wěn)定且沒有毛刺,CCD輸出信號質量高。USB應用于Slave FIFO傳輸模式,滿足了CCD聲光信號采集的要求,具有實時性、高速、穩(wěn)定、可靠等特點。


          上一頁 1 2 下一頁

          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();