0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【文章转载】CANoe与DDS

北汇信息POLELINK 2023-01-13 09:47 次阅读

DDS(Data Distribution Service)是OMG组织(Object Management Group)最早在2004年发布的分布式实时通信中间件标准,旨在使用发布-订阅模式实现可靠、高性能、互操作、实时、可扩展的数据交换。

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

图1:DDS软件示例架构图

在汽车领域,Adaptive AUTOSAR于2018年引用DDS作为可选择的通信方式之一。DDS的实时性恰好适合于自动驾驶系统。因为在这类系统中,通常会存在感知、预测、决策和定位等模块,这些模块都需要非常频繁地高速交换数据。借助DDS,可以很好地满足这类系统的通信需求。凭借以数据为中心及丰富的QoS机制,DDS在汽车行业中逐渐受到青睐,汽车制造商及供应商将DDS作为系统中可选的通讯中间件之一,从而增强其产品的功能特性及可靠性。

DDS具有以数据为中心、即插即用、丰富的QoS等特性,这意味着DDS在网络传输中对各层级数据需要提供丰富且冗长的Header信息,方便通讯双方识别所需内容,因此对硬件及网络中的传输和数据处理性能提出了较高要求。因此在未来,DDS、SOME/IP等SOA通信中间件与车载总线类似,在车内将会是多种中间件长期共存的状态。

DDS有诸多协议规范,其中最核心的2个规范是:DDS规范和DDSI-RTPS规范。DDS规范描述了分布式应用通信和以数据为中心的发布-订阅模型,定义了应用接口(API)和通信语义,从而实现“在正确的时间向正确的地点有效可靠地传递正确的信息”。DDS规范提供了DDS核心概念在与平台无关模型(PIM)中的抽象定义,以及相对于平台专用模型(PSM)中的映射,从应用开发者视角诠释了DDS的核心定义。但是,单纯依靠DDS规范使得各DDS中间件供应商对于具体通信传输介质、行为和数据包结构有着自己的理解,若通信系统中各设备来自不同的DDS中间件供应商,其互操作性可能会存在问题。

为解决这一问题,OMG随后发布了DDSI-RTPS规范,对通信结构、数据消息结构、收发行为、服务发现进行了定义,从而保证来自不同厂商的DDS中间件的互操作性。目前纳入DDSI-RTPS规范中的底层通讯协议为UDP/IP。OMG组织目前暂未对DDS的测试规范进行定义。

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

图2:DDS数据交互简化拓扑图

DDS中重要概念:

>

Domain

连接所有能够互相通信的应用程序的分布式概念,只有在同一个Domain下的Publisher和Subscriber能够互相通信,不同Domain的应用程序不知道彼此的存在,Domain通过DomainID进行区分。Domain中包含了DomainParticipant,后者代表了同一个Domain下参与通讯的应用程序,同时也是Publisher、Subscriber、Topic的工厂。

>

Topic

Publisher和Subscriber互相通讯的数据本身,其名称(Topic Name)在一个Domain中是唯一的。

>

DataWriter

基于绑定的Topic,由应用程序发送数据的实体。1个DataWriter隶属于1个Publisher,同时1个DataWriter对应于1个Topic。

>

DataReader

可使应用程序声明期望的Topic数据,以及访问Subscriber收到的数据。1个DataReader隶属于1个Subscriber,1个DataReader对应1个Topic。

>

Publisher

负责发布实际Topic数据的实体,可以创建及配置多个DataWriter并绑定相应若干Topic。

>

Subscriber

负责接收订阅Topic数据的实体,可以创建及配置多个DataReader并绑定相应若干Topic。

>

QoS

服务质量(Quality of Service)是控制DDS服务的一系列特性。Topic、DataWriter、DataReader、Publisher、Subscriber以及DomainParticipant各实体均可配置其各自的QoS规则,这些QoS互相存在兼容性检查。若通信双方QoS不兼容,则无法建立通信。目前DDS v1.4版本规范定义了Durability、LiveLiness、Reliability、LifeSpan、History等QoS机制。

CANoe中开始支持DDS

随着DDS开始在汽车电子领域的应用,Vector应客户需求在CANoe 16 SP3版本中开始支持DDS的仿真、分析与测试。DDS的通讯模型基于CANoe中的Communication Concept(ComCo)实现。

基于CANoe建立DDS的仿真和解析工程环境,可以充分利用CANoe及其测试工具链现有的优势特性:

>

CANoe是汽车电子、IoT、航空航天等多领域仿真及测试的一站式整合平台,支持CAN、CAN FD、CAN XL、LIN、FlexRay、SOME/IP、AUTOSAR PDU(CP/AP)、DoIP、CCP/XCP、NM网络管理、UDS、Cyber Security(SecOC、TLS/DTLS、IPsec、MACsec等)、E2E、全球充电协议、MQTT、HTTP、WLAN、BLE等多种总线和协议;

>

采用用户熟悉的CAPL、C#Python语言实现;

>

支持SIL/HIL、通信路由、网络仿真、数据分析/记录、诊断/刷写、电源管理、I/O控制等多种场景;

>

极具性价比的测试设计及测试脚本开发环境——vTESTstudio;

>

无缝耦合整车动力学模型及ADAS场景仿真模型工具DYNA4,或基于FMI/FMU、FDX、XIL API、COM、SIL KIT整合第三方测试工具链;

>

匹配汽车电子敏捷开发流程的CI/CT工具链体系。

如何在CANoe中创建DDS仿真及解析工程?通过下图新建Distributed Objects工程:

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

图3:新建CANoe DO工程

而后可在主界面中看到Communication Setup界面,该界面也可通过CANoe上方标签Simulation下打开。随后依据下图指引新建DDS通信接口描述文件vCDL:

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

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

在选择vCDL文件保存路径及文件名后(注意路径及文件名不能包含中文及特殊字符),依据下图指引打开编辑:

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

图5:编辑DDS通信接口描述文件

vCDL语言(Vector Communication Description Language)作为在CANoe Communication Concept中用于描述通信对象的语言,通过Distributed Objects(DO)对DDS的数据对象进行定义。DO的consumed value对应DDS DataReader;provided value对应DDS DataWriter。

以下图示例说明:

定义结构体作为Topic Type(即HealthData);

在interface(即IMonitor)中将该结构体作为consumed value(也可作为provided value)并进行实例化(即healthData),从而隐式声明DDS DataReader,另显式声明名为“/Monitor/healthData”的Topic;

最终对该interface(即IMonitor)分别实例化为Monitor和Sensor,作为Subscriber和Publisher;

其中Sensor的类型为reverse,代表依据IMonitor中的consumed value(即healthData)反向作为provided value。

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

图6:vCDL中对DDS的通信接口定义示例

vCDL DDS的结构体中可以包含如下数据类型:uint或int(8、16、32、64bit),Bool,Double,Float,String,Struct,Array,List,Bytes等,并在逐渐完善中。CANoe Help文档中提供了DDS IDL数据类型与vCDL数据类型的详细对应关系。

当前版本的vCDL中,可对consumed value(DDS DataReader)和provided value(DDS DataWriter)进行QoS规则设置,包括:Reliability、History、Durability、Lifespan、Liveliness,更多的QoS规则会在CANoe后续版本中完善。

其他对于DDS Binding时的属性配置可参考详情:CANoe 16 SP3 Help文档中的“Distributed Objects (DOs) for Data Distribution Service (DDS)”页面专题

当完成DDS的通信接口描述文件创建后,CANoe会自动生成若干观测事件及数据对象,包括DataWriter和DataReader的匹配/不匹配事件信息、服务发现信息、数据Sample信息、Built-in Topic信息等,以DO体现。

用户可在“.. \Sample Configurations 16.3.110\Connectivity\DDS\DDSBasic”中了解DDS Demo示例工程。该工程运行后,在Trace窗口可查看详细的DDS仿真和解析数据内容。

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

图7:CANoe中DDS工程运行状态

由于DDS协议簇范围广,存在较多用户自定义实现,除去当前针对ECU仿真及测试需要的DDS功能支持外,也满足ROS2集成的功能。更多DDS功能将在后续CANoe版本中完善。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • CAN
    CAN
    +关注

    关注

    56

    文章

    2467

    浏览量

    459239
  • DDS
    DDS
    +关注

    关注

    21

    文章

    614

    浏览量

    151731
收藏 人收藏

    评论

    相关推荐

    CANoe软件的使用操作说明

    本文档是CANoe软件的使用操作说明,方便刚接触CANoe的伙伴们快速上手使用这个软件。
    的头像 发表于 02-25 14:30 1157次阅读
    <b class='flag-5'>CANoe</b>软件的使用操作说明

    CanoE和TC3x7应用套件之间建立通信,如何实现通过串行通信从CanoE收到的数据帧?

    我想在 CanoE 和 TC3x7 应用套件之间建立通信。 我希望开发板打印它通过串行通信从 CanoE 收到的数据帧。 我该怎么做? 我是初学者,请帮忙。
    发表于 01-31 06:36

    DDS在ROS2中的应用

    DDS在ROS2中的应用 DDS在ROS2系统中的位置至关重要,所有上层建设都建立在DDS之上。在这个ROS2的架构图中,蓝色和红色部分就是DDS。 刚才我们也提到,
    的头像 发表于 11-24 17:54 424次阅读
    <b class='flag-5'>DDS</b>在ROS2中的应用

    Python与CANoe/CANoe4SW

    Python作为功能强大的编程语言,在智能汽车研发和测试中应用广泛,如数据处理、测试自动化、测试脚本开发,甚至直接将Python应用运行在车辆上。CANoe产品体系为汽车行业XiL测试提供丰富功能
    的头像 发表于 11-16 08:25 674次阅读
    Python与<b class='flag-5'>CANoe</b>/<b class='flag-5'>CANoe</b>4SW

    基于CANoe控制OUTMM输出固定电压实现方案

    CANoe-CANIG配置中把physvalue设置为5,那么OUTMM通道1应该输出5V的电压。同样如果设置为6,则输出6V的电压。
    的头像 发表于 10-10 14:26 242次阅读
    基于<b class='flag-5'>CANoe</b>控制OUTMM输出固定电压实现方案

    CANoe控制OUTMM输出固定电压的方法

    实际应用中需要使用CANoe控制OUTMM输出固定电压,本文介绍具体实现的方法。
    的头像 发表于 10-09 09:55 420次阅读
    <b class='flag-5'>CANoe</b>控制OUTMM输出固定电压的方法

    CANoe中常用的同步方式,软件同步+硬件同步#CANoe

    软件CANoe
    北汇信息POLELINK
    发布于 :2023年08月23日 15:54:30

    CANOE工具使用教程

    CANOE可谓是常用的总线测试工具之一,不管是总线开发工程师还是测试工程师,甚至是驻场工程师,都对它很熟悉。 天正好闲来有空,趁此机会,来分享一波CANOE的基本使用操作。其整体的框图如下所示,详细
    的头像 发表于 07-18 10:33 2346次阅读
    <b class='flag-5'>CANOE</b>工具使用教程

    CANoe的扩展服务有哪些

    CANoe是一款广泛应用于车辆开发、仿真、测试和分析方面的专业工具,支持需求分析、系统实现、测试验证的整个过程。在测试领域,CANoe更是因其众多独特的特点和优势被大家广泛应用。 硬件对接 扩展服务
    的头像 发表于 07-13 16:20 317次阅读

    DDS与PLL的区别解析

    频率的产生有两种方法:DDS和PLL,但是为什么射频工程师一般用PLL多,很少用DDS呢?
    的头像 发表于 06-28 09:38 2041次阅读
    <b class='flag-5'>DDS</b>与PLL的区别解析

    CANoe有哪些扩展服务

    CANoe是一款广泛应用于车辆开发、仿真、测试和分析方面的专业工具,支持需求分析、系统实现、测试验证的整个过程。在测试领域,CANoe更是因其众多独特的特点和优势被大家广泛应用。
    的头像 发表于 06-19 16:22 341次阅读
    <b class='flag-5'>CANoe</b>有哪些扩展服务

    CANOE入门使用教程【一】新建工程

    CANoe是德国Vetor公司推出的一款用于总线开发的设备,全称为CAN open environment。
    的头像 发表于 05-30 14:08 8986次阅读
    <b class='flag-5'>CANOE</b>入门使用教程【一】新建工程

    DDS协议测试解决方案之中间件的作用#DDS

    DDS
    北汇信息POLELINK
    发布于 :2023年05月12日 13:05:42

    会充电的CANoe - 欧标充电控制器EVCC HIL测试系统

    作者|西红柿鸡蛋面小编|吃不饱CANoe是进行网络和ECU开发、测试和分析的专业工具,支持从需求分析到系统实现的整个系统开发过程。从CANoe12.0开始,CANoe新增了充电功能
    的头像 发表于 05-12 10:22 1178次阅读
    会充电的<b class='flag-5'>CANoe</b> - 欧标充电控制器EVCC HIL测试系统

    DDS协议测试解决方案之--什么是中间件?#中间件

    DDS
    北汇信息POLELINK
    发布于 :2023年05月06日 08:29:22