<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 單片機(jī)編程檢驗(yàn)總結(jié)

          單片機(jī)編程檢驗(yàn)總結(jié)

          作者: 時(shí)間:2013-02-05 來(lái)源:網(wǎng)絡(luò) 收藏

          所以,匠人的觀點(diǎn)是:看門狗必須擁有獨(dú)立的計(jì)數(shù)器。(即硬件看門狗)好在現(xiàn)在好多芯片都提供了內(nèi)部WDT。這種狗都是自帶計(jì)數(shù)器的。即使干擾導(dǎo)致程序失控,WDT還是會(huì)造常計(jì)數(shù)直到溢出。當(dāng)然,匠人也沒(méi)有要將軟件狗一棍子全部打死的意思。畢竟不管是軟狗還是硬狗,逮到耗子就是好狗嘛(狗拿耗子——多管閑事?)。如果哪位訓(xùn)狗專家確實(shí)養(yǎng)過(guò)一條能看門的好軟件狗,請(qǐng)牽出來(lái)讓大伙瞧瞧。

          經(jīng)驗(yàn)之三、話說(shuō)RAM冗余技術(shù)

          所謂的RAM冗余,就是:

          1、將重要的數(shù)據(jù)信息備份2份(或以上)并存放在RAM中不同的區(qū)域(指地址不相連)。

          2、當(dāng)平時(shí)對(duì)這些數(shù)據(jù)進(jìn)行修改時(shí),同時(shí)也更新備份。

          3、當(dāng)干擾發(fā)生并被攔截到“程序錯(cuò)誤處理段”中時(shí),

          將數(shù)據(jù)與備份做比較,采用表決方式(少數(shù)服從多數(shù))選出正確(或可能正確?)的那個(gè)。

          4、備份越多,效果越好。(當(dāng)然,你得有足夠的存儲(chǔ)空間)。

          5、只備份最最原始的數(shù)據(jù)。中間變量(指那些可以從原始數(shù)據(jù)重新推導(dǎo)出來(lái)的數(shù)據(jù))不必備份,

          注:

          1、這種思路的理論依據(jù),據(jù)說(shuō)是源于一種“概率論”,即一個(gè)人被老婆打腫臉的概率是很大的,但如果他捂著臉去上班卻發(fā)現(xiàn)全公司每個(gè)已婚男人的臉都青了,這種概率是很小的。同理,一個(gè)RAM寄存器數(shù)據(jù)被沖毀的概率是很大的,但地址不相連的多個(gè)RAM同時(shí)被沖毀的概率是很小的。

          2、前兩年,小匠學(xué)徒時(shí),用過(guò)一次這種方法,但效果不太理想。當(dāng)時(shí)感覺(jué)可能是概率論在我這失效了?現(xiàn)在回想起來(lái),可能是備份的時(shí)機(jī)選的不好。結(jié)果將已經(jīng)沖毀的數(shù)據(jù)又備份進(jìn)去了。這樣以來(lái),恢復(fù)出來(lái)的數(shù)據(jù)自然也就不對(duì)了。

          經(jīng)驗(yàn)之四、話說(shuō)指令冗余技術(shù)

          前面有個(gè)朋友問(wèn)到指令冗余,按匠人的理解,指令冗余,就是動(dòng)作冗余。舉個(gè)例子,你要在某個(gè)輸出口上輸出一個(gè)高電平去驅(qū)動(dòng)一個(gè)外部器件,你如果只送一次“1”,那么,當(dāng)干擾來(lái)臨時(shí),這個(gè)“1”就有可能變成“0”了。正確的處理方式是,你定期刷新這個(gè)“1”。那么,即使偶然受了干擾,它也能恢復(fù)回來(lái)。除了I/O口動(dòng)作的冗余,匠人強(qiáng)烈建議大家在下面各方面也采用這種方法:

          1、LCD的顯示。有時(shí),也許你會(huì)用一些LCD的專用驅(qū)動(dòng)芯片(如HT1621),這種芯片有個(gè)好處,即你只要將顯示數(shù)據(jù)傳送給它,它就會(huì)不斷的自動(dòng)掃描LCD。但是,你千萬(wàn)不要以為這樣就沒(méi)你啥事了。正確的處理方式是,要記得定期刷新送顯數(shù)據(jù)(即使顯示內(nèi)容沒(méi)有改變)。對(duì)于CPU中自帶LCD DRIVER 的,也要定期刷新LCD RAM。

          2、中斷使能標(biāo)志的設(shè)置。不要以為你在程序初始化段將中斷設(shè)置好就OK了。應(yīng)該在主程序中適當(dāng)?shù)牡胤蕉ㄆ谒⑿乱幌?,以免你的中斷被掛起?lái)。

          3、其它一些標(biāo)志字和參數(shù)寄存器(包括你自己定義的),也要記得常常刷新。

          4、其它一些你認(rèn)為有必要反復(fù)刷新的地方。

          經(jīng)驗(yàn)之五、10種軟件濾波方法

          下面奉獻(xiàn)——匠人嘔心瀝血搜腸刮肚冥思苦想東拼西湊整理出來(lái)的10種軟件濾波方法:

          1、限幅濾波法(又稱程序判斷濾波法)

          A、方法:根據(jù)經(jīng)驗(yàn)判斷,確定兩次采樣允許的最大偏差值(設(shè)為A),每次檢測(cè)到新值時(shí)判斷:如果本次值與上次值之差=A,則本次值有效。如果本次值與上次值之差>A,則本次值無(wú)效,放棄本次值,用上次值代替本次值

          B、優(yōu)點(diǎn):能有效克服因偶然因素引起的脈沖干擾。

          C、缺點(diǎn):無(wú)法抑制那種周期性的干擾,平滑度差。

          2、中位值濾波法

          A、方法:連續(xù)采樣N次(N取奇數(shù)),把N次采樣值按大小排列,取中間值為本次有效值。

          B、優(yōu)點(diǎn):能有效克服因偶然因素引起的波動(dòng)干擾,對(duì)溫度、液

          位的變化緩慢的被測(cè)參數(shù)有良好的濾波效果。

          C、缺點(diǎn):對(duì)流量、速度等快速變化的參數(shù)不宜。

          3、算術(shù)平均濾波法

          A、方法:連續(xù)取N個(gè)采樣值進(jìn)行算術(shù)平均運(yùn)算。N值較大時(shí):信號(hào)平滑度較高,但較低;N值較小時(shí):信號(hào)平滑度較低,但較高。N值的選?。阂话懔髁?,N=12;壓力:N=4

          B、優(yōu)點(diǎn):適用于對(duì)一般具有隨機(jī)干擾的信號(hào)進(jìn)行濾波,這樣信號(hào)的特點(diǎn)是有一個(gè)平均值,信號(hào)在某一數(shù)值范圍附近上下波動(dòng)。

          C、缺點(diǎn):對(duì)于測(cè)量速度較慢或要求數(shù)據(jù)計(jì)算速度較快的實(shí)時(shí)控制不適用,比較浪費(fèi)RAM。

          4、遞推平均濾波法(又稱滑動(dòng)平均濾波法)

          A、方法:把連續(xù)取N個(gè)采樣值看成一個(gè)隊(duì)列,隊(duì)列的長(zhǎng)度固定為N,每次采樣到一個(gè)新數(shù)據(jù)放入隊(duì)尾,并扔掉原來(lái)隊(duì)首的一次數(shù)據(jù).(先進(jìn)先出原則),把隊(duì)列中的N個(gè)數(shù)據(jù)進(jìn)行算術(shù)平均運(yùn)算,就可獲得新的濾波結(jié)果。N值的選?。毫髁浚琋=12;壓力:N=4;液面,N=4~12;溫度,N=1~4

          B、優(yōu)點(diǎn):對(duì)周期性干擾有良好的抑制作用,平滑度高,適用于高頻振蕩的系統(tǒng)。



          評(píng)論


          相關(guān)推薦

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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();