a一级爱做片免费观看欧美,久久国产一区二区,日本一二三区免费,久草视频手机在线观看

新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > C8051F020高速ADC采樣的代碼優化

C8051F020高速ADC采樣的代碼優化

作者:黃玉金,董浩斌 時間:2012-01-18 來源:電子產品世界 收藏

  在應用的片內高速進行時間序列采樣時,編寫代碼使工作于最高速度是一個難題。本文從的C語言中斷模式的驅動代碼設計開始,分析對應的匯編語言中消耗CPU的主要步驟,研究ADC采樣的優化方式。經過驗證,通過使用額外定時器可以優化ADC采樣結束時機的控制;而在時間關鍵場所,因為減少了現場保護和恢復的操作代碼,查詢方式比中斷模式具有更高的時間效率。

本文引用地址:http://www.j9360.com/article/128269.htm

  引言

  在設計需要進行時間序列采樣的數據采集儀表中,需要用ADC對電壓信號進行等間隔高速采樣并緩存,帶有高速ADC的[1]是一種很好的選擇。是一款由Silicon Laboratories公司生產的高性能8位混合信號兼容MCS-51,內部集成4096字節的XRAM,以及2個帶有PGA的高速ADC,其中8位模數轉換器ADC1采樣率高達500kSPS(Sample per second)。在進行時間序列分析的應用中需要編程ADC1進行數據采集并將數據緩存到XRAM中。C8051F020的機器周期和時鐘周期相等(傳統的機器周期等于其時鐘周期的12倍),當使用24MHz的晶振時,速度最高可達到24MIPS(Million Instructions Per Second),傳統單片機僅2MIPS。雖然這個速度看起來已經很快,但是如果需要使得ADC1工作于最高頻率,代碼的編寫則需要相當的技巧。針對時間關鍵部分的編程,除了需要考慮常規的代碼優化方案[2],如循環展開、宏替換函數等之外,本文將從基本的采樣設計程序結構設計入手,研究如何在Keil集成開發環境下編寫合適的C語言代碼驅動F020的ADC1,使其工作于最高采樣率。

  ADC1高速采樣的初步時間估算

  時間序列的獲取需要進行等時間間隔采樣,也就是要編寫代碼驅動ADC1進行高速等間隔采樣并將數據存儲到有限數量的XRAM。C8051F020中沒有DMA模塊,控制ADC1采樣以及將采樣結果傳送到XRAM均需要CPU的直接操作。設定單片機系統時鐘24MHz,則其機器周期為T=1/24MHz≈41.67ns。ADC1的時鐘根據器件手冊最高可配置為6MHz[1],可由系統時鐘4分頻得到;當ADC1工作于500kHz時,采樣周期為2μs=2000ns,在該段時間如果運行單周期的指令,可以運行2000ns/41.67ns=48條指令,簡記為48T。已采樣點數計算和判斷、跳轉以及外部存儲器的訪問等操作均需要執行時間≥2T的指令,初步分析在此期間最多可以運行24條匯編指令。

  為了實現等時間間隔采樣,根據對F020數據手冊的閱讀,應該采用定時器2或3周期觸發ADC1,并在ADC1采樣結束立即將采樣結果傳送到XRAM。該類程序的設計一般有兩種模式:查詢方式和中斷方式。通常而言,中斷有利于節約CPU時間,本設計即從中斷模式設計開始分析。



評論


相關推薦

技術專區

關閉