CANoe入门(四) :全真实节点阶段和真实节点和部分仿真节点共存阶段,读取和模拟数据

本文主要是介绍CANoe入门(四) :全真实节点阶段和真实节点和部分仿真节点共存阶段,读取和模拟数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 前言

前篇文章我们在CANoe全仿真阶段,模拟数据和信号。这篇文章,我们来看下全真实节点阶段和真实节点和部分仿真节点共存阶段,怎么读取数据信号,和模拟发送数据信号。

2. 全真实节点阶段

全真实节点阶段,所有的 ECU 都是真实的,也就是要去实车上。

这时CANoe 主要用于监测和分析总线通信。可以在出现问题时读取信号,进行故障诊断和排除。

2.1 新建项目

新建一个CANoe FlexRay 总线的项目,此时,使用的是Real Bus

在这里插入图片描述

同样,要导入XXXXXXX.xml这个数据库

2.2 查看接哪个接口

点击Hardware > Network Haardware > Diver,可以查看设备信息

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

我们可以看到这个CANoe设备

  • FlexRay 的通道是Channel 1,对应FRpiggyC 1082cap
  • CAN的通道是Channel 2Channel 3,对应CANpiggy 1057Gcap [Highspeed)
  • LIN的通道是Channel 4,对应LINpiggy 7269mag

我们这里要接的是FlexRay,所以接的是CH1

在这里插入图片描述
车上的FlexRay口和Canoe CH1口连接好后,就可以运行项目了

2.3 运行项目

运行项目,可以在Trace窗口中看到好多报文了
在这里插入图片描述

2.4 查找HmiXXXXXXXX信号

接着,查找HmiXXXXXXXX信号 (风量等级信号) ,可以看到目前的风量等级是9
在这里插入图片描述

2.5 添加到Graphics窗口中

HmiXXXXXXXX信号添加到Graphics窗口中,并在车机DHU上,操作空调分量,可以发现都,Graphics窗口HmiXXXXXXXX信号也随之发生改变
在这里插入图片描述

2.6 导出日志

Trace窗口中,我们可以右击,选择Export,导出日志。这会导出一个.blf格式的日志文件。

在这里插入图片描述

2.7 注意点

全仿真阶段,无法模拟修改某个信号值,因为所有ECU都是真实的,如果我们去模拟一个信号,会导致冲突。

3. 真实节点和部分仿真节点共存阶段

真实节点和部分仿真节点共存阶段,部分 ECU 是真实的,而其他 ECU 则是通过 CANoe 进行仿真。这种混合模式可以更真实地模拟实际系统的行为,同时也可以对真实 ECU 进行测试和验证。

3.1 拆除实车ECU来实现

我们可以通过拆除实车的某个ECU,然后来实现模拟该ECU的功能。

3.2 直接接入某个ECU

可以直接将某个单独的ECU接入到CANoe设备中,然后单独发信号来控制这个ECU

这涉及到CANoe IG功能,这个功能可以实现发送自定义的报文或者是数据库里的报文,到总线上来。

3.2.1 添加CAN IG模块

通过总线处右击选择 Insert CAN Interactive Generator,添加CANoe IG模块
在这里插入图片描述

3.2.2 发送自定义报文

点击Add CAN Frame : 报文的发送列表中,就出现一栏报文配置行,我们需要设置CAN报文的几个关键属性,包括报文的ID、发送通道、数据类型、DLC长度,然后运行项目后就可以点击在这里插入图片描述Send按钮了

在这里插入图片描述

4. CAPL

CAPLCANoe软件自有的一种类C的编程语言,封装有丰富的函数库,能够很好的帮助使用者实现CANoe的仿真和测试功能,CAPL脚本需要和软件中的节点关联在一起。

CANoe启动时,CAPL中的程序才能伴随工程的运行工作。

使用CANoe的仿真和测量功能时,可以在两个地方添加与CAPL脚本关联的节点。

4.1 方式1

Simulation setup窗口中的网络拓扑图内,我们可以通过右击新建一个网络节点 Insert Network Node,然后右击节点,选择配置选项。

在这里插入图片描述

在打开的节点配置选项里,我们可以配置与节点关联的CAPL文件。

在这里插入图片描述

点击File,打开选择现有的CAPL文件,或者创建一个新的CAPL文件。

4.2 方式2

我们在分析窗口的左侧,右击蓝色方块,然后选择添加一个编程节点 Insert Program Node

同样的,我们对这个编程节点做配置,右击节点,选择Configuration

在这里插入图片描述

在配置中选择或创建CAPL文件,进行关联。

4.3 编写CAPL代码

创建好CAPL节点后,接下来就是对CAPL节点的访问和编辑工作。

我们可以直接双击CAPL节点,打开CAPL文件,进行代码的编写。

4.3.1 CAPL语法
  • 类似于C语言的过程性语言,又相比于C语言较为简单,非常容易上手和熟悉
  • CAPL程序的开发和编辑工作,在CAPL Browser中进行的
    • CAPL Broser是CANoe自带的开发环境,可以从工程直接进入访问
  • 作为CANoe自带的编程语言,可以更容易地访问CANoe工程中的数据
    • 包括数据库中的报文,信号以及系统变量等等
  • 此外,CAPL还支持CANoe预定义的一些函数
  • CAPL程序的执行,是由事件控制的 (Event driven)
    • 运行过程中,CAPL程序由事件触发,从进行执行
4.3.2 CAPL的操作
  • Event : 当事件触发的时候
  • Send Message : 发送消息
  • Access Signal : 当信号改变的时候 / 当信号发送到总线时

5. CANoe入门系列

CANoe入门(一) :相关概念知识
CANoe入门(二) :CANoe环境搭建
CANoe入门(三) :CANoe全仿真阶段,模拟数据和信号
CANoe入门(四) :CANoe入门(四) : 全真实节点阶段和真实节点和部分仿真节点共存阶段,读取和模拟数据

这篇关于CANoe入门(四) :全真实节点阶段和真实节点和部分仿真节点共存阶段,读取和模拟数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121099

相关文章

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

Python实现数据清洗的18种方法

《Python实现数据清洗的18种方法》本文主要介绍了Python实现数据清洗的18种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录1. 去除字符串两边空格2. 转换数据类型3. 大小写转换4. 移除列表中的重复元素5. 快速统

Python数据处理之导入导出Excel数据方式

《Python数据处理之导入导出Excel数据方式》Python是Excel数据处理的绝佳工具,通过Pandas和Openpyxl等库可以实现数据的导入、导出和自动化处理,从基础的数据读取和清洗到复杂... 目录python导入导出Excel数据开启数据之旅:为什么Python是Excel数据处理的最佳拍档

在Pandas中进行数据重命名的方法示例

《在Pandas中进行数据重命名的方法示例》Pandas作为Python中最流行的数据处理库,提供了强大的数据操作功能,其中数据重命名是常见且基础的操作之一,本文将通过简洁明了的讲解和丰富的代码示例,... 目录一、引言二、Pandas rename方法简介三、列名重命名3.1 使用字典进行列名重命名3.编

Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南

《Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南》在日常数据处理工作中,我们经常需要将不同Excel文档中的数据整合到一个新的DataFrame中,以便进行进一步... 目录一、准备工作二、读取Excel文件三、数据叠加四、处理重复数据(可选)五、保存新DataFram

Java读取InfluxDB数据库的方法详解

《Java读取InfluxDB数据库的方法详解》本文介绍基于Java语言,读取InfluxDB数据库的方法,包括读取InfluxDB的所有数据库,以及指定数据库中的measurement、field、... 首先,创建一个Java项目,用于撰写代码。接下来,配置所需要的依赖;这里我们就选择可用于与Infl

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加