>
不可任意加大配線長(zhǎng)度,盡量縮短配線長(zhǎng)度。
(e)減少電路之間的結(jié)合。
尤其是filter與amplifier輸出入之間作電路分割非常重要,它相當(dāng)于audio電路的cross talk對(duì)策。
(f)MCU回路Layout考量:
震蕩電路僅可能接近IC震蕩腳位;震蕩電路與VDD & VSS保持足夠的距離;震蕩頻率大于1MHz時(shí)不需加 osc1 & osc2 電容;電源與地間要最短位置并盡量拉等寬與等距的線,于節(jié)點(diǎn)位置加上104/103/102等陶瓷電容。
Q5:在車載DVD系統(tǒng)中,如何設(shè)計(jì)電子防震系統(tǒng),有那些IC或器件選擇?
A5:1. 在車載DVD系統(tǒng),最好選擇高檔DVD機(jī),因?yàn)楦邫nDVD機(jī)都采用電子防震系統(tǒng)(ADVANCEDESP),當(dāng)記憶緩沖區(qū)內(nèi)的讀數(shù)降低,先進(jìn)的電子防震設(shè)計(jì)會(huì)以雙速讀數(shù)系統(tǒng),做出比正常速度快兩倍的讀數(shù)速率,以減低噪聲,即使連續(xù)震蕩仍可避免跳線情況出現(xiàn),現(xiàn)在就說說怎樣叫電子防震。簡(jiǎn)單地說:電子防震就是一個(gè)信號(hào)的儲(chǔ)存--釋放過程,首先CD要先把信號(hào)進(jìn)行提前讀取,也就是我們見到機(jī)子的加速,再把信號(hào)儲(chǔ)存在RAM中,而我們?cè)陂_防震的時(shí)候所聽到的就是經(jīng)過RAM的聲音,這樣就是它的過程。當(dāng)沒有防震時(shí)是由于信號(hào)是1比1讀取的,所以當(dāng)受到?jīng)_擊后,就會(huì)出現(xiàn)跳音。而當(dāng)開了防震時(shí),機(jī)子受到?jīng)_擊后,由RAM釋放出來的聲音使音樂不停地播放,而與此同時(shí),光頭迅速進(jìn)行重定檢索,當(dāng)檢索到信號(hào)后立即補(bǔ)充,所以不會(huì)出現(xiàn)跳音。大概的情況就是這樣。但是這樣還沒有滿足用家的要求,由于這種的方法帶來的時(shí)間短,通常只有3秒,所以跳音的機(jī)會(huì)還是蠻高,如果增大RAM又帶來造價(jià)的增高因?yàn)镽AM這東西價(jià)格較貴,尤其是質(zhì)量好的.
2. 在電子防震技術(shù)中,最重要的技術(shù)之一要數(shù)是RAM技術(shù),而一直以來都是因?yàn)樗某杀締栴},所以防震時(shí)間都一直不能增加,也就是說RAM本身就有限制,RAM的容量越大,造價(jià)就越高。而許多廠家就如何在RAM的限制里得到最大限度的記憶時(shí)間展開了開發(fā)研究。
Q6:在demo板上采樣電壓時(shí),不穩(wěn)定,采樣結(jié)果有波動(dòng),如何消除?
A6:1.一般來說,仿真器都是工作在一個(gè)穩(wěn)壓的環(huán)境(通常為5V)。如果用仿真器的A/D時(shí),要注意其A/D參考電壓是由仿真器內(nèi)部給出,還是需要外部提供;2.A/D轉(zhuǎn)換需要一個(gè)連續(xù)的時(shí)鐘周期,所以在仿真時(shí)不能用單步調(diào)試的方法,否則會(huì)造成A/D采樣值不準(zhǔn);3.至于A/D采樣不穩(wěn)定,可以在A/D輸入口加一電容,起到濾波作用;在軟件處理時(shí)采用中值濾波的方法。
Q7:如何進(jìn)行編程可以減少程序的bug?
A7:在此提供一些建議,因系統(tǒng)中實(shí)際運(yùn)行的參數(shù)都是有范圍的。系統(tǒng)運(yùn)行中要考慮的超范圍管理參數(shù)有:
物理參數(shù):這些參數(shù)主要是系統(tǒng)的輸入?yún)?shù),它包括激勵(lì)參數(shù)、采集處理中的運(yùn)行參數(shù)和處理結(jié)束的結(jié)果參數(shù)。合理設(shè)定這些邊界,將超出邊界的參數(shù)都視為非正常激勵(lì)或非正;貞(yīng)進(jìn)行出錯(cuò)處理。
資源參數(shù):這些參數(shù)主要是系統(tǒng)中的電路、器件、功能單元的資源,如記憶體容量、存儲(chǔ)單元長(zhǎng)度、堆疊深度。在程式設(shè)計(jì)中,對(duì)資源參數(shù)不允許超范圍使用。
應(yīng)用參數(shù):這些應(yīng)用參數(shù)常表現(xiàn)為一些單片機(jī)、功能單元的應(yīng)用條件。如E2PROM的擦寫次數(shù)與資料存儲(chǔ)時(shí)間等應(yīng)用參數(shù)界限。
過程參數(shù):指系統(tǒng)運(yùn)行中的有序變化的參數(shù)。
在上述參數(shù)群對(duì)一程式編寫者而言,須養(yǎng)成良好習(xí)慣,在程式的開頭,有順序的用自己喜歡文字參數(shù)對(duì)應(yīng)列表來替代,然后用自己定義的文字參數(shù)來編寫程序,這樣在做程式的修改及維護(hù)時(shí)只在程式的開頭做變動(dòng)即可,不用修改到程序段,才比較容易且不會(huì)出錯(cuò)。
Q8:如果已經(jīng)有了針對(duì)某MCU的C實(shí)現(xiàn)的某個(gè)算法,保持框架不變,對(duì)核心的部分用匯編優(yōu)化,請(qǐng)問有沒有一些比較通用的原則?有這些方面介紹的書么?
A8:1.每個(gè)人的編程都有自己的風(fēng)格與習(xí)慣,如果你要利用別人的程序,在其中修修改改,如果它的程序并沒有很好的模塊化的話,建議你最好不要這么做,否則你本來預(yù)期達(dá)到事倍功半,說不定反而事半功倍了。要參考他人的程序當(dāng)然可以,但是首要是你要看懂并理解他人程序的算法精髓,而不是在他的基礎(chǔ)上打補(bǔ)丁。而關(guān)于算法方面的優(yōu)化,你可以購買一些數(shù)據(jù)結(jié)構(gòu)的書籍,上面有比較詳細(xì)的說明。
2.算法的運(yùn)行時(shí)間是指一個(gè)算法在計(jì)算機(jī)上運(yùn)算所花費(fèi)的時(shí)間。它大致等于計(jì)算機(jī)執(zhí)行簡(jiǎn)單操作(如賦值操作,比較操作等)所需要的時(shí)間與算法中進(jìn)行簡(jiǎn)單操作次數(shù)的乘積。通常把算法中包含簡(jiǎn)單操作次數(shù)的多少叫做算法的時(shí)間復(fù)雜性。它是一個(gè)算法運(yùn)行時(shí)間的相對(duì)量度,一般用數(shù)量級(jí)的形式給出。度量一個(gè)程序的執(zhí)行時(shí)間通常有兩種方法:
一種是事后統(tǒng)計(jì)的方法。因?yàn)楹芏嘤?jì)算機(jī)內(nèi)部都有計(jì)時(shí)功能,不同算法的程序可通過一組或若干組相同的統(tǒng)計(jì)數(shù)據(jù)以分辨優(yōu)劣。但這種方法有兩個(gè)缺陷:一是必須先運(yùn)行依據(jù)算法編制的程序;二是所得時(shí)間的統(tǒng)計(jì)量依賴于計(jì)算機(jī)的硬件、軟件等環(huán)境因素,有時(shí)容易掩蓋算法本身的優(yōu)劣。因此人們常常采用另一種事前分析估算的方法。
事前分析估算的方法。一個(gè)程序在計(jì)算機(jī)上運(yùn)行時(shí)所消耗的時(shí)間取決于下列因素:
、 依據(jù)的算法選用何種策略;
、 問題的規(guī)模。例如求100以內(nèi)還是1000以內(nèi)的素?cái)?shù);
③ 書寫程序的語言。對(duì)于同一個(gè)算法,實(shí)現(xiàn)語言的級(jí)別越高,執(zhí)行效率就越低; <





