《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > STM32的曼徹斯特編譯碼系統設計
STM32的曼徹斯特編譯碼系統設計
摘要: 利用ARM芯片STM32F103RET6設計了曼徹斯特電壓/電流編譯碼系統。該系統簡單易行,成本低,傳輸速率可調范圍廣,編碼速率可達1Mb/s.當編碼協議發生變化,只需對編碼和譯碼算法做少量的修改,具有很強的靈活性和通用性。
Abstract:
Key words :
  引言

  由于曼徹斯特(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時鐘控制器分頻器來進行調節。

圖3 編輯示例

  3.2 電壓譯碼

  將定時器設置為輸入捕獲功能,當曼徹斯特碼的上升沿或下降沿到來時定時器會將當前的計數值進行捕獲,并經由DMA通道傳輸到緩存區;主程序中會調用譯碼算法來對緩存區的數據進行處理并進行譯碼,譯碼作為編碼的逆過程,其譯碼算法也要根據具體應用中的編碼協議來編寫。

  3. 3 電流編碼

  將電壓編碼通過圖4所示的電壓/電流轉換電路來實現,將定時器輸出的曼徹斯特電壓編碼轉換為曼徹斯特電流碼。

圖4 電壓/電流轉換電路

  3.4 電流譯碼

  將待測的曼徹斯特電流碼信號通過電流/電壓轉換為電壓碼,進行整形使邊緣變陡峭后交MCU來譯碼,電流/電壓轉換電路如圖5所示。

 

圖5 電流/電壓轉換電路

  4 軟件設計

  軟件流程如圖6所示。系統初始化包括時鐘初始化、定時器初始化、DMA初始化等。如果一次性連續編碼的數據最比較大時,應將這罩的DMA緩沖區設置為雙緩沖,為每個用到的DMA通道開辟兩個緩沖區。當DMA使用其中的一個緩沖區時,MCU調用編碼或者譯碼算法來對另外一個緩沖區進行讀寫操作;當DMA數據傳輸完畢的時候,發生一個DMA傳輸結束中斷,在中斷服務程序里切換到另外一個緩沖區,并將編碼算法或者譯碼算法標志位置位。當主程序查詢到標志位置位后,MCU調用編碼或者譯碼算法來對DMA先前指向的緩沖區進行處理(填充數據或者取數據)。當然,如一次性編碼或者譯碼的數據不是很多時,我們只需一個緩沖區就夠了。

 

 

  因為CPU處理數據的速度要高于編碼的速率,所以CPU可以空出時間來做其他的事情,時間的長短依賴于緩沖區的大小和編碼的速率,等到主程序中查詢到編碼或者譯碼標志位置位了再去執行編碼或者譯碼算法對數據進行處理,這樣就提高了CPU的工作效率。在實時性要求不高的應用中,不再需要一個專門的CPU去處理編碼或者譯碼。

  5 方案驗證

  本方案已在汽車加速度傳感器模擬系統中得到了驗證,這里以某款加速度傳感器的曼徹斯特編碼協議為例,其數據幀格式為一幀數據為19位包括:2個起始位、2個類別位、10個數據位、5個CRC效驗位。

  5.1 編碼方案驗證

  對圖4所示電路的T1點測量曼徹斯特電壓編碼的波形,電流編碼的波形通過測量T2、T3問的壓降來間接測量。

  對一幀數據0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 1 1 1連續編碼,幀之間延時6μs,編碼速率400kb/s,編碼波形如圖7所示。

  5.2 譯碼方案驗證

  通過對某真實傳感器輸出的曼徹斯特電流碼進行捕獲譯碼,得到其ID信息,譯碼數據如圖8所示。ID正確,譯碼成功。

  結語

  該沒計方案可以方便地實現曼徹斯特電壓、電流編碼譯碼,實現方法靈活、可靠,適用于各種類型的曼徹斯特編碼譯碼應用領域。目前,本設計方案已經成功地應用在汽車加速度傳感器模擬系統中。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品欧美久久| 亚洲国产精品专区久久| 欧美成人免费播放| 久久人人97超碰国产公开结果| 亚洲欧美另类在线观看| 亚洲视频欧美视频| 一区二区三区四区精品| 日韩视频一区二区三区在线播放| 久久成人亚洲| 欧美中文字幕在线观看| 性色av一区二区怡红| 亚洲欧美日韩在线不卡| 午夜电影亚洲| 香蕉亚洲视频| 午夜精品亚洲一区二区三区嫩草| 亚洲免费影院| 午夜在线不卡| 久久激情一区| 亚洲激情网址| 日韩一级大片| 亚洲先锋成人| 亚洲欧美日韩在线高清直播| 亚洲欧美中文日韩v在线观看| 先锋影音国产一区| 久久av一区二区| 久久精品国产一区二区三| 久久精品国产精品| 久久综合99re88久久爱| 男人的天堂成人在线| 欧美不卡福利| 欧美欧美全黄| 国产精品videosex极品| 国产精品综合| 雨宫琴音一区二区在线| 最新亚洲一区| 亚洲一区日韩| 欧美中文字幕| 亚洲欧洲一区二区三区久久| 日韩一级片网址| 亚洲欧美久久久久一区二区三区| 午夜精品婷婷| 久久在线免费观看| 欧美极品在线播放| 国产精品区二区三区日本| 国产有码一区二区| 亚洲激情中文1区| 亚洲色图制服丝袜| 久久xxxx| 一本色道婷婷久久欧美| 欧美一区二区| 免费日韩成人| 欧美先锋影音| 国模套图日韩精品一区二区| 亚洲精品国产系列| 亚洲专区在线视频| 亚洲高清免费视频| 亚洲婷婷在线| 久久精品亚洲一区二区| 欧美激情在线免费观看| 国产欧美69| 亚洲第一天堂无码专区| 一区二区三区视频观看| 久久精品官网| 亚洲视频久久| 久久亚洲综合色| 欧美日韩免费区域视频在线观看| 国产亚洲毛片| 亚洲精品资源| 欧美在线日韩精品| 亚洲视频网站在线观看| 久久久综合网站| 国产精品99免费看| 亚洲国产成人av好男人在线观看| 亚洲一区二区三区在线播放| 亚洲黄色一区| 欧美在线精品一区| 欧美日韩精品高清| 狠狠色综合网站久久久久久久| 日韩亚洲视频| 亚洲国产精品成人| 午夜精品福利电影| 欧美激情精品久久久久久久变态 | 亚洲精品久久久久久一区二区| 亚洲女同性videos| 一区二区欧美日韩视频| 久热国产精品| 国产欧美视频一区二区| 99精品国产福利在线观看免费| 亚洲国产99精品国自产| 久久国产精品72免费观看| 欧美三级在线视频| 亚洲国产精品va在线看黑人 | 国产精品一香蕉国产线看观看| 亚洲经典一区| 亚洲第一网站免费视频| 欧美一区二区在线视频| 欧美日韩亚洲免费| 亚洲激情在线播放| 亚洲国产精品小视频| 久久精品成人一区二区三区蜜臀 | 午夜精品美女自拍福到在线| 欧美日韩亚洲一区二区三区在线观看 | 国产精品多人| 亚洲精品一区二| 亚洲日本欧美日韩高观看| 久久久av毛片精品| 国产伦精品一区二区三区照片91 | 国产伦精品一区二区三区视频孕妇 | 99re热这里只有精品视频| 亚洲美女一区| 欧美成人精品高清在线播放| 狠狠做深爱婷婷久久综合一区 | 欧美一区二区三区四区夜夜大片| 性感少妇一区| 国产精品视频你懂的| 一区二区三区久久| 亚洲午夜成aⅴ人片| 欧美日韩一区二区国产| 亚洲美女少妇无套啪啪呻吟| 99riav久久精品riav| 欧美精品在线视频观看| 亚洲日本va午夜在线影院| 亚洲精品在线三区| 欧美欧美全黄| 99国产精品自拍| 亚洲摸下面视频| 国产精品人成在线观看免费 | 国产女主播一区二区三区| 午夜精品久久久久久久久 | 国产午夜精品视频| 欧美一区二区免费视频| 久久婷婷丁香| 影音先锋中文字幕一区| 亚洲国内精品在线| 欧美高清不卡| 亚洲美女电影在线| 亚洲欧美日本国产有色| 国产精品一国产精品k频道56| 亚洲欧美在线视频观看| 久久久久久亚洲精品不卡4k岛国| 韩国视频理论视频久久| 亚洲欧洲美洲综合色网| 欧美精品一卡二卡| 亚洲小说欧美另类社区| 久久国产精品99国产精| 亚洲第一在线综合网站| 一本久久a久久免费精品不卡| 欧美日韩午夜剧场| 亚洲欧美在线高清| 狼狼综合久久久久综合网| 亚洲人成小说网站色在线 | 欧美在线亚洲| 一区精品在线| 一本色道久久综合精品竹菊| 国产精品你懂得| 久久国产精品黑丝| 欧美精品久久久久久久久老牛影院| 一本久久知道综合久久| 欧美专区在线播放| 亚洲国产色一区| 亚洲欧美在线x视频| 激情欧美丁香| 亚洲视频在线观看免费| 国产一级一区二区| 日韩午夜激情av| 国产老女人精品毛片久久| 91久久精品www人人做人人爽| 欧美日韩亚洲一区二区| 亚洲欧美一区二区三区在线| 免费亚洲电影在线观看| 一本到高清视频免费精品| 久久理论片午夜琪琪电影网| 亚洲精品日本| 久久久91精品| 日韩一级精品视频在线观看| 久久激情一区| 99re热这里只有精品免费视频| 久久精品国产久精国产爱| 欧美日韩一区在线观看| 久久国产精品第一页| 欧美视频免费在线| 久久精品亚洲一区二区| 欧美午夜免费影院| 亚洲国产午夜| 国产色视频一区| 亚洲私拍自拍| 在线观看一区二区精品视频| 亚洲欧美日韩一区| 亚洲精品美女| 蜜臀久久99精品久久久久久9| 亚洲一区国产视频| 欧美剧在线观看| 亚洲电影天堂av| 国产欧美日韩一区二区三区在线观看| 亚洲精品一区二区三区不| 国产亚洲免费的视频看| 亚洲一区二区三区精品动漫| 亚洲国产导航| 久久久久一区二区三区四区| 欧美一级播放|