www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > > 充電吧
[導(dǎo)讀]之前已經(jīng)對MSP430F4250的SD16_A進(jìn)行了入門級的了解和設(shè)置,但由于項目有要求:AD——模擬信號頻率范圍100~20kHz,采樣率40kHz,16bit采樣所以,需要設(shè)置采樣率為40KHz,

之前已經(jīng)對MSP430F4250的SD16_A進(jìn)行了入門級的了解和設(shè)置,但由于項目有要求:

AD——模擬信號頻率范圍100~20kHz,采樣率40kHz,16bit采樣

所以,需要設(shè)置采樣率為40KHz,百轉(zhuǎn)千回后得到了如下結(jié)論:

1.需要配置FFL+:

主要寄存器:

(1)FLL_CTL0:

一般官方給出的代碼是


FLL_CTL0?|=?XCAP14PF;


但是其實還有一位關(guān)于時鐘頻率比較重要的:DCOPLUS

為什么要設(shè)置它?

因為DCO的頻率是直接給MCLK和SMCLK的,那么這一位的含義是什么?

參考MSP430X4XX User's Guide


比較重要的說明是,默認(rèn)情況下DCOPLUS = 0并且D = 2,其實D的含義是(Divider的意思),所以總的來說,默認(rèn)情況下你的DCO時鐘頻率=晶振頻率*(N+1)/2,為了提高時鐘頻率,設(shè)置DCOPLUS = 1,即DCO output is not divided,不進(jìn)行默認(rèn)的分頻,可提高2倍時鐘頻率。

(2)SCFQCTL和SCFI0:

之所以把它們放在一起講,因為User's Guide手冊上給出的官方倍頻代碼為:


BIC?#GIE,SR?;?Disable?interrupts
MOV.B?#(64?1),&SCFQCTL?;?MCLK?=?64?*?ACLK,?DCOPLUS=0
MOV.B?#FN_2,&SCFI0?;?Select?DCO?range
BIS?#GIE,SR?;?Enable?interrupts

具體含義是SCFQCTL為倍頻因子,SCFI0用于設(shè)定頻率范圍,具體參考User's Guide手冊吧。



2.已經(jīng)得到了系統(tǒng)時鐘頻率MCLK和外設(shè)時鐘頻率SMCLK,在AD上具體還能如何設(shè)置:


??SD16CTL?=?SD16REFON+SD16SSEL0;????????????//?1.2V?ref,?SMCLK
??SD16INCTL0?=?SD16INTDLY_3;
??SD16CCTL0?|=?SD16OSR_32?+?SD16IE;?????????//?Enable?interrupt

首先設(shè)置SD16CTL,主要用于選擇時鐘和選擇分頻因子,SD16SSEL0就是選擇SMCLK(已經(jīng)是最快了),設(shè)置SD16INCTL0選擇通道0每次采樣結(jié)束產(chǎn)生中斷(事實上,測量中設(shè)置每4次采樣產(chǎn)生一次中斷,中斷頻率也沒有任何變化,暫時不知如何解釋),設(shè)置SD16CCTL0的過采樣率SD16OSR_32,設(shè)置過采樣率為最低也能提高采樣率,但是會降低采樣精度。參考Use's Guide:



更具體的AD時鐘再參考時鐘部分的框圖:


其實fm就是SMCLK通過層層分頻(上述筆者代碼設(shè)置的分頻系數(shù)為0,不分頻,具體參考SD16CTL寄存器說明)得到的頻率,User's Guide在貼圖文字中提到Sample frequency ?fs = fm/OSR,那么自然,筆者把SD16CCTL0的OSR位設(shè)置為最低的32,就能得到最高的采樣頻率了。

除了時鐘之外,通過SD16_A的框圖還能了解到它內(nèi)部存在的高阻抗Buffer和前置放大器(過采樣數(shù)字濾波之前討論fs時的截圖中也有說明),放大器很容易理解,那么高阻抗Buffer有什么用(User's Guide):


總結(jié)來說高阻抗Buffer可以抗采集到的輸入數(shù)據(jù)的鋸齒現(xiàn)象,但是它的設(shè)置和fm的頻率有關(guān),雖然筆者沒有使用,但是卻是SD16_A中一個重要組成部分。


首先解釋前一篇對MSP430 AD研究的博文代碼:

fm = 1MHz,fs = 1MHz/256 = 3.9KHz,約256us會產(chǎn)生一次中斷,最后得到的結(jié)果為224us,誤差0.125,還是有說明價值的。(純屬個人見解)

最后是筆者得到接近200KHz采樣率的代碼:


#include??


#define???Num_of_Results???80

/*?Arrays?to?store?SD16_A?conversion?results?*/
/*?NOTE:?arrays?need?to?be?global?to???????*/
/*???????prevent?removal?by?compiler???????*/
static?unsigned?int?results[Num_of_Results];

void?main(void)
{
??volatile?unsigned?int?i;??????????????????//?Use?volatile?to?prevent?removal
????????????????????????????????????????????//?by?compiler?optimization

??WDTCTL?=?WDTPW?+?WDTHOLD;?????????????????//?Stop?WDT
??FLL_CTL0?|=?XCAP14PF+DCOPLUS;?????????????????????//?Configure?load?caps
??SCFQCTL?=?SCFQ_4M;
??SCFI0?|=?FN_8;//MCLK?=?SMCLK?=?8MHz
??for?(i?=?0;?i?<?10000;?i++);??????????????//?Delay?for?32?kHz?crystal?to
????????????????????????????????????????????//?stabilize
??P1SEL?=?0;????????????????????????????????//GPIO
??P1DIR?=?0xff;?????????????????????????????//out
??
??SD16CTL?=?SD16REFON+SD16SSEL0;????????????//?1.2V?ref,?SMCLK
??SD16INCTL0?=?SD16INTDLY_3;????
??SD16CCTL0?|=?SD16OSR_32?+?SD16IE;?????????//?Enable?interrupt
??for?(i?=?0;?i?<?0x3600;?i++);?????????????//?Delay?for?1.2V?ref?startup

??_EINT();??????????????????????????????????//?Enable?general?interrupts

??SD16CCTL0?|=?SD16SC;??????????????????????//?Set?bit?to?start?conversion
??//_BIS_SR(LPM0_bits);???????????????????????//?Enter?LPM0
??while(1);
}

#pragma?vector=SD16_VECTOR
__interrupt?void?SD16ISR(void)
{
??static?unsigned?int?index?=?0;

??switch?(SD16IV)
??{
??case?2:???????????????????????????????????//?SD16MEM?Overflow
????break;
??case?4:???????????????????????????????????//?SD16MEM0?IFG
????results[index]?=?SD16MEM0;??????????????//?Save?CH0?results?(clears?IFG)
????P1OUT?=?0x03;???????????????????????????//Pin?0,1?out?1
????if?(++index?==?Num_of_Results)
????{
??????index?=?0;????????????????????????????//?SET?BREAKPOINT?HERE
??????P1OUT?=?0x00;?????????????????????????//Pin?0,1?out?0???
????}
????break;
??}
}



代碼仔細(xì)說明:


設(shè)置了MCLK = SMCLK = 8MHz(具體參考用戶手冊和筆者之前對時鐘的設(shè)置說明看看就能明白),設(shè)置了不分頻的時鐘給AD,即fm = 8MHz,fs = 8/32 = 250KHz,所以每250KHz就會進(jìn)入一次中斷,當(dāng)采到80個AD值時,使P1.0和P1.1=0,然后清除計數(shù),再下一次觸發(fā)中斷,P1.1和P1.0會再次置1,通過測量低電平持續(xù)時間可以得到AD的Sample frequency.

得到結(jié)果:


為什么只是186.6KHz?因為MSP430的最大AD采樣頻率就是200KHz,只能無限接近吧。(純屬個人見解)


此文為實踐總結(jié)所得,多數(shù)都為個人見解,僅供參考,具體以TI給出的文檔為準(zhǔn),歡迎討論并提出不足。




本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機(jī)驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機(jī)驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉