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
    +关注

    关注

    57

    文章

    2714

    浏览量

    463330
  • DDS
    DDS
    +关注

    关注

    21

    文章

    631

    浏览量

    152527
收藏 人收藏

    评论

    相关推荐

    Xilinx DDS IP核的使用和参数配置

    用RAM实现一个DDS,从原理上来说很简单,在实际使用的时候,可能没有直接使用官方提供的IP核来的方便。这个博客就记录一下,最近使用到的这个DDS IP。
    的头像 发表于 10-25 16:54 359次阅读
    Xilinx <b class='flag-5'>DDS</b> IP核的使用和参数配置

    DDS通信中间件——DCPS规范(上)

    DDS通信中间件——DCPS规范(上)本篇文章继续和大家分享一下对DDS这套规范的理解。预期本系列文章将包括以下内容陆续更新:1.DDS规范概述2.DCPS规范解读3.DDS-XTyp
    的头像 发表于 09-26 08:08 314次阅读
    <b class='flag-5'>DDS</b>通信中间件——DCPS规范(上)

    车载通信与DDS标准解读系列(5):DDS-Security

    本文将从DDS系统安全风险分析切入,对系统的实现的认证、访问控制、加密环节等安全机制做介绍。
    的头像 发表于 07-19 10:55 3872次阅读
    车载通信与<b class='flag-5'>DDS</b>标准解读系列(5):<b class='flag-5'>DDS</b>-Security

    车辆动力学模型DYNA4与CANoe集成操作演示#CANoe #车辆动力学仿真

    模型CANoe
    北汇信息POLELINK
    发布于 :2024年06月20日 18:35:52

    时间同步对DDS实时性能的影响#DDS #TSN #时间敏感网络

    网络DDS
    北汇信息POLELINK
    发布于 :2024年05月30日 10:38:03

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

    Logging是CANoe软件中的数据记录模块,主要在台架测试中使用,支持CAN/CANFD、LIN、FlexRay以及车载以太网总线的数据记录。常用的数据记录仪还有GL数据记录仪,GL有自己单独
    的头像 发表于 05-23 08:25 1092次阅读
    <b class='flag-5'>CANoe</b>中Logging模块使用方法及妙招

    DDS重要特性之--以数据为中心#DDS

    数据中心DDS
    北汇信息POLELINK
    发布于 :2024年05月20日 18:18:28

    DDS协议测试实践及问题分析

    在上一篇文章中,我们对DDS协议测试的策略、方法和工具进行了详细的介绍。本文旨在进一步探讨如何利用这些方法和工具搭建实际的测试环境,并执行测试,进而揭示可能遇到的各类问题。被测协议栈简介在本次测试中
    的头像 发表于 04-12 08:26 547次阅读
    <b class='flag-5'>DDS</b>协议测试实践及问题分析

    CANoe软件的使用操作说明

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

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

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

    什么是DDS?车载以太网—DDS篇详解

    DDS是一系列标准,它指定了分布式应用程序可用于交换实时数据的API、协议和安全机制。
    的头像 发表于 01-09 18:23 3827次阅读
    什么是<b class='flag-5'>DDS</b>?车载以太网—<b class='flag-5'>DDS</b>篇详解

    如何确定DDS输出信号频谱中的杂散源

    直接数据频率合成器(DDS)因能产生频率捷变且残留相位噪声性能卓越而著称。另外,多数用户都很清楚DDS输出频谱中存在的杂散噪声,比如相位截断杂散以及与相位-幅度转换过程相关的杂散等。此类杂散是实际
    发表于 12-15 07:38

    什么是DDS?初识CP AUTOSAR平台下的DDS规范

    数据分发服务(DDS)[1]是一个来自对象管理组(OMG)的中间件协议和API标准。它将系统的组件集成在一起,提供低延迟的数据连接,极高的可靠性,和可扩展的架构。
    的头像 发表于 12-05 18:18 3653次阅读
    什么是<b class='flag-5'>DDS</b>?初识CP AUTOSAR平台下的<b class='flag-5'>DDS</b>规范

    DDS常见问题解答 DDS没有输出怎么办?

    直接数字式频率综合器 DDS(Direct Digital Synthesizer),实际上是一种分频器:通过编程频率控制字来分频系统时钟(SYSTEM CLOCK)以产生所需要的频率。DDS
    发表于 11-28 15:07 1次下载
    <b class='flag-5'>DDS</b>常见问题解答 <b class='flag-5'>DDS</b>没有输出怎么办?

    DDS在ROS2中的应用

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