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

    文章

    2756

    瀏覽量

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

    關(guān)注

    21

    文章

    634

    瀏覽量

    152690
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    DDS通信中間件——DCPS規(guī)范(下)

    DDS通信中間件——DCPS規(guī)范(下)本期還是DCPS規(guī)范,填上期沒(méi)有聊完的QoS的坑。本系列文章將包括以下內(nèi)容陸續(xù)更新:1.DDS規(guī)范概述2.DCPS規(guī)范解讀3.DDS-XTypes與IDL解讀
    的頭像 發(fā)表于 11-27 11:47 ?248次閱讀
    <b class='flag-5'>DDS</b>通信中間件——DCPS規(guī)范(下)

    Xilinx DDS IP核的使用和參數(shù)配置

    用RAM實(shí)現(xiàn)一個(gè)DDS,從原理上來(lái)說(shuō)很簡(jiǎn)單,在實(shí)際使用的時(shí)候,可能沒(méi)有直接使用官方提供的IP核來(lái)的方便。這個(gè)博客就記錄一下,最近使用到的這個(gè)DDS IP。
    的頭像 發(fā)表于 10-25 16:54 ?989次閱讀
    Xilinx <b class='flag-5'>DDS</b> IP核的使用和參數(shù)配置

    dds數(shù)字頻率是怎么合成的 DDS數(shù)字頻率信號(hào)發(fā)生器的設(shè)計(jì)

    DDS(Direct Digital Synthesizer,直接數(shù)字頻率合成器)是一種廣泛應(yīng)用于現(xiàn)代電子系統(tǒng)的頻率合成技術(shù),它通過(guò)數(shù)字方式直接產(chǎn)生各種頻率的信號(hào),具有高精度、高分辨率和快速頻率轉(zhuǎn)換
    的頭像 發(fā)表于 10-06 15:33 ?568次閱讀

    dds輸出頻率與時(shí)鐘的關(guān)系

    DDS(Direct Digital Synthesizer,直接數(shù)字頻率合成器)技術(shù)是一種頻率合成方法,其輸出頻率與時(shí)鐘之間存在密切的關(guān)系。 一、DDS基本原理 DDS技術(shù)通過(guò)編程頻率控制字來(lái)分頻
    的頭像 發(fā)表于 10-06 15:27 ?795次閱讀
    <b class='flag-5'>dds</b>輸出頻率與時(shí)鐘的關(guān)系

    DDS通信中間件——DCPS規(guī)范(上)

    DDS通信中間件——DCPS規(guī)范(上)本篇文章繼續(xù)和大家分享一下對(duì)DDS這套規(guī)范的理解。預(yù)期本系列文章將包括以下內(nèi)容陸續(xù)更新:1.DDS規(guī)范概述2.DCPS規(guī)范解讀3.DDS-XTyp
    的頭像 發(fā)表于 09-26 08:08 ?554次閱讀
    <b class='flag-5'>DDS</b>通信中間件——DCPS規(guī)范(上)

    車載通信與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 ?3974次閱讀
    車載通信與<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 ?1218次閱讀
    <b class='flag-5'>CANoe</b>中Logging模塊使用方法及妙招

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

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

    CANoe新版本18正式發(fā)布

    新版本持續(xù)為電動(dòng)智能軟件開(kāi)發(fā)測(cè)試帶來(lái)系列化的新功能,新版本CANoe產(chǎn)品體系包括具有GUI交互的桌面版本、可部署在服務(wù)器后云端的服務(wù)器版本、HIL臺(tái)架專業(yè)版本:強(qiáng)化ADAS目標(biāo)可視化分析與測(cè)試、新增
    的頭像 發(fā)表于 05-09 08:25 ?3690次閱讀
    <b class='flag-5'>CANoe</b>新版本18正式發(fā)布

    DDS協(xié)議測(cè)試實(shí)踐及問(wèn)題分析

    在上一篇文章中,我們對(duì)DDS協(xié)議測(cè)試的策略、方法和工具進(jìn)行了詳細(xì)的介紹。本文旨在進(jìn)一步探討如何利用這些方法和工具搭建實(shí)際的測(cè)試環(huán)境,并執(zhí)行測(cè)試,進(jìn)而揭示可能遇到的各類問(wèn)題。被測(cè)協(xié)議棧簡(jiǎn)介在本次測(cè)試中
    的頭像 發(fā)表于 04-12 08:26 ?595次閱讀
    <b class='flag-5'>DDS</b>協(xié)議測(cè)試實(shí)踐及問(wèn)題分析

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

    本文檔是CANoe軟件的使用操作說(shuō)明,方便剛接觸CANoe的伙伴們快速上手使用這個(gè)軟件。
    的頭像 發(fā)表于 02-25 14:30 ?1.2w次閱讀
    <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 ?4226次閱讀
    什么是<b class='flag-5'>DDS</b>?車載以太網(wǎng)—<b class='flag-5'>DDS</b>篇詳解