《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 業界動態 > 基于卷煙機組的CAN總線實時監聽器設計淺析

基于卷煙機組的CAN總線實時監聽器設計淺析

2019-04-27

  引 言

  卷煙生產中的卷煙機組主要包括兩大部分,上位機MLP,用于為控制系統和檢測系統提供操作和顯示的裝置,它包括一個工業PC和一個監視器。以及下位機SRP,包括傳感器,調節裝置或者檢測裝置。SRP主要包括四種結點1)SPS,2)HIP,3)CIS,4)SRM。上位機和下位機各結點之間的通信是頻繁的,數據對象眾多,數據種類也繁多,包括參數上傳,下傳,指令,域數據等等,所以在這之中,難免會因為操作人員操作失誤或者控制器本身的原因導致錯誤,但錯誤發生的時候需要盡快的分析,發現錯誤,解決錯誤。因此我們需要建立一個可靠的錯誤判斷機制。本文所討論的CANBUS實時監聽器正是應這種需求而產生的。工作人員根據實時監聽器所捕獲的并且友好顯示的線路上的適時數據便可分析出是哪一方出了問題,出了什么類型的問題。這對安全生產,準確控制起了舉足輕重的作用。

  (一) 硬件實現

  在實時監聽器的實現中,我們選擇采用了周立功公司的PCI-9810非智能CAN接口卡作為硬件接口用于接收捕獲CAN總線上的傳輸數據。如下圖

  PCI-9810非智能CAN接口卡是具有高性能價格比的CAN-bus總線通訊適配卡,它使PC機方便的連接到CAN總線上,實現CAN2.0B協議的連接通訊。它是一款采用專用PCI接口轉換芯片設計的非智能型CAN接口卡,即插即用,符合PCI2.1規范。它采用中斷接收方式,可最大限度減輕占用PC的負荷;具有最多8幀的數據緩沖區。另外我們采用了周立功公司提供的Windows驅動程序升級版PCI-9810BWDM驅動文件將其驅動。

  1250015W1_0.jpg

  (二) 界面軟件實現

  界面軟件實現主要包括四大方面,1)軟件平臺的選擇,2)對硬件接口CAN卡的使用,3)利用接口接收CANBUS線路上數據的實現,4)所接收數據的處理(主要是判斷和顯示)的實現。

  〈1〉軟件平臺的選擇—DELPHI

  系統的開發可利用多種程序設計語言,如DELPHI,VB,VC,PB等語言都是面向對象的程序設計語言,但把幾者相比較,DELPHI是唯一一套能夠同時適用于開發數據庫應用、網絡及WEB 應用等所有軟件的高效率開發環境,且第三方控件多,開發比較快,且設計界面比VB,VC,PB 靈活。基于以上因素,考慮到所要監聽CANBUS線路的傳輸數據信息量大、種類多,以及信息之間相對獨立,又有關系且必須備有優良的圖形顯示等特點,我們選擇DELPHI作為軟件開發平臺。

  〈2〉對硬件接口PCI-9810的操作的實現

  在DELPHI程序中,我們是通過調用周立功提供的通用VCI動態鏈接庫來實現對硬件接口PCI-9810的操作的,該動態鏈接庫提供了界面軟件能在windows下運行必需的代碼和其他資源,其中主要包括十個接口函數如設備相關函數和CAN通訊相關函數以及相關的數據結構的定義。把動態鏈接庫文件夾添加到項目文件夾,然后把庫源文件添加到程序代碼的應用文件單元即可實現對動態鏈接庫的調用,也就實現了對PCI-9810卡的打開,關閉,啟動,復位,收發數據等操作。

  〈3〉CANBUS線路上數據的實時接收

  CANBUS線路上的數據對CAN卡來說有著不期性,所以要能對數據實時,準確的接收,必須要通過程序實現一種功能即線路上一旦有數據,就能捕獲。對于此,我們采用的方式是利用多線程。即在程序中專門開辟一個線程用于對線路的監聽,接收。

  關于多線程

  在32位的windows系統中,系統可以同時運行多個進程,一個調入內存并準備執行的應用程序稱為一個進程,它由裝入內存的程序代碼和操作系統及由此創建的應用程序執行環境組成,進程就是應用程序的運行實例。每個進程都有自己私有的虛擬地址空間和動態分配的內存,以及文件,線程和其它模塊。每個進程都有一個主線程,但可以建立另外的線程。進程中的線程是并行執行的,每個線程占用CPU的時間由系統來劃分,可以把線程看成是操作系統分配CPU時間的基本實體。每個進程也可以同時執行多個線程并由系統不停地在各個線程之間切換。

  多線程的DELPHI實現

  雖然Windows 提供了比較多的多線程設計的API 函數,但是直接使用API 函數一方面極其不方便,而且使用不當還容易出錯。為避免這個問題,我們采用了DEPHI所提供的方法即繼承TThread類產生線程對象。TThread由DELPHI的VCL類庫提供用于線程編程。在Tthread類中封裝了windows中關于線程機制的API函數,繼承TThread類產生的線程對象就代表了實際程序中的一個線程。線程對象通過封裝使用線程所需的內容大大簡化了多線程問題的處理。另外,在DELPHI中,Tthread在Classes單元中聲明,直接從Tobject繼承下來的,因此,它不是組件。Tthread是個抽象類,所以不能創建Tthread的實例,而只能創建其派生類的實例。在本程序中利用Ttread類來編寫多線程的步驟如下

  (1)從Tthread類派生出一個新的線程類。即建立的TreceiveThread。

  (2)創建線程對象。即在Types里面定義thread1:TreceiveThread。

  (3)在DELPHI自動生成的用于保存派生類代碼的新的單獨的文件中重載Execute過程,在該過程中將對CAN線路上的數據實時接收并調用對接收到的數據進行處理的基本顯示和分類顯示函數。在Execute過程中使用了repeat…。.until語句來判斷過程是否結束。

  (4)如果Execute過程執行完畢,則該線程就結束了,并釋放線程占用的棧空間。

  〈4〉對所接收的數據進行處理

  對數據的實時處理包括兩方面:1)將接收到的數據楨按照接收數據的數據結構完全顯示,這包括楨類型,楨格式,楨ID,楨數據等等。2)將數據進行更深一層的分析判斷出數據的真實含義,并將其填入對應的文本框或者畫出對應的狀態圖等等。

  (1)對于第一種基本顯示,我們采用的是用DELPHI提供的listbox控件進行

  滾動顯示,listbox的容量足夠本顯示的需要,另外,我們還添加了一個按鈕控件用于按照操作人員的需要隨時清除listbox里面的內容。

  (2)對于第二種分類顯示。對于不同的數據,我們將用不同的分析處理方法進行顯示。根據數據的現實含義,主要分為1)上,下傳參數。2)域請求和域數據,3)下傳指令和上傳消息。下面將分別介紹處理方法:

  1 利用數據庫系統進行上,下傳參數的顯示

  在CAN線路上傳輸的參數不僅多達近200種,而且有上傳和下傳之分,可見所要顯示的量之大,加上上下傳的參數有著相同的數據結構,所以我們采用查詢預先建立好的數據庫的方法來進行顯示。

  關于數據庫系統 數據庫系統為我們提供了一種把與我們的工作和生活緊密相關的信息集合在一起的方法。它還提供了在某個集中的地方存儲和維護這些信息的方法。數據庫系統主要由三大部分組成:數據庫管理系統,數據庫應用程序,數據庫。

  數據庫系統的DELPHI實現 (1)建立數據庫,在本項目中,我們是利用Microsoft Access 建立了一個關系數據庫(由若干表組成的數據庫)。其中包含了一張表,該表的字段分為id表示用以判斷的字符串,以及locaTIon表示參數值應填的文本框代號。(2)在應用程序中要實現對所建立的數據庫的訪問需要用到數據庫引擎和數據庫訪問組件以及數據庫控制組件,DELPHI7中提供了BDE,ADO數據引擎,考慮到項目中的數據庫應用相對簡單,我們選擇了常用的BDE(Borland Database Engine)控制讀取所建立的數據庫,具體操作為1)利用DEPHI7文件夾中的BDE Administer為所建立的數據庫創建別名。2)在窗體中添加數據庫訪問組件和數據庫控制組件(包括Data Access頁和BDE頁中的組件)來實現應用程序與數據庫之間的聯系。項目中,我們用Table組件來封裝數據表,通過BDE數據引擎從數據庫表格中取得數據(參數值應填的文本框代號)并通過DataSource組件將數據傳遞給數據控制組件TDBEdit,3)在程序中,我們通過TTable提供的Gotokey的方法實現對數據庫的查找,以及通過對TDBEdit中的數據的使用。實現了將不同參數值填到其唯一對應的文本框中。

  2 域請求和域數據的處理

  因為域數據的多類,多變性,以及不確定性,我們不能用處理參數一樣的數據庫或者其他統一處理的方法,所以在程序中我們使用的是用多層復合選擇語句進行判斷然后根據不同的域數據做出不同的處理,域數據是根據標識符上傳的,只有數據沒有別的判斷信息,對域數據的判斷決定于域請求的數據內容,因此在程序中首先判斷楨是否為域請求,如果是,則將楨數據賦值對應的變量,這些變量保存的便是域數據的判斷信息,而如果根據標識符判斷出為域數據,則根據變量保存的信息進行對應的處理。

  在域數據的處理中,很多情況是要繪出曲線。對此,我們選擇了DELPHI的Tchart控件。利用其Series屬性里面的Fast-line,將收到的數據正確的繪成曲線。

  3 指令和消息的處理

  指令和消息的處理類似于域數據的處理,也是采用多層復合選擇語句進行判斷,然后做出相應的處理,在此,相應的處理即將指令,消息的相關信息填入文本框。

  〈5〉軟件流程圖

  125101c92_0.jpg

  數據處理函數dataprocess()流程圖

  1252013627_0.jpg

  結 論

  在本項目中,CAN卡PCI-9810的控制器是SJA1000,在收發數據方面它支持正常和只聽兩種模式,在監聽器的實際運行中我們選用只聽模式進行線路監聽,取的了不錯的效果,而且在界面的設計過程中上我們添加了發送部分,這是便于進行CAN卡的檢測 以及數據接收的調試,此時需要選擇正常模式。

  本文作者的創新點:結合實際情況的具體需要,合理的選用了Delphi作為軟件開發平臺,在實時性方面,我們選擇了Delphi自身提供的線程類,而不是按照常規選擇windows提供的API函數,從而使程序的設計變的簡潔,另外在數據的處理方面,我們不僅采用了通常的數據庫方法,而且還根據實際需要采用了其他簡易可行的方法。很好地完成了需求。

  總之,借鑒前者地經驗加上實際地創新我們成功設計了實時監聽器并通過了實際檢驗,本項目所設計的實時監聽器在實用性,實時性,準確性,以及友好性上都是很不錯的。


本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 又黄又爽又色的视频在线看 | 国产色婷婷精品综合在线 | 日韩毛片在线影视 | 波多野结衣久久高清免费 | 亚洲精品网站在线 | 精品久久久久久久九九九精品 | 伦理片在线观看网站资源 | 亚洲欧美国产一区二区三区 | 一级特黄特黄的大片免费 | 性欧美video另类hd高清 | 日本操片| 亚洲欧洲尹人香蕉综合 | 免费精品国产 | 尤物视频一区 | 天堂在线链接 | 性欧美黑人巨大videos | 日韩操操操 | 野花的视频在线观看免费高清 | 最近的免费中文字幕视频 | 午夜96影视 | 亚洲欧美精品综合中文字幕 | 亚洲香蕉伊在人在线观看9 亚洲香蕉一区二区三区在线观看 | 天天色综合2 | 禁视频网站在线观看漫画 | 99爱在线视频这里只有精品 | 宅男在线永久免费观看99 | 欧美日韩免费 | 波多野结衣在线观看一区二区三区 | 一级国产视频 | 日韩新片在线观看 | 日本午色www高清视频 | 在线视频一本 | 看黄网站在线看 | 又爽又黄又无遮挡网站 | 久久99久久99精品免观看麻豆 | 在线观看你懂的视频 | 亚洲一区二区三区在线免费观看 | 涩涩涩视频在线观看免费 | 欧美综合自拍亚洲综合 | www.国产成人| 最近高清无吗免费看 |