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文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/songdm_2012/article/details/131415200
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/245892

相关文章

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、

Python处理大量Excel文件的十个技巧分享

《Python处理大量Excel文件的十个技巧分享》每天被大量Excel文件折磨的你看过来!这是一份Python程序员整理的实用技巧,不说废话,直接上干货,文章通过代码示例讲解的非常详细,需要的朋友可... 目录一、批量读取多个Excel文件二、选择性读取工作表和列三、自动调整格式和样式四、智能数据清洗五、

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

SpringBoot如何对密码等敏感信息进行脱敏处理

《SpringBoot如何对密码等敏感信息进行脱敏处理》这篇文章主要为大家详细介绍了SpringBoot对密码等敏感信息进行脱敏处理的几个常用方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录​1. 配置文件敏感信息脱敏​​2. 日志脱敏​​3. API响应脱敏​​4. 其他注意事项​​总结

Python使用python-docx实现自动化处理Word文档

《Python使用python-docx实现自动化处理Word文档》这篇文章主要为大家展示了Python如何通过代码实现段落样式复制,HTML表格转Word表格以及动态生成可定制化模板的功能,感兴趣的... 目录一、引言二、核心功能模块解析1. 段落样式与图片复制2. html表格转Word表格3. 模板生

Python Pandas高效处理Excel数据完整指南

《PythonPandas高效处理Excel数据完整指南》在数据驱动的时代,Excel仍是大量企业存储核心数据的工具,Python的Pandas库凭借其向量化计算、内存优化和丰富的数据处理接口,成为... 目录一、环境搭建与数据读取1.1 基础环境配置1.2 数据高效载入技巧二、数据清洗核心战术2.1 缺失

SpringBoot项目中Redis存储Session对象序列化处理

《SpringBoot项目中Redis存储Session对象序列化处理》在SpringBoot项目中使用Redis存储Session时,对象的序列化和反序列化是关键步骤,下面我们就来讲讲如何在Spri... 目录一、为什么需要序列化处理二、Spring Boot 集成 Redis 存储 Session2.1