新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應用 > 利用單片機使用MSP430F149設(shè)計正弦波發(fā)生器解析方案

利用單片機使用MSP430F149設(shè)計正弦波發(fā)生器解析方案

作者: 時間:2012-06-18 來源:網(wǎng)絡(luò) 收藏

根據(jù)《鐵路車輛內(nèi)旅客振動舒適性評價準則》UIC513國際標準開發(fā)的SSD-J-2振動舒適度測量儀是基于的三維振動便攜式分析儀,內(nèi)含上下、左右、前后振動的生理濾器。為了調(diào)整和標定這組生理濾波器的精度,的一個PWM輸出端配上II型的RC濾波,在軟件支持下構(gòu)成調(diào)節(jié)方便的超低頻波。經(jīng)實用表明其性能達到UIC513標準的技術(shù)要求。

本文引用地址:http://butianyuan.cn/article/171285.htm

1 的內(nèi)部結(jié)構(gòu)

是美國TEXAS INSTRUCMENTS公司最新推出的16位超低功耗混合信號,帶有Flash存儲器,具備很強的靈活性,方便修改代碼及產(chǎn)品售后升級。它采用精簡指令集(RISC),125ns指令周期,大部分的指令在一個指令周期內(nèi)完成。1.8V~3.6V的供電電壓,其超低功耗(供電電壓2.2V,工作頻率 32kHz時,工作電流為7μA;供電電壓2.2V,工作頻率1MHz時,工作電流為250μA.)使超低頻波形可被成電池供電且長時間工作的系統(tǒng)。MSP430F149內(nèi)含一個具有8個外部通道的12位高性能A/D轉(zhuǎn)換器,一個具有自動掃描功能的容量為16個字節(jié)的可編程緩沖器,片內(nèi)參考電壓,一個溫度傳感器以及電池低壓時的檢測電路;內(nèi)部具有兩具定時器:帶有7個捕獲/比較寄存器的16位 Timer_B和帶有3個捕獲/比較寄存器的16位Timer_A,在比較模式下可以產(chǎn)生PWM信號,控制DCO的頻率,它們可以滿足要求;該芯片具有60KB的閃速存儲器,2KB RAM,采用串行在線編程方式,為用戶修改程序和控制參數(shù)帶來靈活的空間,而且內(nèi)部的安全保密熔絲可使程序不被非法拷貝。此外,MSP430F149具有強大的中斷功能,48個I/O此腳,兩個串行通訊接口,10萬次的擦寫,超強的抗干擾能力。

2 超低頻波形的電路原理

用于人體乘坐的交通運輸工具中的振動分析儀對信號有嚴格的濾波要求。UIC513標準中對Z方向(上、下)振動信號規(guī)定按圖1的濾波計權(quán)曲線進行濾,其濾波頻帶為0.4Hz~16Hz,并且具臺階性。重要的是檢驗濾波的效果是評價振動舒適性的前提,濾波電路只有經(jīng)過嚴格的標定校調(diào)后方能投入,所以需要采用低失真、超低頻正弦信號源來標定電路。應用MSP430F149進行,電路十分簡單。產(chǎn)生的波形精度取決于脈寬計數(shù)器的精度,最高可達16位,頻率取決于軟件所設(shè)計正弦表的大小、系統(tǒng)頻率以及讀取正弦表的時間長短。應該注意的是所設(shè)計的頻率應該比需要的頻率略高一些,這樣由脈寬高制信號到正弦波信號的濾波電路階數(shù)可以降低。

3 用MSP430F149實現(xiàn)PWM功能的軟件設(shè)計

在該超低頻波形發(fā)生器的軟件設(shè)計中,主要應用到了以下幾個功能模塊:Timer_B定時器、Timer_A定時器、CPU寄存器、片內(nèi)的數(shù)字控制晶振以及XT1低功耗振蕩器。

3.1 穩(wěn)定DCO頻率模塊

DCO 實質(zhì)上是一個RC振蕩器,具有RC振蕩器的特點。其在頻率的設(shè)置和轉(zhuǎn)換上不準確,但由于它是數(shù)字控制的振蕩器,可以通過一個已知的頻率穩(wěn)定的晶振如 32768Hz手表晶振來進行校準,使DCO達到準確的頻率。因為MSP430F149不含有鎖頻環(huán)數(shù)字邏輯,所以只有通過軟件進行“軟鎖頻”校準 DCO,這十分重要。

程序如下:

Setup_TA mov #TASSEL1+TACLR,TACTL;設(shè)置TA時鐘SMCLK

Setup_CC2 mov #CCIS0+CM0+CAP,CCTL2;設(shè)置CCR2,輸入信號:;ACLK,捕獲模式

Bis #MC1,TACTL;設(shè)置Timer_A:連接模式

Test_DCO bit #CCIFG,CCTL2;檢測捕獲標志位

jz Test_DCO

bic #CCIFG,CCTL2 ;清除標志位

AdjDCO mov CCR2,R14

;R14=捕獲的SMCLK值

sub R15,R14;R14=捕獲SMCLK的差值

mov CCR2,R15;上次捕獲的SMCLK值

com #Delta,R14 ;Delta=SMCLK/ACLK

jlo IncDCO

jeq DoneFLL

DecDCO dec.b DCOCTL ;調(diào)整DCO

jmp Test_DCO

IncDCO inc.b DCOCTL

Jmp Test_DCO

DoneFLL clr CCTL2 ;停止CCR2

Clr TACTL ;停止Timer_A


上一頁 1 2 下一頁

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉