熟悉CAN通訊的工程師們一般都會(huì)見過“反碼位”一專業(yè)術(shù)語,,但它到底是什么?到底有什么用,?也許很多人對(duì)其并沒有深入的理解,,本文將讓大家對(duì)此不再迷惑,。
數(shù)據(jù)數(shù)字編碼具有很多方法,諸如非歸零(NRZ),、曼徹斯特或脈寬編碼,,它們的區(qū)別在于用來表示一個(gè)位的時(shí)隙的數(shù)目不同,如圖 1所示,。非歸零電平編碼的信號(hào)電平在整個(gè)位時(shí)間里保持不變,,因此只需要一個(gè)時(shí)隙來表示一個(gè)位。而曼徹斯特編碼的信號(hào)在一個(gè)位時(shí)間內(nèi)發(fā)生變化,,因此需要兩個(gè)時(shí)隙來表示一個(gè)位,。曼徹斯特編碼的優(yōu)點(diǎn)是每個(gè)位都有一個(gè)信號(hào)邊沿用來實(shí)現(xiàn)位同步(Self-clocking code)。但是曼徹斯特編碼和非歸零編碼相比,,在相同的位時(shí)間(位頻率)時(shí),,位速率只能達(dá)到非歸零碼一半。由于非歸零編碼的信號(hào)電平可長時(shí)間保持不變(取決于所傳輸?shù)臄?shù)據(jù)),,因此有必要采取適當(dāng)?shù)拇胧┮源_保不超過兩個(gè)信號(hào)沿之間最大允許的時(shí)間間隔,。重新同步點(diǎn)之間最大的時(shí)間間隔由節(jié)點(diǎn)振蕩器的誤差決定。重新同步可通過應(yīng)用“位填充”的方法實(shí)現(xiàn),。這種方法是在一定數(shù)量的恒定位電平之后將一個(gè)反碼插入到位流中,。
圖 1 NRZ和曼徹斯特編碼的位表示
CAN協(xié)議中應(yīng)用的是帶位填充(填充寬度為5位)的NRZ信號(hào)編碼,它保證了具有足夠同步能力的最高傳輸性能,。這種類型的編碼還提供非常良好的信號(hào)輻射特性(總線輻射的能量大致上和傳輸信號(hào)的頻率以及信號(hào)邊沿的數(shù)量成比例),。
CAN協(xié)議中應(yīng)用NRZ編碼的部分包括SOF、仲裁場,、控制場,、數(shù)據(jù)場、數(shù)據(jù)幀和遠(yuǎn)程請(qǐng)求幀的CRC序列,。發(fā)送器一檢測到5個(gè)連續(xù)相同值的序列,,它就會(huì)在實(shí)際傳輸?shù)奈涣髦胁迦胍粋€(gè)反碼位。數(shù)據(jù)幀或遠(yuǎn)程幀剩下的部分(CRC分隔符,、ACK場和EOF)都有一個(gè)固定的形式(隱性電平),,并且不采用位填充進(jìn)行發(fā)送。出錯(cuò)和超載幀也是如此,。