Matlab处理CANape/INCA汽车测试软件记录的mdf或dat格式log文件

2023-10-20 08:20

本文主要是介绍Matlab处理CANape/INCA汽车测试软件记录的mdf或dat格式log文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

做汽车软件标定测试的小伙伴都知道,常用的测试log格式有.dat\.mdf\.blf\.asc\.csv等,一般写试验报告或者PPT时,需要对数据进行稍复杂的统计分析处理,CANoe一般通过CAPL编程方式实现,MDA也有编辑简单公式的给功能,但借助matlab强大的计算功能,可以发挥的空间比较大,创作性高,同时可以结合simulink进行模型仿真。本文介绍通过M脚本的方式导入log到matlab工作空间,进行编辑公式、简单计算、绘制曲线等。

1、打开log文件

m=mdf('油耗测试55KW2000rpm01.dat'); %把.dat文件放到当前matlab工作路径下,mdf函数返回文件对象,对象属性如下图所示:

2、获取通道组信息

ChannelGroup=m.ChannelGroup(7) %获取通道信息,其中数字代表第几个group;用CANape打开dat文件可以看到相关的信息,需要知道要处理的信号在哪个group,本文的数据处在cnannel gruop 7中;

3、获取通道信号名称

ChannelName=m.ChannelNames{7} %获取7通道中信号名称;就是我们熟悉的信号。

4、获取log中关注的数据

SignalTimetable=read(m, 7, m.ChannelNames{7});  %获取通道7中所有timatable数据;此数据就是用CANape或者MDA数据分析软件打开看到的数据,其中第一列是采样时间,其余是对应的变量;

5、获取采样时间序列

t=SignalTimetable.Time; %把timetable数据转化成了非timetable格式的数据矩阵,如果不转化成矩阵不方便进行矩阵运算;

6、获取log中电流信号数据

CANRx_CurrentISG=SignalTimetable.CANRx_CurrentISG_XCP_1; %同上,处理其它信号

7、获取log中电压信号数据

CANRx_VoltageISG=SignalTimetable.CANRx_VoltageISG_XCP_1;%同上,处理其它信号

8、根据需求处理数据

Power=CANRx_CurrentISG.*CANRx_VoltageISG/1000; %对数据进行运算处理,根据需要可以编制复杂函数,此处用简单的乘除法说明;

9、组建新的timetable数据

newdata=timetable(t,CANRx_VoltageISG,CANRx_CurrentISG,Power); %组建新的timetable数据;

10、绘制曲线图以及调整图格式

s=stackedplot(newdata);%作图,堆叠图stackedplot函数,在堆叠图中绘制表或时间表的变量。该函数在垂直层叠的单独 y 轴中绘制变量。这些变量共享一个公共 x 轴。
如果 tbl 是表,则该函数绘制变量对行号的图。
如果 tbl 是时间表,则该函数绘制变量对行时间的图。

比figure函数作图有优势;例如光标数据点可以实时显示数据点,不同的数据可以分开绘制曲线,调整曲线格式、坐标轴等非常方便,绘制的曲线如下:

以下给出调整图片属性的部分方法

% s.LineProperties(3).LineWidth = 1;%修改线宽
% s.LineProperties(2).LineStyle = 'none';%线形设置成无
% s.LineProperties(2).Marker = 's';%数据点标定为方框
s.LineProperties(3).Color='r';%线的颜色设置为红色
% vars = {{'CANRx_VoltageISG','Power'},'CANRx_CurrentISG'};%共Y轴的设置方法
% stackedplot(newdata,vars);%画共Y轴的图


本博文参考matlab help文档。

这篇关于Matlab处理CANape/INCA汽车测试软件记录的mdf或dat格式log文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

Mysql常见的SQL语句格式及实用技巧

《Mysql常见的SQL语句格式及实用技巧》本文系统梳理MySQL常见SQL语句格式,涵盖数据库与表的创建、删除、修改、查询操作,以及记录增删改查和多表关联等高级查询,同时提供索引优化、事务处理、临时... 目录一、常用语法汇总二、示例1.数据库操作2.表操作3.记录操作 4.高级查询三、实用技巧一、常用语

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序