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

相关文章

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

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

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

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

Python视频处理库VidGear使用小结

《Python视频处理库VidGear使用小结》VidGear是一个高性能的Python视频处理库,本文主要介绍了Python视频处理库VidGear使用小结,文中通过示例代码介绍的非常详细,对大家的... 目录一、VidGear的安装二、VidGear的主要功能三、VidGear的使用示例四、VidGea

Python结合requests和Cheerio处理网页内容的操作步骤

《Python结合requests和Cheerio处理网页内容的操作步骤》Python因其简洁明了的语法和强大的库支持,成为了编写爬虫程序的首选语言之一,requests库是Python中用于发送HT... 目录一、前言二、环境搭建三、requests库的基本使用四、Cheerio库的基本使用五、结合req