資料介紹
由于曼徹斯特(MancheSTer)編碼具有傳輸時無直流分量,時鐘提取方便等特點,被廣泛地應用于以太網、車輛總線、工業總線中。現在工程上常用的曼徹斯特編譯碼芯片為HD-6408和HD-6409,但是這種芯片有一些不足。首先,該芯片在傳輸速率和每幀數據中的有效位數等方面都做了嚴格的限制。其次,使用該芯片需要增加額外的硬件電路,提高了系統成本。使用FPGA做曼徹斯特編譯碼成本高,而且開發周期長。本文提出了一種基于STM32F103RET6的編譯碼系統方案,利用了STM32F103RET6強大的定時器功能,采用靈活的編譯碼方式,傳輸速率和數據幀格式都可以根據需要完全自行定義。STM32F103RET6自帶DMA的功能使得數據編碼不再需要頻繁的定時中斷,提高了編碼速率,節約了CPU的資源。該設計方案實現方法簡單、穩定、靈活,應用范圍廣泛。
1 曼徹斯特碼
曼徹斯特編碼是一種自動同步的編碼方式即時鐘同步信號就隱藏在數據波形中。在曼徹斯特編碼中,每一位的中間有一跳變,位中間的跳變既作為時鐘信號,又作為數據信號。每個碼元均用兩個不同相位的電平信號表示,與用高、低電平表示的非歸零二進制碼相比,在連“0”或連“1”的情況下更易于提取同步時鐘信息。并且曼徹斯特碼傳輸時沒有直流分量,可以降低系統的功耗,且有很強的抗干擾能力。圖1所示是最常用的一種曼徹斯特編碼方法,當傳送信號為“1”時,曼徹斯特編碼由高電平跳變為低電平;若傳送的信息為“0”,曼徹斯特由低電平跳變為高電平,在一個數據周期內保持低電平無跳變則表示空閑。
圖1 曼徹斯特編碼
2 STM32F103RET6的定時器與DMA簡介
控制器采用ST公司的STM32微處理器,STM32系列微處理器基于ARM Cortex-M3內核,采用高效的哈佛結構三級流水線,達到1.25DMIPS /MHz,這里我們選用增強型的STM32F103RET6.它具有如下特征:72 MHz系統時鐘頻率、512 KB閃存程序存儲器、64 KBSRAM、8個定時器、3個12位模數轉換器、1個數模轉換器,1個CAN接口、7通道DMA控制器,以及SPI、USART、I2C、I2S、USB接口等。該控制器具有豐富的外設和較強的抗干擾能力,很適用于工業現場控制。
STM32F103RET6有8個定時器,每個定時器由一個可編程預分頻的1 6位自動裝載計數器構成,計數頻率高達72 MHz,它適用于多種場合包括輸入信號的脈沖長度(輸入捕獲)或者產生輸出波形(輸出比較或者PWM)。
STM32F103RET6支持DMA操作,DMA是在外沒和存儲器之間或者存儲器和存儲器之間的高速數據傳輸通道,通過DMA數據可以快速地移動而無需CPU的參與,這就節省了CPU的資源來做其他事情。本次設計便是利用計數器觸發DMA進行內存與定時器的數據交換,比起中斷查詢的方式,提高了編碼的效率和穩定性。
定時器的計數頻率最高為72 MHz,DMA傳輸速率為6 Mb/s,因此曼徹斯特編碼的速率可以很輕松的做到1 Mb/s,滿足高速編碼的需求。
3 系統實現方案
基于STM32F103RET6的曼徹斯特電壓、電流編譯碼系統框圖如圖2所示。該系統設計主要使用STM32F103RET6芯片的定時器加DMA功能來實現曼徹斯特的電壓編譯碼,對于電流編碼譯碼需要借助外圍的電壓與電流轉換電路來實現。
圖2 基于STM32F103RET6的曼徹斯特電壓、電流編譯碼系統框圖
3.1 電壓編碼
將定時器設置為輸出比較翻轉功能,申請一個緩存區,將要編碼的數據通過編碼算法轉換為翻轉匹配值放入此緩存區,如圖3所示的ABC DEF……計數值,編碼算法根據具體應用中的編碼協議來編寫。啟動定時器后,計數器開始計數,當計數值與定時器比較寄存器的值匹配時,輸出引腳的電平進行翻轉并觸發DMA從緩存區來更新比較寄存器;每更新一次,DMA指向的內存地址遞增1,指向下一次要更新到比較寄存器的數據,以此方式實現定時器根據緩存區的數據輸出對應的編碼波形。編碼速率可通過修改定時器預分頻器和RCC時鐘控制器分頻器來進行調節。
1 曼徹斯特碼
曼徹斯特編碼是一種自動同步的編碼方式即時鐘同步信號就隱藏在數據波形中。在曼徹斯特編碼中,每一位的中間有一跳變,位中間的跳變既作為時鐘信號,又作為數據信號。每個碼元均用兩個不同相位的電平信號表示,與用高、低電平表示的非歸零二進制碼相比,在連“0”或連“1”的情況下更易于提取同步時鐘信息。并且曼徹斯特碼傳輸時沒有直流分量,可以降低系統的功耗,且有很強的抗干擾能力。圖1所示是最常用的一種曼徹斯特編碼方法,當傳送信號為“1”時,曼徹斯特編碼由高電平跳變為低電平;若傳送的信息為“0”,曼徹斯特由低電平跳變為高電平,在一個數據周期內保持低電平無跳變則表示空閑。
圖1 曼徹斯特編碼
2 STM32F103RET6的定時器與DMA簡介
控制器采用ST公司的STM32微處理器,STM32系列微處理器基于ARM Cortex-M3內核,采用高效的哈佛結構三級流水線,達到1.25DMIPS /MHz,這里我們選用增強型的STM32F103RET6.它具有如下特征:72 MHz系統時鐘頻率、512 KB閃存程序存儲器、64 KBSRAM、8個定時器、3個12位模數轉換器、1個數模轉換器,1個CAN接口、7通道DMA控制器,以及SPI、USART、I2C、I2S、USB接口等。該控制器具有豐富的外設和較強的抗干擾能力,很適用于工業現場控制。
STM32F103RET6有8個定時器,每個定時器由一個可編程預分頻的1 6位自動裝載計數器構成,計數頻率高達72 MHz,它適用于多種場合包括輸入信號的脈沖長度(輸入捕獲)或者產生輸出波形(輸出比較或者PWM)。
STM32F103RET6支持DMA操作,DMA是在外沒和存儲器之間或者存儲器和存儲器之間的高速數據傳輸通道,通過DMA數據可以快速地移動而無需CPU的參與,這就節省了CPU的資源來做其他事情。本次設計便是利用計數器觸發DMA進行內存與定時器的數據交換,比起中斷查詢的方式,提高了編碼的效率和穩定性。
定時器的計數頻率最高為72 MHz,DMA傳輸速率為6 Mb/s,因此曼徹斯特編碼的速率可以很輕松的做到1 Mb/s,滿足高速編碼的需求。
3 系統實現方案
基于STM32F103RET6的曼徹斯特電壓、電流編譯碼系統框圖如圖2所示。該系統設計主要使用STM32F103RET6芯片的定時器加DMA功能來實現曼徹斯特的電壓編譯碼,對于電流編碼譯碼需要借助外圍的電壓與電流轉換電路來實現。
圖2 基于STM32F103RET6的曼徹斯特電壓、電流編譯碼系統框圖
3.1 電壓編碼
將定時器設置為輸出比較翻轉功能,申請一個緩存區,將要編碼的數據通過編碼算法轉換為翻轉匹配值放入此緩存區,如圖3所示的ABC DEF……計數值,編碼算法根據具體應用中的編碼協議來編寫。啟動定時器后,計數器開始計數,當計數值與定時器比較寄存器的值匹配時,輸出引腳的電平進行翻轉并觸發DMA從緩存區來更新比較寄存器;每更新一次,DMA指向的內存地址遞增1,指向下一次要更新到比較寄存器的數據,以此方式實現定時器根據緩存區的數據輸出對應的編碼波形。編碼速率可通過修改定時器預分頻器和RCC時鐘控制器分頻器來進行調節。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 數控直流電流源設計方案
- 基于NVM和DRAN的混合內存系統設計方案 12次下載
- 基于電流傳輸器的檢測電路設計方案 43次下載
- 簡易病房呼叫系統設計方案 15次下載
- 基于PLC的小型環保生態系統設計方案 20次下載
- 天然氣運輸站的PLC控制系統設計方案 39次下載
- 基于軟件無線電的NRLDPC編譯碼設計與實現 5次下載
- 現代USB音頻系統的機遇(含設計方案) 16次下載
- 如何使用FPGA實現結構化LDPC碼的高速編譯碼器 12次下載
- Turbo碼的編譯碼基本原理和常用編譯碼算法分析及仿真程序 19次下載
- 基于FPGA的曼徹斯特譯碼電路 1次下載
- 赫夫曼編譯碼系統的設計與實現 31次下載
- 基于Nios的通用編譯碼器的設計
- 基于FPGA曼徹斯特碼數據傳輸系統的實現
- 簡易編譯碼電路圖
- UPS系統設計方案解讀 448次閱讀
- 基于H7的曼徹斯特編碼/解碼/串口系統設計 3301次閱讀
- 基于STM32的室內空氣凈化監測系統設計方案 2258次閱讀
- 低功耗24位立體聲編譯碼器ADAU1781的主要特性及應用 2849次閱讀
- 微特電機有哪些_微特電機種類 1w次閱讀
- 微特電機的應用_微特電機結構 6639次閱讀
- 基于Turbo碼編譯碼算法的FPGA實現突發數據通信 3531次閱讀
- 外加電壓檢測復位電路設計方案 7253次閱讀
- 基于FPGA 的LDPC 碼編譯碼器聯合設計 4235次閱讀
- 基于GSM的剩余電流動作保護器檢測系統的設計方案 1380次閱讀
- 基于24V電源的雙環電流型PWM控制器的設計方案 3594次閱讀
- 基于STM32的自動量程電壓表的設計方案 1.4w次閱讀
- UHF RFID讀寫器的設計方案 3005次閱讀
- 基于高穩定電源虛擬測試系統設計方案 3247次閱讀
- 基于SVPWM算法的變頻調速系統設計方案 4800次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費下載
- 0.00 MB | 1491次下載 | 免費
- 2單片機典型實例介紹
- 18.19 MB | 95次下載 | 1 積分
- 3S7-200PLC編程實例詳細資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關電源原理及各功能電路詳解
- 0.38 MB | 11次下載 | 免費
- 6100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 7基于單片機和 SG3525的程控開關電源設計
- 0.23 MB | 4次下載 | 免費
- 8基于AT89C2051/4051單片機編程器的實驗
- 0.11 MB | 4次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費
- 4LabView 8.0 專業版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費
- 5555集成電路應用800例(新編版)
- 0.00 MB | 33562次下載 | 免費
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費
- 8開關電源設計實例指南
- 未知 | 21539次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537793次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191183次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183277次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138039次下載 | 免費
評論
查看更多