《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 可編程邏輯 > 設(shè)計(jì)應(yīng)用 > CPLD 在時(shí)柵位移傳感器中的應(yīng)用
CPLD 在時(shí)柵位移傳感器中的應(yīng)用
摘要: 基于CPLD的數(shù)字信號(hào)處理電路智能時(shí)柵位移傳感器內(nèi)部基于CPLD的數(shù)字信號(hào)處理電路,。電路采用雙MCU+CPLD結(jié)構(gòu)設(shè)計(jì),內(nèi)部嵌入主從式兩塊單片機(jī),,副MCU負(fù)責(zé)數(shù)據(jù)采集與預(yù)處理工作,,主MCU通過(guò)接口電
關(guān)鍵詞: CPLD 時(shí)柵位移傳感器
Abstract:
Key words :
智能時(shí)柵位移傳感器內(nèi)部基于CPLD的數(shù)字信號(hào)處理電路。電路采用雙MCU+CPLD結(jié)構(gòu)設(shè)計(jì),,內(nèi)部嵌入 主從式兩塊單片機(jī),,副MCU負(fù)責(zé)數(shù)據(jù)采集與預(yù)處理工作,主MCU通過(guò)接口電路與外界實(shí)現(xiàn)數(shù)據(jù)交換,。動(dòng),、定測(cè)頭感應(yīng)到的微弱信號(hào)經(jīng)放大、自動(dòng)增益控制,、濾波 和整形等預(yù)處理電路后,,得到供數(shù)字電路處理的方波信號(hào)。兩路方波信號(hào)送入CPLD進(jìn)行處理,,CPLD包括雙路比相器,、脈沖當(dāng)量計(jì)量電路、計(jì)數(shù)電路,、總線收 發(fā)三態(tài)控制電路等4個(gè)功能模塊。


CPLD芯片選用Altera公司的MAX7000S系列器件EPM7128SLC84,它有128個(gè)邏 輯宏單元,,邏輯門(mén)數(shù)為2500門(mén),,在MAX+PLUSII軟件環(huán)境下,采用VHDL和原理圖輸入相結(jié)合的方法進(jìn)行設(shè)計(jì),。設(shè)計(jì)輸入完成后,,進(jìn)行整體的編譯和 邏輯仿真,然后進(jìn)行轉(zhuǎn)換,、布局,、布線、延時(shí)仿真生成配置文件,,最后以4引腳的JTAG接口方式通過(guò)ByteBlaster下載電纜對(duì)CPLD進(jìn)行在線編程 (ISP),,完成結(jié)構(gòu)功能配置,實(shí)現(xiàn)其硬件功能,,制成專用芯片,。為了避免器件內(nèi)的設(shè)計(jì)被他人復(fù)制和取出,可通過(guò)對(duì)MAX7128S內(nèi)部的一個(gè)保密位編程,, 對(duì)設(shè)計(jì)進(jìn)行加密,。當(dāng)對(duì)器件重新編程時(shí),保密位連同其它的編程數(shù)據(jù)均能擦除和重寫(xiě),。

動(dòng),、定測(cè)頭方波信號(hào)分別從DO_INPUT和 DI_INPUT端輸入CPLD,采樣信號(hào)INT0_OUT由定測(cè)頭信號(hào)DI_INPUT反相得到,,通過(guò)雙路比相器獲取動(dòng)測(cè)頭信號(hào)DO_INPUT的上,、 下沿至采樣時(shí)刻的相位差信號(hào)。Fai_OUT1,、Fai_OUT2信號(hào)表示插入高頻細(xì)分脈沖信號(hào)后的相位差信號(hào),,高頻時(shí)鐘脈沖由CLK端輸入,通過(guò)2路帶 允許端的20位同步計(jì)數(shù)器分別對(duì)插入的細(xì)分脈沖進(jìn)行計(jì)數(shù),。每一個(gè)脈沖所代表的角度大小由脈沖當(dāng)量計(jì)量電路來(lái)確定,,用于計(jì)算脈沖當(dāng)量的Ti_OUT1信號(hào)由 DI_INPUT信號(hào)二分頻得到。

EPM7128SLC84輸出信號(hào)INT0_OUT與副MCU第12腳P3.2相連,,每一脈沖下降沿觸 發(fā)副MCU中斷一次,。通過(guò)對(duì)各信號(hào)邏輯時(shí)序的分析,可以看出:動(dòng),、定測(cè)頭方波信號(hào)頻率為50Hz,,為保證時(shí)柵位移傳感器能正常工作,MCU必須每20ms 中斷一次(若信號(hào)頻率為400Hz,,中斷時(shí)間間隔為2.5ms),,也就是說(shuō)MCU用于處理數(shù)據(jù)的時(shí)間只有20ms,。MCU做多字節(jié)除法、乘法運(yùn)算時(shí),,運(yùn)行 時(shí)間較長(zhǎng),,且用于單片機(jī)與計(jì)算機(jī)間數(shù)據(jù)通信的時(shí)間就至少需要10ms,因此20ms時(shí)間MCU無(wú)法處理完全部工作,。處理時(shí)間不夠就會(huì)導(dǎo)致死機(jī),,傳感器無(wú)法 工作,實(shí)踐也證明了這一點(diǎn),。

解決這一問(wèn)題的方法通常是采取硬件分頻,,信號(hào)分頻后,相應(yīng)周期加倍,,供MCU處理數(shù)據(jù)的時(shí)間加長(zhǎng),。但在本設(shè)計(jì)中,無(wú)論是將動(dòng),、定測(cè)頭方波信號(hào)同時(shí)分頻或僅將引起MCU中斷的信號(hào)分頻,,均無(wú)法保證同時(shí)采集到正確的3個(gè)數(shù)據(jù)。

基 于此,,本文提出采用“軟件分頻”來(lái)解決這一問(wèn)題,,這也是采用雙MCU的關(guān)鍵原因之一。中斷信號(hào)INT0_OUT每20ms觸發(fā)副MCU中斷一次,,每4次中 斷采集一次數(shù)據(jù),,前面3次中斷時(shí)副MCU通過(guò)程序判斷中斷次數(shù)而進(jìn)行相應(yīng)處理,為第4次中斷時(shí)采集數(shù)據(jù)作準(zhǔn)備,,第4次中斷時(shí)在中斷服務(wù)程序中采集數(shù)據(jù),,包 括φ1、φ2和Ti等3個(gè)參數(shù),。其中,,φ1、φ2和Ti分別代表一個(gè)信號(hào)周期內(nèi)插入Fai_OUT1,、Fai_OUT2和Ti_OUT1中的時(shí)鐘脈沖個(gè) 數(shù),。副MCU對(duì)數(shù)據(jù)進(jìn)行預(yù)處理后,通過(guò)P3.1腳觸發(fā)主MCU中斷,,接收副MCU傳送的數(shù)據(jù),,這樣,主MCU每80ms中斷一次,,供主MCU處理數(shù)據(jù)的時(shí) 間增加為80ms,,相當(dāng)于4分頻,但并沒(méi)有改變各信號(hào)時(shí)序,。這一思想在信號(hào)頻率提高到400Hz或更高后仍然適用,,只需對(duì)軟件作少量改動(dòng)即可,。

通過(guò)以上分析,不難看出:CPLD邏輯功能仿真波形為硬件電路和程序的正確設(shè)計(jì)與優(yōu)化提供了依據(jù),,具有邏輯分析儀的功能,,為設(shè)計(jì)者帶來(lái)了方便,,這充分體現(xiàn)了采用CPLD設(shè)計(jì)數(shù)字電路的優(yōu)點(diǎn),。

總 線收發(fā)三態(tài)控制電路實(shí)現(xiàn)副MCU在讀取φ1、φ2和Ti時(shí)分時(shí)復(fù)用20位數(shù)據(jù)總線D19~D0,。副MCU每讀一個(gè)數(shù)據(jù),,先通過(guò)使能端EN讓計(jì)數(shù)器停止計(jì) 數(shù),再通過(guò)RD端打開(kāi)三態(tài)門(mén)讀取數(shù)據(jù),,讀完數(shù)據(jù)后關(guān)閉三態(tài)門(mén),,并通過(guò)CLR端將計(jì)數(shù)器清零,為下一次讀取數(shù)據(jù)做準(zhǔn)備,。副MCU對(duì)采集到的數(shù)據(jù)進(jìn)行預(yù)處理 后,,送給主MCU。圖1中,,副MCU的P3.0腳與主MCU的P2.0腳相連是為了實(shí)現(xiàn)數(shù)據(jù)傳輸過(guò)程中2塊MCU間的通信握手,,數(shù)據(jù)準(zhǔn)備就緒后,主MCU 打開(kāi)三態(tài)總線緩沖74LS244,,從P0口讀取數(shù)據(jù),。

數(shù)據(jù)采集與預(yù)處理軟件設(shè)計(jì)

如前所述,數(shù)據(jù)采集與預(yù)處理在副MCU中斷0服務(wù)程序內(nèi)完成,,程序流程圖如圖3所示,。程序設(shè)計(jì)中采用了前面介紹的軟件分頻技術(shù),流程圖中φ代表不受預(yù)處理電路中整形芯片門(mén)限電壓影響的準(zhǔn)確相位角,。

結(jié)束語(yǔ)

PM7128SLC84 在智能時(shí)柵位移傳感器數(shù)字電路設(shè)計(jì)中取得了很好的應(yīng)用效果,,實(shí)現(xiàn)了硬件設(shè)計(jì)軟件化,使用可編程邏輯器件技術(shù)避免了復(fù)雜的PCB布線,,帶來(lái)不僅在成本,、開(kāi)發(fā) 周期、可靠性等方面的優(yōu)勢(shì),,而且大大增強(qiáng)了硬件模塊的柔性,,通過(guò)編程來(lái)很方便地修改硬件電路結(jié)構(gòu),功耗也大大降低,。但在使用CPLD器件時(shí)也發(fā)現(xiàn)了一些問(wèn) 題,,如EPM7128SLC84對(duì)信號(hào)毛刺很敏感,因此,,對(duì)信號(hào)的前置處理和電路設(shè)計(jì)提出了更高要求,。

此內(nèi)容為AET網(wǎng)站原創(chuàng),,未經(jīng)授權(quán)禁止轉(zhuǎn)載。