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

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

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

【文章轉(zhuǎn)載】CANoe與DDS

北匯信息POLELINK ? 2023-01-13 09:47 ? 次閱讀

DDS(Data Distribution Service)是OMG組織(Object Management Group)最早在2004年發(fā)布的分布式實(shí)時(shí)通信中間件標(biāo)準(zhǔn),旨在使用發(fā)布-訂閱模式實(shí)現(xiàn)可靠、高性能、互操作、實(shí)時(shí)、可擴(kuò)展的數(shù)據(jù)交換。

7efbe260-918f-11ed-ad0d-dac502259ad0.jpg

圖1:DDS軟件示例架構(gòu)圖

在汽車領(lǐng)域,Adaptive AUTOSAR于2018年引用DDS作為可選擇的通信方式之一。DDS的實(shí)時(shí)性恰好適合于自動(dòng)駕駛系統(tǒng)。因?yàn)樵谶@類系統(tǒng)中,通常會(huì)存在感知、預(yù)測(cè)、決策和定位等模塊,這些模塊都需要非常頻繁地高速交換數(shù)據(jù)。借助DDS,可以很好地滿足這類系統(tǒng)的通信需求。憑借以數(shù)據(jù)為中心及豐富的QoS機(jī)制,DDS在汽車行業(yè)中逐漸受到青睞,汽車制造商及供應(yīng)商將DDS作為系統(tǒng)中可選的通訊中間件之一,從而增強(qiáng)其產(chǎn)品的功能特性及可靠性。

DDS具有以數(shù)據(jù)為中心、即插即用、豐富的QoS等特性,這意味著DDS在網(wǎng)絡(luò)傳輸中對(duì)各層級(jí)數(shù)據(jù)需要提供豐富且冗長(zhǎng)的Header信息,方便通訊雙方識(shí)別所需內(nèi)容,因此對(duì)硬件及網(wǎng)絡(luò)中的傳輸和數(shù)據(jù)處理性能提出了較高要求。因此在未來(lái),DDS、SOME/IP等SOA通信中間件與車載總線類似,在車內(nèi)將會(huì)是多種中間件長(zhǎng)期共存的狀態(tài)。

DDS有諸多協(xié)議規(guī)范,其中最核心的2個(gè)規(guī)范是:DDS規(guī)范和DDSI-RTPS規(guī)范。DDS規(guī)范描述了分布式應(yīng)用通信和以數(shù)據(jù)為中心的發(fā)布-訂閱模型,定義了應(yīng)用接口(API)和通信語(yǔ)義,從而實(shí)現(xiàn)“在正確的時(shí)間向正確的地點(diǎn)有效可靠地傳遞正確的信息”。DDS規(guī)范提供了DDS核心概念在與平臺(tái)無(wú)關(guān)模型(PIM)中的抽象定義,以及相對(duì)于平臺(tái)專用模型(PSM)中的映射,從應(yīng)用開(kāi)發(fā)者視角詮釋了DDS的核心定義。但是,單純依靠DDS規(guī)范使得各DDS中間件供應(yīng)商對(duì)于具體通信傳輸介質(zhì)、行為和數(shù)據(jù)包結(jié)構(gòu)有著自己的理解,若通信系統(tǒng)中各設(shè)備來(lái)自不同的DDS中間件供應(yīng)商,其互操作性可能會(huì)存在問(wèn)題。

為解決這一問(wèn)題,OMG隨后發(fā)布了DDSI-RTPS規(guī)范,對(duì)通信結(jié)構(gòu)、數(shù)據(jù)消息結(jié)構(gòu)、收發(fā)行為、服務(wù)發(fā)現(xiàn)進(jìn)行了定義,從而保證來(lái)自不同廠商的DDS中間件的互操作性。目前納入DDSI-RTPS規(guī)范中的底層通訊協(xié)議為UDP/IP。OMG組織目前暫未對(duì)DDS的測(cè)試規(guī)范進(jìn)行定義。

7f21735e-918f-11ed-ad0d-dac502259ad0.jpg

圖2:DDS數(shù)據(jù)交互簡(jiǎn)化拓?fù)鋱D

DDS中重要概念:

>

Domain

連接所有能夠互相通信的應(yīng)用程序的分布式概念,只有在同一個(gè)Domain下的Publisher和Subscriber能夠互相通信,不同Domain的應(yīng)用程序不知道彼此的存在,Domain通過(guò)DomainID進(jìn)行區(qū)分。Domain中包含了DomainParticipant,后者代表了同一個(gè)Domain下參與通訊的應(yīng)用程序,同時(shí)也是Publisher、Subscriber、Topic的工廠。

>

Topic

Publisher和Subscriber互相通訊的數(shù)據(jù)本身,其名稱(Topic Name)在一個(gè)Domain中是唯一的。

>

DataWriter

基于綁定的Topic,由應(yīng)用程序發(fā)送數(shù)據(jù)的實(shí)體。1個(gè)DataWriter隸屬于1個(gè)Publisher,同時(shí)1個(gè)DataWriter對(duì)應(yīng)于1個(gè)Topic。

>

DataReader

可使應(yīng)用程序聲明期望的Topic數(shù)據(jù),以及訪問(wèn)Subscriber收到的數(shù)據(jù)。1個(gè)DataReader隸屬于1個(gè)Subscriber,1個(gè)DataReader對(duì)應(yīng)1個(gè)Topic。

>

Publisher

負(fù)責(zé)發(fā)布實(shí)際Topic數(shù)據(jù)的實(shí)體,可以創(chuàng)建及配置多個(gè)DataWriter并綁定相應(yīng)若干Topic。

>

Subscriber

負(fù)責(zé)接收訂閱Topic數(shù)據(jù)的實(shí)體,可以創(chuàng)建及配置多個(gè)DataReader并綁定相應(yīng)若干Topic。

>

QoS

服務(wù)質(zhì)量(Quality of Service)是控制DDS服務(wù)的一系列特性。Topic、DataWriter、DataReader、Publisher、Subscriber以及DomainParticipant各實(shí)體均可配置其各自的QoS規(guī)則,這些QoS互相存在兼容性檢查。若通信雙方QoS不兼容,則無(wú)法建立通信。目前DDS v1.4版本規(guī)范定義了Durability、LiveLiness、Reliability、LifeSpan、History等QoS機(jī)制。

CANoe中開(kāi)始支持DDS

隨著DDS開(kāi)始在汽車電子領(lǐng)域的應(yīng)用,Vector應(yīng)客戶需求在CANoe 16 SP3版本中開(kāi)始支持DDS的仿真、分析與測(cè)試。DDS的通訊模型基于CANoe中的Communication Concept(ComCo)實(shí)現(xiàn)。

基于CANoe建立DDS的仿真和解析工程環(huán)境,可以充分利用CANoe及其測(cè)試工具鏈現(xiàn)有的優(yōu)勢(shì)特性:

>

CANoe是汽車電子、IoT、航空航天等多領(lǐng)域仿真及測(cè)試的一站式整合平臺(tái),支持CAN、CAN FD、CAN XL、LIN、FlexRay、SOME/IP、AUTOSAR PDU(CP/AP)、DoIP、CCP/XCP、NM網(wǎng)絡(luò)管理、UDS、Cyber Security(SecOC、TLS/DTLS、IPsec、MACsec等)、E2E、全球充電協(xié)議、MQTT、HTTP、WLAN、BLE等多種總線和協(xié)議;

>

采用用戶熟悉的CAPL、C#Python語(yǔ)言實(shí)現(xiàn);

>

支持SIL/HIL、通信路由、網(wǎng)絡(luò)仿真、數(shù)據(jù)分析/記錄、診斷/刷寫、電源管理、I/O控制等多種場(chǎng)景;

>

極具性價(jià)比的測(cè)試設(shè)計(jì)及測(cè)試腳本開(kāi)發(fā)環(huán)境——vTESTstudio;

>

無(wú)縫耦合整車動(dòng)力學(xué)模型及ADAS場(chǎng)景仿真模型工具DYNA4,或基于FMI/FMU、FDX、XIL API、COM、SIL KIT整合第三方測(cè)試工具鏈;

>

匹配汽車電子敏捷開(kāi)發(fā)流程的CI/CT工具鏈體系。

如何在CANoe中創(chuàng)建DDS仿真及解析工程?通過(guò)下圖新建Distributed Objects工程:

7f367254-918f-11ed-ad0d-dac502259ad0.png

圖3:新建CANoe DO工程

而后可在主界面中看到Communication Setup界面,該界面也可通過(guò)CANoe上方標(biāo)簽頁(yè)Simulation下打開(kāi)。隨后依據(jù)下圖指引新建DDS通信接口描述文件vCDL:

7f439fc4-918f-11ed-ad0d-dac502259ad0.png

圖4:新建DDS通信接口描述文件

在選擇vCDL文件保存路徑及文件名后(注意路徑及文件名不能包含中文及特殊字符),依據(jù)下圖指引打開(kāi)編輯:

7f502f64-918f-11ed-ad0d-dac502259ad0.png

圖5:編輯DDS通信接口描述文件

vCDL語(yǔ)言(Vector Communication Description Language)作為在CANoe Communication Concept中用于描述通信對(duì)象的語(yǔ)言,通過(guò)Distributed Objects(DO)對(duì)DDS的數(shù)據(jù)對(duì)象進(jìn)行定義。DO的consumed value對(duì)應(yīng)DDS DataReader;provided value對(duì)應(yīng)DDS DataWriter。

以下圖示例說(shuō)明:

定義結(jié)構(gòu)體作為Topic Type(即HealthData);

在interface(即IMonitor)中將該結(jié)構(gòu)體作為consumed value(也可作為provided value)并進(jìn)行實(shí)例化(即healthData),從而隱式聲明DDS DataReader,另顯式聲明名為“/Monitor/healthData”的Topic;

最終對(duì)該interface(即IMonitor)分別實(shí)例化為Monitor和Sensor,作為Subscriber和Publisher;

其中Sensor的類型為reverse,代表依據(jù)IMonitor中的consumed value(即healthData)反向作為provided value。

7f5d90be-918f-11ed-ad0d-dac502259ad0.png

圖6:vCDL中對(duì)DDS的通信接口定義示例

vCDL DDS的結(jié)構(gòu)體中可以包含如下數(shù)據(jù)類型:uint或int(8、16、32、64bit),Bool,Double,F(xiàn)loat,String,Struct,Array,List,Bytes等,并在逐漸完善中。CANoe Help文檔中提供了DDS IDL數(shù)據(jù)類型與vCDL數(shù)據(jù)類型的詳細(xì)對(duì)應(yīng)關(guān)系。

當(dāng)前版本的vCDL中,可對(duì)consumed value(DDS DataReader)和provided value(DDS DataWriter)進(jìn)行QoS規(guī)則設(shè)置,包括:Reliability、History、Durability、Lifespan、Liveliness,更多的QoS規(guī)則會(huì)在CANoe后續(xù)版本中完善。

其他對(duì)于DDS Binding時(shí)的屬性配置可參考詳情:CANoe 16 SP3 Help文檔中的“Distributed Objects (DOs) for Data Distribution Service (DDS)”頁(yè)面專題

當(dāng)完成DDS的通信接口描述文件創(chuàng)建后,CANoe會(huì)自動(dòng)生成若干觀測(cè)事件及數(shù)據(jù)對(duì)象,包括DataWriter和DataReader的匹配/不匹配事件信息、服務(wù)發(fā)現(xiàn)信息、數(shù)據(jù)Sample信息、Built-in Topic信息等,以DO體現(xiàn)。

用戶可在“.. \Sample Configurations 16.3.110\Connectivity\DDS\DDSBasic”中了解DDS Demo示例工程。該工程運(yùn)行后,在Trace窗口可查看詳細(xì)的DDS仿真和解析數(shù)據(jù)內(nèi)容。

7f6995d0-918f-11ed-ad0d-dac502259ad0.png

圖7:CANoe中DDS工程運(yùn)行狀態(tài)

由于DDS協(xié)議簇范圍廣,存在較多用戶自定義實(shí)現(xiàn),除去當(dāng)前針對(duì)ECU仿真及測(cè)試需要的DDS功能支持外,也滿足ROS2集成的功能。更多DDS功能將在后續(xù)CANoe版本中完善。

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

    關(guān)注

    57

    文章

    2663

    瀏覽量

    462441
  • DDS
    DDS
    +關(guān)注

    關(guān)注

    21

    文章

    625

    瀏覽量

    152288
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    車載通信與DDS標(biāo)準(zhǔn)解讀系列(5):DDS-Security

    本文將從DDS系統(tǒng)安全風(fēng)險(xiǎn)分析切入,對(duì)系統(tǒng)的實(shí)現(xiàn)的認(rèn)證、訪問(wèn)控制、加密環(huán)節(jié)等安全機(jī)制做介紹。
    的頭像 發(fā)表于 07-19 10:55 ?3702次閱讀
    車載通信與<b class='flag-5'>DDS</b>標(biāo)準(zhǔn)解讀系列(5):<b class='flag-5'>DDS</b>-Security

    車輛動(dòng)力學(xué)模型DYNA4與CANoe集成操作演示#CANoe #車輛動(dòng)力學(xué)仿真

    模型CANoe
    北匯信息POLELINK
    發(fā)布于 :2024年06月20日 18:35:52

    時(shí)間同步對(duì)DDS實(shí)時(shí)性能的影響#DDS #TSN #時(shí)間敏感網(wǎng)絡(luò)

    網(wǎng)絡(luò)DDS
    北匯信息POLELINK
    發(fā)布于 :2024年05月30日 10:38:03

    CANoe中Logging模塊使用方法及妙招

    Logging是CANoe軟件中的數(shù)據(jù)記錄模塊,主要在臺(tái)架測(cè)試中使用,支持CAN/CANFD、LIN、FlexRay以及車載以太網(wǎng)總線的數(shù)據(jù)記錄。常用的數(shù)據(jù)記錄儀還有GL數(shù)據(jù)記錄儀,GL有自己?jiǎn)为?dú)
    的頭像 發(fā)表于 05-23 08:25 ?859次閱讀
    <b class='flag-5'>CANoe</b>中Logging模塊使用方法及妙招

    DDS重要特性之--以數(shù)據(jù)為中心#DDS

    數(shù)據(jù)中心DDS
    北匯信息POLELINK
    發(fā)布于 :2024年05月20日 18:18:28

    CANoe軟件的使用操作說(shuō)明

    本文檔是CANoe軟件的使用操作說(shuō)明,方便剛接觸CANoe的伙伴們快速上手使用這個(gè)軟件。
    的頭像 發(fā)表于 02-25 14:30 ?8920次閱讀
    <b class='flag-5'>CANoe</b>軟件的使用操作說(shuō)明

    CanoE和TC3x7應(yīng)用套件之間建立通信,如何實(shí)現(xiàn)通過(guò)串行通信從CanoE收到的數(shù)據(jù)幀?

    我想在 CanoE 和 TC3x7 應(yīng)用套件之間建立通信。 我希望開(kāi)發(fā)板打印它通過(guò)串行通信從 CanoE 收到的數(shù)據(jù)幀。 我該怎么做? 我是初學(xué)者,請(qǐng)幫忙。
    發(fā)表于 01-31 06:36

    什么是DDS?車載以太網(wǎng)—DDS篇詳解

    DDS是一系列標(biāo)準(zhǔn),它指定了分布式應(yīng)用程序可用于交換實(shí)時(shí)數(shù)據(jù)的API、協(xié)議和安全機(jī)制。
    的頭像 發(fā)表于 01-09 18:23 ?2969次閱讀
    什么是<b class='flag-5'>DDS</b>?車載以太網(wǎng)—<b class='flag-5'>DDS</b>篇詳解

    DDS常見(jiàn)問(wèn)題解答 DDS沒(méi)有輸出怎么辦?

    直接數(shù)字式頻率綜合器 DDS(Direct Digital Synthesizer),實(shí)際上是一種分頻器:通過(guò)編程頻率控制字來(lái)分頻系統(tǒng)時(shí)鐘(SYSTEM CLOCK)以產(chǎn)生所需要的頻率。DDS
    發(fā)表于 11-28 15:07 ?1次下載
    <b class='flag-5'>DDS</b>常見(jiàn)問(wèn)題解答 <b class='flag-5'>DDS</b>沒(méi)有輸出怎么辦?

    DDS在ROS2中的應(yīng)用

    DDS在ROS2中的應(yīng)用 DDS在ROS2系統(tǒng)中的位置至關(guān)重要,所有上層建設(shè)都建立在DDS之上。在這個(gè)ROS2的架構(gòu)圖中,藍(lán)色和紅色部分就是DDS。 剛才我們也提到,
    的頭像 發(fā)表于 11-24 17:54 ?761次閱讀
    <b class='flag-5'>DDS</b>在ROS2中的應(yīng)用

    Python與CANoe/CANoe4SW

    Python作為功能強(qiáng)大的編程語(yǔ)言,在智能汽車研發(fā)和測(cè)試中應(yīng)用廣泛,如數(shù)據(jù)處理、測(cè)試自動(dòng)化、測(cè)試腳本開(kāi)發(fā),甚至直接將Python應(yīng)用運(yùn)行在車輛上。CANoe產(chǎn)品體系為汽車行業(yè)XiL測(cè)試提供豐富功能
    的頭像 發(fā)表于 11-16 08:25 ?1573次閱讀
    Python與<b class='flag-5'>CANoe</b>/<b class='flag-5'>CANoe</b>4SW

    基于FPGA 程序的DDS IP配置和調(diào)試

    DDS 同 DSP(數(shù)字信號(hào)處理)一樣,是一項(xiàng)關(guān)鍵的數(shù)字化技術(shù)。DDS 是直接數(shù)字式頻率合成器(Direct Digital Synthesizer)的英文縮寫。與傳統(tǒng)的頻率合成器相比,DDS 具有
    發(fā)表于 10-31 11:14 ?583次閱讀
    基于FPGA 程序的<b class='flag-5'>DDS</b> IP配置和調(diào)試

    基于以太網(wǎng)網(wǎng)絡(luò)接口卡VN5600A的CSM數(shù)采設(shè)備與CANape、CANoe的配置方案

    客戶在實(shí)際應(yīng)用中需要使用CANoe或者CANape/vMeasure結(jié)合CSM的ECAT模塊對(duì)數(shù)據(jù)進(jìn)行采集,而且往往需要面對(duì)多路以太網(wǎng)的數(shù)據(jù)采集場(chǎng)景。針對(duì)以上特定需求,本文以VN5610A接口卡為例, 分別搭建CANoe和CANape同ECAT ADMM數(shù)采模塊的測(cè)量工程
    的頭像 發(fā)表于 10-16 10:42 ?1328次閱讀
    基于以太網(wǎng)網(wǎng)絡(luò)接口卡VN5600A的CSM數(shù)采設(shè)備與CANape、<b class='flag-5'>CANoe</b>的配置方案

    基于CANoe控制OUTMM輸出固定電壓實(shí)現(xiàn)方案

    CANoe-CANIG配置中把physvalue設(shè)置為5,那么OUTMM通道1應(yīng)該輸出5V的電壓。同樣如果設(shè)置為6,則輸出6V的電壓。
    的頭像 發(fā)表于 10-10 14:26 ?456次閱讀
    基于<b class='flag-5'>CANoe</b>控制OUTMM輸出固定電壓實(shí)現(xiàn)方案

    CANoe控制OUTMM輸出固定電壓的方法

    實(shí)際應(yīng)用中需要使用CANoe控制OUTMM輸出固定電壓,本文介紹具體實(shí)現(xiàn)的方法。
    的頭像 發(fā)表于 10-09 09:55 ?680次閱讀
    <b class='flag-5'>CANoe</b>控制OUTMM輸出固定電壓的方法