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

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

3天内不再提示

【CDD】诊断数据库创建速成班-课堂(一)

北汇信息POLELINK 2022-08-01 14:15 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

每一辆车都有很多功能,比如智能驾驶功能、娱乐域功能。但是无论怎么发展,我们车辆传统的诊断功能都是必须要有的,而且是十分重要的。那么什么是车辆诊断呢,简单来说就是在通过诊断服务一问一答的方式,获取车辆内部的参数信息。

车辆诊断过程:

poYBAGLmKjOAaw1DAAG0wNVGanI006.png

在我们整个汽车开发、测试、生产、售后服务过程中,都需要用到车辆诊断功能。但是这些都是由不同公司或者不同部门完成的,那么在各个阶段我们就需要统一诊断数据库,去保证整个流程中诊断需求的一致性和诊断数据的复用性。诊断数据库需要具备机器(如软件)可读的特性,从而使诊断自动化测试和诊断协议栈自动生成成为可能。诊断数据库平台还需要具备良好的交互性,便于不同格式的诊断数据库的交互和转换。

这里就给大家开一个速成班,让大家了解Vector诊断产品链CANdelaStudio工具,是如何生成诊断数据库文件,保持诊断规范的一致性。

一、 CANdelaStudio简介

1.CANdelaStudio诊断规范定义

poYBAGLmLBWAZpqbAAC-74La5vs571.png

如上图所示,就是一个典型的V-L模型,从前期开发到售后阶段,以ECU的诊断数据库(对应于ECU的诊断需求)为核心。在开发阶段根据ECU诊断数据库,进行ECU诊断协议栈的实现。测试阶段根据ECU诊断数据库,生成诊断测试规范和测试用例。生产阶段,根据ECU诊断数据库,开发、应用参数化的EOL设备。售后阶段,根据ECU诊断数据库,开发、应用参数化的诊断仪。不同阶段,使用的诊断数据库格式可能不一样,但是所有的诊断数据库都源于同一个数据源。基于机器可读的诊断数据库,实现诊断在开发、测试、生产和售后阶段的需求一致性、数据复用性和诊断设备参数化。

CANdelaStudio用于定义ECU的诊断需求,支持用户创建和编辑车辆ECU诊断需求,生成诊断数据库文件(CDD),实现我们诊断需求的一致性。

pYYBAGLmLCuAcrBNAACv6_nmHKI654.png

安装CANdelaStudio软件后,会自带CDDT模板,CDD文件是由CDDT模板文件生成,生成的CDD文件也可以导入不同软件中。比如基于AUTOSAR体系,CDD文件可以导入到达芬奇软件中,生成MICROSAR Diag部分的代码;CDD文件可以导入其他Vector软件中(CANoe、CANape、Indigo等),进行诊断的手动测试;还可以导入CANoe.DiVa软件中生成诊断自动化测试用例,最终在CANoe中导入CANoe.DiVa生成的测试用例进行自动化测试。

刚才说了CDD文件是由CDDT文件生成而来,那么它们之间到底有什么区别呢?CDDT文件就是CDD的模板文件。当CDD文件生成后,我们需要明确它是由哪个CDDT文件生成。

poYBAGLmLFSAbNI3AACR47_xf9Y923.png

CDDT文件:定义宏观-整车级通信参数类型、服务列表、结构、整车通用的会话模式、安全访问、DID等

CDD文件:定义微观-单个控制器级具体的通信参数、具体的服务参数、具体的会话模式、安全访问、DID等

2.CANdelaStudio版本介绍

CANdelaStudio View:可以查看CDD文件,不能对CDD文件进行编辑

CANdelaStudio Standard:基于CDDT编辑CDD文件,但不可以编辑CDDT文件

CANdelaStudio Pro:支持多语言版本

CANdelaStudio Admin:权限最高版本,可以编辑CDDT文件

查看软件版本:

pYYBAGLmLHWAHKV8AACvaKWj3AI119.png

3.CANdelaStudio中诊断数据和架构介绍

1)工程创建方法:

点击New选择相应的CDDT模板来编辑数据库保存为CDD文件

poYBAGLmLNKAdHOvAAEc-HbK-UI284.png

点击Open,可以打开CDDT文件,编辑保存CDDT文件;或者打开一个CDD文件进行编辑保存。

pYYBAGLmLOiAXzjKAADNQv38RZI990.png

2)CDD文件结构分析:

pYYBAGLmLPeAbWmMAACmxJWPA-I347.png

Variants:变体,CDD文件的核心内容,包含一个ECU当中的所有诊断服务数据。在这里出现了Base Variant和Variants,可以简单理解为车型分高中低配,每个配置的车型对应一个Variant。在其他Vector工具(CANoe、Diva等)中导入CDD文件时可以选择相应Variant。

每个Variant下,都需要去选择所支持的类(Supported Classes):

pYYBAGLmLQuAMcKxAADWjC9xTCM767.png

打开每个类,下面都有不同的服务,比如Sessions类,下面就包含了10会话服务。可以查看支持的子功能和服务相关参数

poYBAGLmLRyAQ0vJAACTDb9jgCQ753.png

再打开DID相关的类,可以去勾选是否支持可写

poYBAGLmLSuAfcmhAADIdezEB68061.png

3)CDD数据复用性

在CDD里面的数据内容Data Types、Variants、DTC、DID等,可以通过粘贴复制来完成数据复用,从CDD1到CDD2不用重新编辑

服务架构查看:

pYYBAGLmLUSANU7gAAD7aBQ0l_A307.png

二、编辑CDD文件工程

1.创建新工程

1)接下来,我们就来通过CDDT文件创建一个新的CDD工程:

poYBAGLmLWiAVYcOAACaX6rmzuc083.png

poYBAGLmLXiAGV0XAADx6WKrWyA096.png

2)编辑作者、变更历史:Document->Revision History:

pYYBAGLmLYaALfYuAADejTbe9hw254.png

3)ECU信息描述编辑:

pYYBAGLmLZ2APfeAAADA9VqrTow625.png

4)选择相关总线接口类型:

pYYBAGLmLa-AC7UDAACmHJI5xOo206.png

2.通信参数编辑

通信参数设置:需要设置请求ID、响应ID、时间参数、波特率等

poYBAGLmLcGALAnXAAEITmQf59g098.png

3.DID编辑

DID是两个字节的标识符,不同的DID存放的数据格式不一样,比如存放多少字节的十进制数、ASCII码类型数或者线性的数据等。那么在CANdelaStudio里面如何去编辑DID呢?

首先我们需要去创建DID,一般都是选择在Base Variant里进行创建。

步骤一:新建DID

1.选择DIDs;2.选择New DID;3.编辑ID和名称。

pYYBAGLmLe2Af0DEAADjMSv9Fjs404.png

步骤二:新建Data Type

1.选择Data Type;2.选择New;3.选择需要的数据类型;4.编辑参数。

poYBAGLmLfyADTiGAAE1EQXTgj8805.png

poYBAGLmLhOAC6-jAACir80hoD4763.png

步骤三:DID与Data Type关联

1.选择DIDs,并选择之前创建的DID;2.选择相应的Data Type。

pYYBAGLmLiiAG-GOAAEqmxywgUY618.png

为什么需要Data Type呢,因为读取或者写入的DID数据都是有数据类型的,所以需要进行关联一个Data Type进行解析。常见的Data Type有Raw Value(软硬件版本号);Text Table(枚举型);Linear(线性的)。

步骤四:Class类关联

1.选择DID相关的Class类。

poYBAGLmLlOAQJDyAAEgbpiX_fU373.png

2.如果有需要定义bit的DID,先在关联Data Type处选择New Bitfield,然后在关联Data Type。

pYYBAGLmLmCASf54AABagATr1ZI186.png

poYBAGLmLm2AMuN5AAEI0ysCsTs088.png

无效值定义:

在定义Data Type时,选择Invalid Values,去定义无效值的类型。

pYYBAGLmLoyAN54gAACupzuQHpw224.png

激活/取消激活DID:

针对我们创建的DID,可以选择进行激活或者取消激活

pYYBAGLmLp-ATawlAAFOALKWL_8079.png

4.DTC故障码编辑

在创建编辑DTC之前,我们先了解一下CDD里的DTC库:

poYBAGLmLtOATm-8AAG6I8fTorc202.png

新建DTC:

1.选择DTC数据库;2.点击新建DTC;3.DTC参数编辑。

poYBAGLmLvKAL0ZuAADmu_wfl6Q111.png

DTC故障码导入/导出:

在DTC数据库中,可以将Excle表中的DTC直接导入CANdelaStudio中,也可以将CANdelaStudio中的DTC导出成Excle表格。

poYBAGLmLwOATYavAAIzQPO8sN8115.png

将DTC库中的DTC加载到Variant中:

在Primary Fault Memory的DTC Table中,右键弹出的窗口中选择Copy & Reference from Available DTCs…,即可将DTC库中的故障码加载至Variant中。

pYYBAGLmLxmALDY_AAEYDZFzkqs657.png

虽然选择Copy和Reference都可以加载DTC,但是如果我们在DTC库中有修改DTC,通过Copy的方式加载的DTC在DTC Table中不会跟着DTC库的修改而自动更新。通过Reference的方式加载的DTC可以自动更新。

0x19服务设置:

设置需要应用的0x19服务

poYBAGLmLzSAFW63AAFSnz8o4x0139.png

状态掩码设置:

1.根据需求进行Status mask设置;2.设置请求的默认值

pYYBAGLmL06Ae1Q1AADIw1baGNs266.png

DTC码总览:

在此处所有的DTC会显示出来,可以查看DTC码是否被应用。

poYBAGLmL16ANmKsAAI3TlOUOGw752.png

5.快照数据编辑

步骤一:1.定义所有DTC记录的快照数据个数;2.针对所有DTC,设置快照数据读取的DID内容。

poYBAGLmL3GAdePxAAE4JQ_FepA730.png

步骤二:1.显示所有的DTC,可以单独选择进行编辑;2.可以针对单个DTC选择需要记录快照的DID。

pYYBAGLmL32AXMrNAAD_W9RqGcA088.png

步骤三:显示快照数据的个数,可设置是否支持快照数据。

poYBAGLmL4yAKgdLAADQYQRtcZA307.png

6.扩展快照数据编辑

步骤一:1.定义扩展快照数据个数;2.设置扩展快照数据内容。

pYYBAGLmL5uAfQ0gAADmI5LEc_M167.png

步骤二:1.显示所有的DTC,可以单独选择进行编辑;2.设置是否支持扩展数据。

poYBAGLmL6mASQTLAAD0wPFAhGs122.png

本堂课关于CANdelaStudio之CDD文件速成的分享就到这里,请继续关注我们下堂课的分享。

Vector Informatik公司是全球领先的分布式系统设计开发工具、网络节点测试验证工具和嵌入式软件组件提供商,为汽车总线网络的设计、建模、仿真、分析、测试以及ECU的开发、测试、标定和诊断等过程提供一系列强有力的软硬件工具和组件,支持CAN、LIN、MOST、FlexRay、以太网、SAE J1939、OSEK和AUTOSAR等多种总线系统、协议和标准。在全球范围内,来自汽车、商用车、工程机械控制工程领域的客户都在应用Vector提供的解决方案和产品。

北汇信息作为Vector中国的合作伙伴,不仅提供相应的工具和技术支持服务及培训,还针对不同的应用提供相应的解决方案,助力中国客户的研发效率提升。欢迎联系北汇信息,为您答疑解惑!

注:图中部分图片来源于Vector

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    CANdelaStudio 25的AI Feature功能助力CDD文件创建

    了解CANdelaStudio,也读不懂CDD文件,那它在工程现场的价值就会非常有限。CANdelaStudio 25的AI Feature,意义就在这里。 如下图所示,它不是简单地在工具里加个聊天框
    的头像 发表于 06-04 13:51 30次阅读
    CANdelaStudio 25的AI Feature功能助力<b class='flag-5'>CDD</b>文件<b class='flag-5'>创建</b>

    【米尔RZ/T2H开发板试用,驱控体芯】+数据库操作及功能测试

    米尔RZ/T2H开发板提供了数据库服务,其选取版本是SQLite3,它是款轻型的数据库,所遵守的是关系型数据库管理系统,具有占用资源少的特点,所移植的版本为3.31.1。 (1)启用
    发表于 05-30 19:36

    【米尔TI AM62L开发板试用】+数据库操作及功能测试

    的是,这个轻量级的数据库竟然支持中文信息处理。 图2 创建数据库 (3)删除记录 删除记录的操作如图3所示,在完成记录删除后,可见到只有条记录存在。 图3 完成删除 (4)增加记录
    发表于 05-11 11:31

    生产环境数据库连接池耗尽的全流程排查与性能优化实战

    数据库连接池是应用程序与数据库之间的缓存连接组件。连接池在应用程序启动时创建数据库连接,应用程序从连接池获取连接,使用完毕后归还连接池而
    的头像 发表于 03-27 15:58 511次阅读

    Oracle数据库ASM实例无法挂载的数据恢复案例

    个Oracle数据库故障表现为ASM磁盘组掉线,ASM实例无法挂载(mount)。数据库管理员自行进行简单修复,未能成功,随后联系北亚数据恢复中心恢复
    的头像 发表于 02-24 15:19 304次阅读
    Oracle<b class='flag-5'>数据库</b>ASM实例无法挂载的<b class='flag-5'>数据</b>恢复案例

    恒讯科技解析:如何安装MySQL并创建数据库

    安装和管理MySQL不必复杂。只需几分钟,你就能在Linux服务器上搭建MySQL,创建一个数据库,甚至自动化备份——同时确保数据安全有序。 什么是 MySQL  MySQL 是
    的头像 发表于 01-14 14:25 512次阅读

    ODX诊断数据的质量基石ODX Checker Rules详解

    在汽车诊断数据标准化的今天,诊断数据库在车辆生命周期的不同阶段扮演着重要的角色。例如:在代码开发阶段,会用到符合AUTOSAR标准的ARXML文件; 在控制器
    的头像 发表于 01-08 11:28 757次阅读

    国产数据库的AI战事

    国产数据库硝烟再起,Vastbase V100构筑企业智能基座
    的头像 发表于 10-24 20:45 4591次阅读
    国产<b class='flag-5'>数据库</b>的AI战事

    数据库性能优化指南

    作为名在大厂摸爬滚打多年的运维老兵,我见过太多因为数据库性能问题导致的生产事故。今天分享套完整的数据库优化方法论,从SQL层面到硬件配置,帮你彻底解决性能瓶颈!
    的头像 发表于 08-18 11:21 996次阅读

    数据库数据恢复—服务器异常断电导致Oracle数据库故障的数据恢复案例

    Oracle数据库故障: 某公司台服务器上部署Oracle数据库。服务器意外断电导致数据库报错,报错内容为“system01.dbf需要更多的恢复来保持
    的头像 发表于 07-24 11:12 967次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—服务器异常断电导致Oracle<b class='flag-5'>数据库</b>故障的<b class='flag-5'>数据</b>恢复案例

    三款主流国产数据库的技术特点

    随着数字经济的快速发展和数据安全要求的提升,国产数据库正迎来前所未有的发展机遇。在信创浪潮推动下,达梦数据库、TiDB、华为高斯数据库等国产数据库
    的头像 发表于 07-14 11:08 1449次阅读

    数据库数据恢复—MongoDB数据库文件丢失的数据恢复案例

    MongoDB数据库数据恢复环境: 台操作系统为Windows Server的虚拟机上部署MongoDB数据库。 MongoDB数据库
    的头像 发表于 07-01 11:13 905次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—MongoDB<b class='flag-5'>数据库</b>文件丢失的<b class='flag-5'>数据</b>恢复案例

    数据库数据恢复—SQL Server数据库被加密如何恢复数据

    SQL Server数据库故障: SQL Server数据库被加密,无法使用。 数据库MDF、LDF、log日志文件名字被篡改。
    的头像 发表于 06-25 13:54 950次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—SQL Server<b class='flag-5'>数据库</b>被加密如何恢复<b class='flag-5'>数据</b>?

    达梦数据库常用管理SQL命令详解

    达梦数据库常用管理SQL命令详解
    的头像 发表于 06-17 15:12 7910次阅读
    达梦<b class='flag-5'>数据库</b>常用管理SQL命令详解

    oracle数据恢复—oracle数据库误执行错误truncate命令如何恢复数据

    oracle数据库误执行truncate命令导致数据丢失是种常见情况。通常情况下,oracle数据库误操作删除数据只需要通过备份恢复
    的头像 发表于 06-05 16:01 2062次阅读
    oracle<b class='flag-5'>数据</b>恢复—oracle<b class='flag-5'>数据库</b>误执行错误truncate命令如何恢复<b class='flag-5'>数据</b>?