CAN是Controller Area Network 的縮寫(以下稱為CAN),是ISO國際標準化的串行通信協議。在當前的汽車產業中,出于對安全性、舒適性、方便性、低公害、低成本的要求,各種各樣的電子控制系統被開發了出來。由于這些系統之間通信所用的數據類型及對可靠性的要求不盡相同,由多條總線構成的情況很多,線束的數量也隨之增加。為適應“減少線束的數量”、“通過多個LAN,進行大量數據的高速通信”的需要,1986 年德國電氣商博世公司開發出面向汽車的CAN 通信協議。此后,CAN 通過ISO11898 及ISO11519 進行了標準化,現在在歐洲已是汽車網絡的標準協議。
現在,CAN 的高性能和可靠性已被認同,并被廣泛地應用于工業自動化、船舶、醫療設備、工業設備等方面。現場總線是當今自動化領域技術發展的熱點之一,被譽為自動化領域的計算機局域網。它的出現為分布式控制系統實現各節點之間實時、可靠的數據通信提供了強有力的技術支持。
一. CAN總線的產生與發展
控制器局部網(CAN-CONTROLLER AREA NETWORK)是BOSCH公司為現代汽車應用領先推出的一種多主機局部網,由于其卓越性能現已廣泛應用于工業自動化、多種控制設備、交通工具、醫療儀器以及建筑、環境控制等眾多部門。控制器局部網將在我國迅速普及推廣。
隨著計算機硬件、軟件技術及集成電路技術的迅速發展,工業控制系統已成為計算機技術應用領域中最具活力的一個分支,并取得了巨大進步。由于對系統可靠性和靈活性的高要求,工業控制系統的發展主要表現為:控制面向多元化,系統面向分散化,即負載分散、功能分散、危險分散和地域分散。
分散式工業控制系統就是為適應這種需要而發展起來的。這類系統是以微型機為核心,將 5C 技術--COMPUTER(計算機技術)、CONTROL(自動控制技術)、COMMUNICATION(通信技術)、CRT(顯示技術)和 CHANGE(轉換技術)緊密結合的產物。它在適應范圍、可擴展性、可維護性以及抗故障能力等方面,較之分散型儀表控制系統和集中型計算機控制系統都具有明顯的優越性。
典型的分散式控制系統由現場設備、接口與計算設備以及通信設備組成。現場總線(FIELDBUS)能同時滿足過程控制和制造業自動化的需要,因而現場總線已成為工業數據總線領域中最為活躍的一個領域。現場總線的研究與應用已成為工業數據總線領域的熱點。
盡管目前對現場總線的研究尚未能提出一個完善的標準,但現場總線的高性能價格比將吸引眾多工業控制系統采用。同時,正由于現場總線的標準尚未統一,也使得現場總線的應用得以不拘一格地發揮,并將為現場總線的完善提供更加豐富的依據。控制器局部網 CAN正是在這種背景下應運而生的。
由于CAN為愈來愈多不同領域采用和推廣,導致要求各種應用領域通信報文的標準化。為此,1991 年 9 月 PHILIPS SEMICONDUCTORS 制訂并發布了 CAN技術規范(VERSION2.0)。該技術規范包括A和B 兩部分。2.0A給出了曾在CAN技術規范版本1.2 中定義的CAN報文格式,而2.0B給出了標準的和擴展的兩種報文格式。此后,1993 年11 月ISO正式頒布了道路交通運載工具--數字信息交換--高速通信控制器局部網(CAN)國際標準(ISO11898),為控制器局部網標準化、規范化推廣鋪平了道路。
二. CAN總線特點
CAN總線是德國BOSCH公司從80年代初為解決現代汽車中眾多的控制與測試儀器之間的數據交換而開發的一種串行數據通信協議,它是一種多主總線,通信介質可以是雙絞線、同軸電纜或光導纖維。通信速率可達1MBPS。CAN總線通信接口中集成了CAN協議的物理層和數據鏈路層功能,可完成對通信數據的成幀處理,包括位填充、數據塊編碼、循環冗余檢驗、優先級判別等項工作。
CAN協議的一個最大特點是廢除了傳統的站地址編碼,而代之以對通信數據塊進行編碼。采用這種方法的優點可使網絡內的節點個數在理論上不受限制,數據塊的標識碼可由11 位或29 位二進制數組成,因此可以定義211或229 個不同的數據塊,這種按數據塊編碼的方式,還可使不同的節點同時接收到相同的數據,這一點在分布式控制系統中非常有用。數據段長度最多為8 個字節,可滿足通常工業領域中控制命令、工作狀態及測試數據的一般要求。同時,8 個字節不會占用總線時間過長,從而保證了通信的實時性。CAN協議采用CRC 檢驗并可提供相應的錯誤處理功能,保證了數據通信的可靠性。CAN卓越的特性、極高的可靠性和獨特的設計,特別適合工業過程監控設備的互連,因此,越來越受到工業界的
重視,并已公認為最有前途的現場總線之一。
另外,CAN總線采用了多主競爭式總線結構,具有多主站運行和分散仲裁的串行總線以及廣播通信的特點。CAN總線上任意節點可在任意時刻主動地向網絡上其它節點發送信息而不分主次,因此可在各節點之間實現自由通信。CAN總線協議已被國際標準化組織認證,技術比較成熟,控制的芯片已經商品化,性價比高,特別適用于分布式測控系統之間的數通訊。CAN總線插卡可以任意插在PC AT XT兼容機上,方便地構成分布式監控系統。
三. CAN 總線技術介紹
3.1位仲裁
要對數據進行實時處理,就必須將數據快速傳送,這就要求數據的物理傳輸通路有較高的速度。在幾個站同時需要發送數據時,要求快速地進行總線分配。實時處理通過網絡交換的緊急數據有較大的不同。一個快速變化的物理量,如汽車引擎負載,將比類似汽車引擎溫度這樣相對變化較慢的物理量更頻繁地傳送數據并要求更短的延時。CAN 總線以報文為單位進行數據傳送,報文的優先級結合在11 位標識符中,具有最低二進制數的標識符有最高的優先級。這種優先級一旦在系統設計時被確立后就不能再被更改。
總線讀取中的沖突可通過位仲裁解決。當幾個站同時發送報文時,站1 的報文標識符為011111;站2 的報文標識符為0100110;站3 的報文標識符為0100111。所有標識符都有相同的兩位01,直到第3 位進行比較時,站1 的報文被丟掉,因為它的第3 位為高,而其它兩個站的報文第3 位為低。站2 和站3 報文的4、5、6 位相同,直到第7 位時,站3 的報文才被丟失。注意,總線中的信號持續跟蹤最后獲得總線讀取權的站的報文。在此例中,站2 的報文被跟蹤。這種非破壞性位仲裁方法的優點在于,在網絡最終確定哪一個站的報文被傳送以前,報文的起始部分已經在網絡上傳送了。所有未獲得總線讀取權的站都成為具有最高優先權報文
的接收站,并且不會在總線再次空閑前發送報文。
CAN具有較高的效率是因為總線僅僅被那些請求總線懸而未決的站利用,這些請求是根據報文在整個系統中的重要性按順序處理的。這種方法在網絡負載較重時有很多優點,因為總線讀取的優先級已被按順序放在每個報文中了,這可以保證在實時系統中較低的個體隱伏時間。
對于主站的可靠性,由于CAN 協議執行非集中化總線控制,所有主要通信,包括總線讀取(許可)控制,在系統中分幾次完成。這是實現有較高可靠性的通信系統的唯一方法
3.2 CAN 與其它通信方案的比較
在實踐中,有兩種重要的總線分配方法:按時間表分配和按需要分配。在第一種方法中 ,不管每個節點是否申請總線,都對每個節點按最大期間分配。由此,總線可被分配給每個站并且是唯一的站,而不論其是立即進行總線存取或在一特定時間進行總線存取。這將保證在總線存取時有明確的總線分配。在第二種方法中,總線按傳送數據的基本要求分配給一個站 ,總線系統按站希望的傳送分配(如:Ethernet CSMA/CD)。因此,當多個站同時請求總線存取時,總線將終止所有站的請求,這時將不會有任何一個站獲得總線分配。為了分配總線,多于一個總線存取是必要的。CAN實現總線分配的方法,可保證當不同的站申請總線存取時,明確地進行總線分配。這種位仲裁的方法可以解決當兩個站同時發送數據時產生的碰撞問題。不同于Ethernet 網絡的消息仲裁,CAN 的非破壞性解決總線存取沖突的方法,確保在不傳送有用消息時總線不被占用。甚至當總線在重負載情況下,以消息內容為優先的總線存取也被證明是一種有效的系統。雖然總線的傳輸能力不足,所有未解決的傳輸請求都按重要性順序來處理。在CSMA/CD 這樣的網絡中,如Ethernet,系統往往由于過載而崩潰,而這種情況在CAN中不會發生。
3.3 CAN 的報文格式
在總線中傳送的報文,每幀由7 部分組成,見圖3。CAN協議支持兩種報文格式,其唯一的不同是標識符(ID)長度不同,標準格式為11 位,擴展格式為29 位。在標準格式中,報文的起始位稱為幀起始(SOF),然后是由11 位標識符和遠程發送請求位(RTR)組成的仲裁場。
RTR 位標明是數據幀還是請求幀,在請求幀中沒有數據字節。控制場包括標識符擴展位(IDE),指出是標準格式還是擴展格式。它還包括一個保留位 (ro),為將來擴展使用。它的最后四個字節用來指明數據場中數據的長度(DLC)。數據場范圍為0~8 個字節,其后有一個檢測數據錯誤的循環冗余檢查(CRC)。
應答場(ACK)包括應答位和應答分隔符。發送站發送的這兩位均為隱性電平(邏輯1),這時正確接收報文的接收站發送主控電平(邏輯0)覆蓋它。用這種方法,發送站可以保證網絡中至少有一個站能正確接收到報文。報文的尾部由幀結束標出。在相鄰的兩條報文間有一很短的間隔位,如果這時沒有站進行總線存取,總線將處于空閑狀態。
3.4 數據錯誤檢測
不同于其它總線,CAN 協議不能使用應答信息。事實上,它可以將發生的任何錯誤用信號發出。CAN協議可使用五種檢查錯誤的方法,其中前三種為基于報文內容檢查。
3.4.1 循環冗余檢查(CRC)
在一幀報文中加入冗余檢查位可保證報文正確。接收站通過CRC 可判斷報文是否有錯。
3.4.2 幀檢查
這種方法通過位場檢查幀的格式和大小來確定報文的正確性,用于檢查格式上的錯誤。
3.4.3.應答錯誤
如前所述,被接收到的幀由接收站通過明確的應答來確認。如果發送站未收到應答,那么表明接收站發現幀中有錯誤,也就是說,ACK場已損壞或網絡中的報文無站接收。CAN協議也可通過位檢查的方法探測錯誤。
3.4.4 總線檢測
有時,CAN 中的一個節點可監測自己發出的信號。因此,發送報文的站可以觀測總線電平并探測發送位和接收位的差異。
3.4.5 位填充
一幀報文中的每一位都由不歸零碼表示,可保證位編碼的最大效率。然而,如果在一幀報文中有太多相同電平的位,就有可能失去同步。為保證同步,同步沿用位填充產生。在五個生。在五個連續相等位后,發送站自動插入一個與之互補的補碼位;接收時,這個填充位被自動丟掉。例如,五個連續的低電平位后,CAN 自動插入一個高電平位。CAN通過這種編碼規則檢查錯誤,如果在一幀報文中有6 個相同位,CAN 就知道發生了錯誤。如果至少有一個站通過以上方法探測到一個或多個錯誤,它將發送出錯標志終止當前的發送。這可以阻止其它站接收錯誤的報文,并保證網絡上報文的一致性。當大量發送數據被終止后,發送站會自動地重新發送數據。作為規則,在探測到錯誤后23 個位周期內重新開始發送。在特殊場合,系統的恢復時間為31 個位周期。
但這種方法存在一個問題,即一個發生錯誤的站將導致所有數據被終止,其中也包括正確的數據。因此,如果不采取自監測措施,總線系統應采用模塊化設計。為此,CAN 協議提供一種將偶然錯誤從永久錯誤和局部站失敗中區別出來的辦法。這種方法可以通過對出錯站統計評估來確定一個站本身的錯誤并進入一種不會對其它站產生不良影響的運行方法來實現,即站可以通過關閉自己來阻止正常數據因被錯誤地當成不正確的數據而被終止。
3.4.6 CAN可靠性
為防止汽車在使用壽命期內由于數據交換錯誤而對司機造成危險,汽車的安全系統要求數據傳輸具有較高的安全性。如果數據傳輸的可靠性足夠高,或者殘留下來的數據錯誤足夠低的話,這一目標不難實現。從總線系統數據的角度看,可靠性可以理解為,對傳輸過程產生的數據錯誤的識別能力。
殘余數據錯誤的概率可以通過對數據傳輸可靠性的統計測量獲得。它描述了傳送數據被破壞和這種破壞不能被探測出來的概率。殘余數據錯誤概率必須非常小,使其在系統整個壽命周期內,按平均統計時幾乎檢測不到。計算殘余錯誤概率要求能夠對數據錯誤進行分類 ,并且數據傳輸路徑可由一模型描述。如果要確定CAN的殘余錯誤概率,我們可將殘留錯誤的概率作為具有80~90 位的報文傳送時位錯誤概率的函數,并假定這個系統中有5~10 個站,并且錯誤率為1/1000,那么最大位錯誤概率為10—13 數量級。例如,CAN 網絡的數據傳輸率最大為1Mbps,如果數據傳輸能力僅使用50%,那么對于一個工作壽命4000小時、平均報文長度為 80 位的系統,所傳送的數據總量為9×1010。在系統運行壽命期內,不可檢測的傳輸錯誤的統計平均小于10—2 量級。換句話說,一個系統按每年365 天,每天工作8 小時,每秒錯誤率為0. 7 計算,那么按統計平均,每1000 年才會發生一個不可檢測的錯誤。
四.應用舉例
某醫院現有5 臺16T/H德國菲斯曼燃氣鍋爐,向洗衣房、制劑室、供應室、生活用水、暖氣等設施提供5kg/cm2 的蒸汽,全年耗用天然氣1200 萬m3,耗用20 萬噸自來水。醫院采用接力式方式供熱,對熱網進行地域性管理,分四大供熱區。其中冬季暖氣的用氣量很大,據此設計了基于CAN現場總線的分布式鍋爐蒸汽熱網智能監控系統。現場應用表明:該樓宇自動化系統具有抗干擾能力強,現場組態容易,網絡化程度高,人機界面友好等特點。
五.存在問題
目前現場總線技術在我國的應用已取得很大進展,但也存在一些問題,制約了其推廣。
在工程應用方面,工程投資比較大。雖然各種現場總線都把節省費用當成自己的主要優點,但在實際應用中現場總線的投資比傳統控制系統要大。一是試用的系統規模太小;二是試用的系統并不分散或者是利用原有布線的改造項目,因此無法充分發揮現場總線節省電纜的優勢。
其次,調試和運行維護比較難。由于現階段熟練掌握現場總線的應用技術和開發技術的人才少,企業在調試和運行時經常會遇到困難。因此,企業在選擇系統集成商時,應選擇技術力量比較強,比較有經驗的單位。
再者,與傳統控制系統相比優點不明顯。以智能化現場儀表為基礎的現場總線系統與傳統系統相比,其優點不僅在于控制方面,更多的在于自診斷、自校正等自動管理方面。但是,目前國內用的系統大多數太小,沒有把管理自動化和遠程診斷功能納入系統,因此無法發揮現場總線系統降低運行維護費用的優勢。
在技術方面,當總線切斷時,系統有可能產生不可預知的后果,用戶希望這時系統的效能可以降低,但不能崩潰,這一點目前許多現場總線不能保證;現有的防爆規定限制了總線長度和總線上所掛設備的數量,也就限制了現場總線節省電纜優點的發揮;系統組態參數過分復雜,不容易掌握。但組態參數設定得好壞,對系統性能影響很大。
在應用中,現場總線的開放、互聯性及互操作性決定了與之俱來的不可避免的安全問題。
外部網是一個由現場總線實現的自動化系統,是和企業的Intranet 緊密結合在一起的,存在著與In ternet普通應用相同的種種威脅,包括竊聽、盜取資料、非法獲取控制權、進行破壞、阻礙通信等。要解決這些問題,必須建立起一套適合企業的針對現場總線應用的安全策略。
在Intranet內部,人們容易放松警惕。由于現場總線多應用于化工、電氣及樓宇自動化控制中,這些場合都要求系統連續運行,因此現場總線可能受到的攻擊時間與普通應用相比長得多。
基于安全情況,可以考慮將各子系統設計得較為獨立,使一個子系統受到破壞不會影響到整個系統;采用通信控制器將總線與以太網相聯,改善通信控制器的功能,可以起到一定程度的安全防范作用,包括拒絕非法訪問,危險時將總線與以太網隔離等;進行合理的冗余設計,以提高系統穩定性。
六.結論
綜上所述,現場總線并不是為解決傳統控制系統不能解決的問題而出現的,它的主要優點是更靈活、更開放,并為采用新型系統維護方式和企業管理模式提供了可能。但對于以價格為首選條件的場合,系統規模較小、控制對象分布比較集中的場合,以及沒有擴展設備智能診斷和管理要求的場合,現場總線并不一定是最佳選擇。
參考文獻
[1]饒運濤等,現場總線CAN原理與應用技術,北京:北京航空航天大學出版社,2007.8
[2]鄔寬明, CAN總線原理和應用系統設計. 北京:北京航空航天大學出版社,2002.3
[3] 韓兵,現場總線控制系統應用實例. 北京:北京航空航天大學出版社,2006.8