0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于發(fā)送方接收方雙向同步算法實(shí)現(xiàn)時鐘漂移與偏移補(bǔ)償機(jī)制的研究

電子設(shè)計(jì) ? 來源:單片機(jī)與嵌入式系統(tǒng)應(yīng)用 ? 作者:徐世武 ? 2020-02-10 08:03 ? 次閱讀

引言

無線傳感器網(wǎng)絡(luò)是由密集型、低成本、隨機(jī)分布的節(jié)點(diǎn)組成,集成了傳感器技術(shù)、計(jì)算機(jī)技術(shù)和通信技術(shù),能夠協(xié)同地實(shí)時監(jiān)測、感知并采集各種環(huán)境的數(shù)據(jù),適用于戰(zhàn)場通信、搶險(xiǎn)救災(zāi)和公共集會等突發(fā)性、臨時性場合。保持節(jié)點(diǎn)之間時間上的同步在無線傳感器網(wǎng)絡(luò)中非常重要,它是保證可靠的數(shù)據(jù)傳輸、精確的節(jié)點(diǎn)定位、可靠的數(shù)據(jù)融合、準(zhǔn)確的目標(biāo)跟蹤與檢測的前提。如利用波的到達(dá)時間差測距,就需要高精度的時間同步。無線傳感器網(wǎng)絡(luò)中,由于頻率漂移,各個節(jié)點(diǎn)之間必然會產(chǎn)生一定的時鐘偏移,因此有效的時間同步技術(shù)對保證各個節(jié)點(diǎn)之間的時鐘同步非常重要[2]。

2002年,Elson等人在影響未來網(wǎng)絡(luò)研究發(fā)展方向的國際權(quán)威學(xué)術(shù)會議HotNets上,首次提出無線傳感器網(wǎng)絡(luò)時間同步的研究課題,至今已有相當(dāng)多的典型時間同步算法?;诎l(fā)送者接收者的雙向同步算法中,比較典型的如TPSN(Timingsync Protocol for Sensor Networks)算法[3]。TPSN算法分成兩個階段,第一階段為層次發(fā)現(xiàn)階段,第二階段為同步階段。在同步階段采用發(fā)送者接收者的雙向成對同步算法, MAC層采用加入時間戳的技術(shù),進(jìn)而估算出節(jié)點(diǎn)之間的傳輸延遲與時鐘偏移。該作者在Mica 節(jié)點(diǎn)上測試過,TPSN平均單跳誤差為17.61 μs?;诎l(fā)送者接收者的單向時間同步算法中,比較典型的如FTSP(Flooding Time Synchronization Protocol)算法[4]、DMTS(Delay Measurement Time Synchronization)算法[5]?;诮邮照呓邮照叩耐剿惴?,典型的有RBS(Reference Broadcast Synchronization)算法[6]。近幾年,也有作者提出了協(xié)作同步機(jī)制[7]。協(xié)作同步的核心思想仍然是屬于集中式協(xié)議,要求整個網(wǎng)絡(luò)中節(jié)點(diǎn)密度較高。參考文獻(xiàn)[8]中,作者提出了分步式同步機(jī)制,整個網(wǎng)絡(luò)無需構(gòu)造由根節(jié)點(diǎn)發(fā)起的生成樹,只需要每個節(jié)點(diǎn)之間使用分布式廣播同步機(jī)制。

傳統(tǒng)的同步機(jī)制只是簡單地修正節(jié)點(diǎn)之間的時鐘偏移,傳感器節(jié)點(diǎn)時鐘由晶體振蕩器驅(qū)動。晶體振蕩器的實(shí)際頻率通常與它標(biāo)定的頻率之間存在一定的偏移,即存在時鐘頻率的漂移。傳統(tǒng)的同步算法為了提高同步精度,節(jié)點(diǎn)就必須頻繁地重復(fù)時間同步算法,以消除時鐘偏移的影響。頻繁地交換消息,必然給功耗受限的節(jié)點(diǎn)帶來額外的負(fù)擔(dān),因此考慮節(jié)點(diǎn)之間的時鐘漂移也是非常重要的[9]。

1 、CDCO時鐘同步算法設(shè)計(jì)

1.1 時鐘模型

本同步算法采用的是發(fā)送者接收者的雙向同步算法,同時考慮了時鐘漂移與偏移對同步精度的影響。在無線傳感器網(wǎng)絡(luò)的節(jié)點(diǎn)中,如果采用的是時鐘速率恒定模型,那么節(jié)點(diǎn)的硬件時鐘Ci(t)與真實(shí)時間Ck(t)的關(guān)系可以表示為Ci(t)=aik·Ck(t)+mik。式中,aik為節(jié)點(diǎn)之間的相對漂移量,mik為節(jié)點(diǎn)之間的相對偏移量。如果兩個節(jié)點(diǎn)之間完全同步,則相對漂移量aik為1,相對偏移量mik為0。

1.2 單跳同步原理

如圖1所示,hi(t1)、hi(t4)、hi(t5)用來記錄參考節(jié)點(diǎn)的本地時間, hk(t2)、hk(t3)、hk(t6)用來記錄同步節(jié)點(diǎn)的本地時間。同步過程采用類似TPSN算法的雙向同步過程,假設(shè)同步節(jié)點(diǎn)與參考節(jié)點(diǎn)的時鐘關(guān)系采用時鐘恒定模型(這在現(xiàn)實(shí)中也是合理的),則hk(t)=ρki·hi(t)+mki。式中,hk(t)、hi(t)分別為同步節(jié)點(diǎn)與參考節(jié)點(diǎn)在本地時刻t的時鐘,ρki、mki分別為時鐘漂移量與偏移量。

圖1 雙向同步原理圖

假設(shè)傳播延遲為dki,因?yàn)樵跇O短的時間內(nèi)來回傳播延遲與節(jié)點(diǎn)時偏可假設(shè)相同。假設(shè)漂移量

則在理想情況下,ρki為1,即線段hi(t1)hk(t2)平行于線段hi(t5)hk(t6),此時不存在時鐘漂移[10]。如圖1所示,根據(jù)雙向同步原理與時鐘恒定模型可以得到:

基于發(fā)送方接收方雙向同步算法實(shí)現(xiàn)時鐘漂移與偏移補(bǔ)償機(jī)制的研究

則根據(jù)得到的ρBA、mBA修改同步節(jié)點(diǎn)的本地時鐘,就能實(shí)現(xiàn)與同步節(jié)點(diǎn)的時鐘同步。

1.3 多跳同步原理

假設(shè)節(jié)點(diǎn)A與其下一跳節(jié)點(diǎn)B已經(jīng)實(shí)現(xiàn)了時間同步,則可以得到:

基于發(fā)送方接收方雙向同步算法實(shí)現(xiàn)時鐘漂移與偏移補(bǔ)償機(jī)制的研究

由式(5)與式(6)可以得到:

同樣,假設(shè)節(jié)點(diǎn)B與下一跳節(jié)點(diǎn)C已經(jīng)實(shí)現(xiàn)了時間同步,同理可以得到:

顯然將式(7)帶入式(8)可以得到節(jié)點(diǎn)A與C之間的同步。

采用同樣的方法逐級迭代下去,就可以實(shí)現(xiàn)全網(wǎng)的時間同步。

1.4 理論誤差來源分析

由1.2節(jié)的分析可知,兩節(jié)點(diǎn)之間的時鐘關(guān)系為hk(t)=ρki·hi(t)+mki。如果兩個節(jié)點(diǎn)不存在時鐘頻偏的情況,ρki為1,即hi(t1)hk(t2)平行于邊hi(t5)hk(t6),則頻率偏移誤差:

基于發(fā)送方接收方雙向同步算法實(shí)現(xiàn)時鐘漂移與偏移補(bǔ)償機(jī)制的研究

假設(shè)不存在頻率偏移的情況下,即ρki為1,我們來計(jì)算時鐘偏移的誤差來源。根據(jù)圖1所示的發(fā)送接收雙向消息同步過程,可以得到:

式中, hk(t3)、hi(t4)分別是t3、t4所對應(yīng)的同步節(jié)點(diǎn)和本地節(jié)點(diǎn)所測出的本地時間,Sk代表節(jié)點(diǎn)k的報(bào)文發(fā)送時間,Ak是發(fā)送報(bào)文的訪問時間,Pk→i是節(jié)點(diǎn)k傳播到節(jié)點(diǎn)i的時間,Ri是節(jié)點(diǎn)i的報(bào)文接收處理時間,Nkt是傳輸Nk個比特的總時間,Terror指傳輸比特的誤差,Rerror為打時標(biāo)過程存在的誤差,Dk→it3代表節(jié)點(diǎn)k與節(jié)點(diǎn)i在hk(t3)時刻的時偏。因?yàn)樵趯?shí)驗(yàn)中采用了MAC層的打時標(biāo)方法,這樣就可以消除發(fā)送時間與訪問時間對誤差的影響。于是式(11)就可以簡寫為:

式中,Dk→it3=Dk→it6+RDk→it3→t6。同理可以得到hk(t6):

由以上各式可以得到時偏:

基于發(fā)送方接收方雙向同步算法實(shí)現(xiàn)時鐘漂移與偏移補(bǔ)償機(jī)制的研究

式中,RDk→it3→t6代表從hk(t3)到hk(t6)時段內(nèi),節(jié)點(diǎn)k相對于節(jié)點(diǎn)i增加的時偏;Dk→it6是hk(t6)時刻節(jié)點(diǎn)k與節(jié)點(diǎn)i之間的時偏??梢运愠鰰r鐘偏差為:

2 、算法性能分析

無線傳感器節(jié)點(diǎn)采用的是晶體振蕩器來計(jì)時節(jié)點(diǎn)的本地時鐘,由于成本的限制,只能采用一些低成本的晶振。硬件設(shè)備廠商一般都會給出晶振頻率變化范圍,一般時鐘漂移為[10,100]ppm。同步周期取20 s,在一個周期內(nèi)采樣4次,得到的結(jié)果如表1所列。相同情況下的多跳同步誤差如表2所列。

基于發(fā)送方接收方雙向同步算法實(shí)現(xiàn)時鐘漂移與偏移補(bǔ)償機(jī)制的研究

從表1中可以看出,在同一個周期內(nèi),相比TPSN算法,CDCO算法誤差隨采樣間隔的增長明顯比TPSN慢,在相同的采樣間隔,誤差也明顯低于TPSN算法。因?yàn)橄啾扔赥PSN算法,本文考慮了時鐘漂移,因此可以在較長的時間內(nèi)保持同步。從表2可以看出,隨跳數(shù)增加,CDCO算法精度較高于TPSN算法。在相同的跳數(shù)內(nèi),CDCO算法的誤差明顯低于TPSN算法,且隨著跳數(shù)增加,CDCO算法的同步誤差增加明顯低于TPSN算法。相對于TPSN算法,CDCO算法可以減小誤差多跳累加的影響。

3、結(jié)語

本文基于發(fā)送方接收方雙向同步算法的原理,設(shè)計(jì)了一種同時考慮時鐘偏移與漂移的同步補(bǔ)償機(jī)制(CDCO算法)。實(shí)驗(yàn)結(jié)果表明,相比傳統(tǒng)的發(fā)送方接收方雙向同步算法,CDCO算法因?yàn)椴捎昧藭r鐘漂移補(bǔ)償技術(shù),在同一個同步周期內(nèi),同步誤差隨時間增加變化較小;而傳統(tǒng)的算法因?yàn)榇嬖跁r鐘漂移,在同一個周期內(nèi)誤差隨時間增大而變得越來越大。相對于TPSN算法,CDCO算法可以減小誤差多跳累加的影響。

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 無線傳感器
    +關(guān)注

    關(guān)注

    15

    文章

    770

    瀏覽量

    98436
  • 網(wǎng)絡(luò)
    +關(guān)注

    關(guān)注

    14

    文章

    7592

    瀏覽量

    89060
  • 時鐘
    +關(guān)注

    關(guān)注

    11

    文章

    1744

    瀏覽量

    131661
收藏 人收藏

    評論

    相關(guān)推薦

    異步機(jī)制同步機(jī)制

    間可以不用同時在線等待,任何一只需各自處理自己的業(yè)務(wù),比如發(fā)送發(fā)送消息以后不用等待接收方的響應(yīng),可以接著處理其他的任務(wù)。也就是說
    發(fā)表于 04-14 12:33

    雙向同步自適應(yīng)時鐘技術(shù)

    調(diào)時(SelfTimed)技術(shù),即采用類似應(yīng)答機(jī)制實(shí)現(xiàn)兩個不同時鐘域系統(tǒng)間信號的可靠傳輸,如圖l所示。圖l中的發(fā)送接收系統(tǒng)均工作在各自獨(dú)
    發(fā)表于 05-21 05:00

    采用ADS實(shí)現(xiàn)接收機(jī)碼元同步算法

    系統(tǒng)中,碼元同步對于實(shí)現(xiàn)信號的準(zhǔn)確判決碼元和降低系統(tǒng)誤碼率起著關(guān)鍵作用。本文介紹了在ADS仿真環(huán)境下實(shí)現(xiàn)16QAM接收機(jī)碼元同步
    發(fā)表于 06-27 06:04

    設(shè)計(jì)時間同步機(jī)制關(guān)注的主要性能參數(shù)

    ,提高了脈沖數(shù)量,提高了檢測精度。因?yàn)?rbs算法消除了發(fā)送的不確定性,所以無需在節(jié)點(diǎn)間進(jìn)行雙向信息交換,因此比傳統(tǒng)的時鐘
    發(fā)表于 12-31 17:09

    分享一種實(shí)現(xiàn)時鐘頻率同步的設(shè)計(jì)方案

    本文研究了一種可對頻率進(jìn)行動態(tài)調(diào)整的時鐘,通過對時鐘頻率的動態(tài)修正,實(shí)現(xiàn)主從時鐘頻率的同步,進(jìn)而
    發(fā)表于 04-08 06:23

    怎樣去設(shè)計(jì)一種同步補(bǔ)償機(jī)制(CDCO算法)?

    本文基于發(fā)送接收方雙向同步算法的原理,提出一種基于時鐘
    發(fā)表于 05-17 06:18

    如何使用PTP實(shí)現(xiàn)時鐘同步?

    我正在嘗試使用 PTP 實(shí)現(xiàn)時鐘同步,請幫忙。
    發(fā)表于 03-31 09:00

    同步傳輸,同步傳輸工作原理是什么?

    同步傳輸,同步傳輸工作原理是什么? 同步傳輸方式中發(fā)送接收方
    發(fā)表于 03-17 16:36 ?2445次閱讀

    同步傳輸/異步傳輸原理什么?

    同步傳輸/異步傳輸原理什么? 同步傳輸 同步傳輸方式中發(fā)送接收方
    發(fā)表于 04-03 15:10 ?2329次閱讀

    基于卡爾曼濾波估計(jì)的一致性時鐘同步算法

    了基于分布式卡爾曼濾波估計(jì)的一致性補(bǔ)償時鐘同步算法DKFCC。該算法首先利用雙向信息交換
    發(fā)表于 11-29 09:59 ?3次下載
    基于卡爾曼濾波估計(jì)的一致性<b class='flag-5'>時鐘</b><b class='flag-5'>同步</b><b class='flag-5'>算法</b>

    如何使用ADS實(shí)現(xiàn)接收機(jī)碼元同步算法的設(shè)計(jì)

    引起的時鐘抖動問題,實(shí)現(xiàn)接收信號和發(fā)送信號同步。并對該算法在ADS環(huán)境下進(jìn)行了仿真,仿真結(jié)果表
    發(fā)表于 08-28 10:48 ?1次下載
    如何使用ADS<b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>接收</b>機(jī)碼元<b class='flag-5'>同步</b><b class='flag-5'>算法</b>的設(shè)計(jì)

    HT32F5232學(xué)習(xí)之USART串口實(shí)現(xiàn)發(fā)送接收以及對三種接收方式的思考

    HT32F5232學(xué)習(xí)之USART串口實(shí)現(xiàn)發(fā)送接收以及對三種接收方式的思考
    發(fā)表于 12-02 20:51 ?7次下載
    HT32F5232學(xué)習(xí)之USART串口<b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>發(fā)送</b><b class='flag-5'>接收</b>以及對三種<b class='flag-5'>接收方</b>式的思考

    淺談PLC的異步通信和同步通信

    所謂異步是指發(fā)送接收方之間的數(shù)據(jù)幀不需要嚴(yán)格的同步同步同步是指
    發(fā)表于 01-18 11:12 ?2502次閱讀

    控制系統(tǒng)之間如何實(shí)現(xiàn)時鐘同步?

    控制系統(tǒng)之間如何實(shí)現(xiàn)時鐘同步? 控制系統(tǒng)之間的時鐘同步是確保不同系統(tǒng)之間的時鐘保持一致的過程。它在許多實(shí)時應(yīng)用中非常重要,如分布式系統(tǒng)、通信
    的頭像 發(fā)表于 01-16 14:37 ?1217次閱讀

    同步調(diào)制異步調(diào)制的概念及優(yōu)缺點(diǎn)

    接收方時鐘信號是同步的。這意味著發(fā)送接收方都使用相同的
    的頭像 發(fā)表于 08-14 11:17 ?1910次閱讀