python调用simulink_使用Python从dbc文件中提取simulink建模数据定义

使用dbc文件建模完成CAN通讯是一种比较高效的开发模式,不过在建模的过程中dbc文件中描述的数据需要自己去定义。使用文本编辑工具打开dbc文件可以看到,实际上dbc文件是一个可以进行语义解析的文本。这样,通过脚本语言便可以轻松的实现simulink建模所需要的数据定义。

以下面的dbc文件为例,简单做一下尝试。首先定义dbc文件中定义两个消息帧,以及消息帧相关的部分变量。出于示例的简单,只定义了8位和16位的数据。具体的dbc文件文本如下:

VERSION

""

NS_ :

NS_DESC_

CM_

BA_DEF_

BA_

VAL_

CAT_DEF_

CAT_

FILTER

BA_DEF_DEF_

EV_DATA_

ENVVAR_DATA_

SGTYPE_

SGTYPE_VAL_

BA_DEF_SGTYPE_

BA_SGTYPE_

SIG_TYPE_REF_

VAL_TABLE_

SIG_GROUP_

SIG_VALTYPE_

SIGTYPE_VALTYPE_

BO_TX_BU_

BA_DEF_REL_

BA_REL_

BA_DEF_DEF_REL_

BU_SG_REL_

BU_EV_REL_

BU_BO_REL_

SG_MUL_VAL_

BS_:

BU_:

BO_ 2147486754 Message2: 8 Vector__XXX

BO_ 2147486753 Message1: 8 Vector__XXX

SG_ message_var3_16bit : 55|16@0+ (1,0) [0|0]

"" Vector__XXX

SG_ message_var2_16bit : 39|16@0+ (1,0) [0|0]

"" Vector__XXX

SG_ message_var2_8bit : 31|8@0+ (1,0) [0|0]

"" Vector__XXX

SG_ message_var1_16bit : 15|16@0+ (1,0) [0|0]

"" Vector__XXX

SG_ test_flag : 7|8@0+ (1,0) [0|0]

"" Vector__XXX

BA_DEF_ SG_

"SigType" ENUM

"Default","Range","RangeSigned","ASCII","Discrete","Control","ReferencePGN","DTC","StringDelimiter","StringLength","StringLengthControl";

BA_DEF_ SG_

"GenSigEVName" STRING

;

BA_DEF_ SG_

"GenSigILSupport"

ENUM

"No","Yes";

BA_DEF_ SG_

"GenSigSendType"

ENUM

"Cyclic","OnWrite","OnWriteWithRepetition","OnChange","OnChangeWithRepetition","IfActive","IfActiveWithRepetition","NoSigSendType";

BA_DEF_ BO_

"GenMsgFastOnStart" INT 0

100000;

BA_DEF_ SG_

"GenSigInactiveValue" INT 0

0;

BA_DEF_ BO_

"GenMsgCycleTimeFast" INT 0

3600000;

BA_DEF_ BO_

"GenMsgNrOfRepetition" INT 0

1000000;

BA_DEF_ SG_

"GenSigStartValue" INT 0

10000;

BA_DEF_ BO_

"GenMsgDelayTime" INT 0

1000;

BA_DEF_ BO_

"GenMsgILSupport"

ENUM

"No","Yes";

BA_DEF_ BO_

"GenMsgStartDelayTime" INT 0

100000;

BA_DEF_ BU_

"NodeLayerModules" STRING

;

BA_DEF_ BU_

"ECU" STRING ;

BA_DEF_ BU_

"NmJ1939SystemInstance" INT 0

15;

BA_DEF_ BU_

"NmJ1939System" INT 0

127;

BA_DEF_ BU_

"NmJ1939ManufacturerCode" INT 0

2047;

BA_DEF_ BU_

"NmJ1939IndustryGroup" INT 0

7;

BA_DEF_ BU_

"NmJ1939IdentityNumber" INT 0

2097151;

BA_DEF_ BU_

"NmJ1939FunctionInstance" INT 0

7;

BA_DEF_ BU_

"NmJ1939Function" INT 0

255;

BA_DEF_ BU_

"NmJ1939ECUInstance" INT 0

3;

BA_DEF_ BU_

"NmJ1939AAC" INT 0 1;

BA_DEF_ BU_

"NmStationAddress" INT 0

255;

BA_DEF_ BO_

"GenMsgSendType"

ENUM

"cyclic","NotUsed","IfActive","NotUsed","NotUsed","NotUsed","NotUsed","NotUsed","noMsgSendType";

BA_DEF_ BO_

"GenMsgRequestable" INT 0

1;

BA_DEF_ BO_

"GenMsgCycleTime" INT 0

3600000;

BA_DEF_ SG_

"SPN" INT 0 524287;

BA_DEF_

"DBName" STRING ;

BA_DEF_

"BusType" STRING ;

BA_DEF_

"ProtocolType" STRING

;

BA_DEF_ BO_

"VFrameFormat"

ENUM

"StandardCAN","ExtendedCAN","reserved","J1939PG";

BA_DEF_DEF_

"SigType"

"Default";

BA_DEF_DEF_

"GenSigEVName"

"Env@Nodename_@Signame";

BA_DEF_DEF_

"GenSigILSupport"

"Yes";

BA_DEF_DEF_

"GenSigSendType"

"NoSigSendType";

BA_DEF_DEF_

"GenMsgFastOnStart" 0;

BA_DEF_DEF_

"GenSigInactiveValue"

0;

BA_DEF_DEF_

"GenMsgCycleTimeFast"

0;

BA_DEF_DEF_

"GenMsgNrOfRepetition"

0;

BA_DEF_DEF_

"GenSigStartValue" 0;

BA_DEF_DEF_

"GenMsgDelayTime" 0;

BA_DEF_DEF_

"GenMsgILSupport"

"Yes";

BA_DEF_DEF_

"GenMsgStartDelayTime"

0;

BA_DEF_DEF_

"NodeLayerModules"

"";

BA_DEF_DEF_

"ECU"

"";

BA_DEF_DEF_

"NmJ1939SystemInstance"

0;

BA_DEF_DEF_

"NmJ1939System" 0;

BA_DEF_DEF_

"NmJ1939ManufacturerCode"

0;

BA_DEF_DEF_

"NmJ1939IndustryGroup"

0;

BA_DEF_DEF_

"NmJ1939IdentityNumber"

0;

BA_DEF_DEF_

"NmJ1939FunctionInstance"

0;

BA_DEF_DEF_

"NmJ1939Function" 0;

BA_DEF_DEF_

"NmJ1939ECUInstance"

0;

BA_DEF_DEF_

"NmJ1939AAC" 0;

BA_DEF_DEF_

"NmStationAddress"

254;

BA_DEF_DEF_

"GenMsgSendType"

"noMsgSendType";

BA_DEF_DEF_

"GenMsgRequestable" 1;

BA_DEF_DEF_

"GenMsgCycleTime" 0;

BA_DEF_DEF_

"SPN" 0;

BA_DEF_DEF_

"DBName"

"";

BA_DEF_DEF_

"BusType"

"CAN";

BA_DEF_DEF_

"ProtocolType"

"J1939";

BA_DEF_DEF_

"VFrameFormat"

"J1939PG";

BA_ "DBName"

"ECUTstInf";

BA_

"VFrameFormat" BO_ 2147486754

3;

BA_

"VFrameFormat" BO_ 2147486753

3;

编写Python脚本,首先数据的解析。完成一个M脚本,脚本会通过对MATLAB

Workspace中的数据模板进行拷贝修改完成数据定义。

脚本如下(其中Excel写入变量信息表的功能可以去掉):

#!/usr/bin/python

################################################################################

# Grey 2016.03.02

# Update : add the function to gnerate M script

for data import.

# Grey  2016.03.01

# generate variables list according to dbc

file.

# Inupt : dbc file name as a string, excel file

name as a string.

# Output : An excel file : variables list

file

#

import re

from xlwt import Workbook

def

GetVarList(dbc_file,var_list,model_name):

data_c_file

= model_name + '_Data.c'

data_head_file

= model_name + '_Data.h'

fid

= open('var_import.m','w')

book

= Workbook()

sheet_result

= book.add_sheet('variables')

data_type_dict

= {2:'uint8',8:'uint8',12:'uint16',16:'uint16'}

text_lines

= open(dbc_file,'r')

regexp_var

= re.compile(r'SG_\s+(\w+)\s+.*\|(\w+)@')

var_detail

=

re.compile(r'SG_.*\((\S+),(\S+)\).*\[(\S+)\|(\S+)\].*\"(\S*)\"')

index_col_num

= 0

var_name_col_num  = 1

data_type_col_num = 2

raw_num

= 0

sheet_result.write(raw_num,index_col_num,'index')

sheet_result.write(raw_num,var_name_col_num,'variable

name')

sheet_result.write(raw_num,data_type_col_num,'data

type')

for each_line in text_lines:

line_info  =

each_line.strip()

if line_info.startswith('SG_ '):

search_result

= regexp_var.search(line_info)

var_detail_result =

var_detail.search(line_info)

try:

raw_num += 1

var_name

= search_result.group(1)

data_index

= int(search_result.group(2))

data_type

= data_type_dict[data_index]

factor_value  =

var_detail_result.group(1)

bias_value

= var_detail_result.group(2)

min_value

= var_detail_result.group(3)

max_value

= var_detail_result.group(4)

unit_str

= var_detail_result.group(5)

sheet_result.write(raw_num,index_col_num,raw_num)

sheet_result.write(raw_num,var_name_col_num,var_name)

sheet_result.write(raw_num,data_type_col_num,data_type)

if data_type

== 'uint8':

fid.write("%s =

copy(base_8bit);\n" % var_name)

fid.write("%s.DataType =

\'fixdt(0,8,%s,%s)\';\n"

%(var_name,factor_value,bias_value))

fid.write("%s.Min =

%s;\n" % (var_name,0))

fid.write("%s.Max =

%s;\n" % (var_name,255))

fid.write("%s.DocUnits =

\'%s\';\n" % (var_name,unit_str))

fid.write("%s.RTWInfo.CustomAttributes.DefinitionFile

= '%s';\n" % (var_name,data_c_file))

fid.write("%s.RTWInfo.CustomAttributes.HeaderFile

= '%s';\n" % (var_name,data_head_file))

elif data_type == 'uint16':

fid.write("%s =

copy(base_16bit);\n" % var_name)

fid.write("%s.DataType =

\'fixdt(0,16,%s,%s)\';\n"

%(var_name,factor_value,bias_value))

fid.write("%s.Min =

%s;\n" % (var_name,0))

fid.write("%s.Max =

%s;\n" % (var_name,65535))

fid.write("%s.DocUnits =

\'%s\';\n" % (var_name,unit_str))

fid.write("%s.RTWInfo.CustomAttributes.DefinitionFile

= '%s';\n" % (var_name,data_c_file))

fid.write("%s.RTWInfo.CustomAttributes.HeaderFile

= '%s';\n" % (var_name,data_head_file))

#print("%s factor : %s\t bias :

%s\tMin : %s\tMax : %s\tUnit : %s" % \

#(var_name,factor_value,bias_value,min_value,max_value,unit_str))

except:

print("ERROR:%s" %

line_info)

book.save(var_list)

fid.close()

print("Process Done! Please

refer to excel file %s" % var_list)

GetVarList('test.dbc','temp.xls','DbcTst')

运行脚本,生成如下内容的M文件:

message_var3_16bit = copy(base_16bit);

message_var3_16bit.DataType =

'fixdt(0,16,1,0)';

message_var3_16bit.Min = 0;

message_var3_16bit.Max = 65535;

message_var3_16bit.DocUnits = '';

message_var3_16bit.RTWInfo.CustomAttributes.DefinitionFile =

'DbcTst_Data.c';

message_var3_16bit.RTWInfo.CustomAttributes.HeaderFile =

'DbcTst_Data.h';

message_var2_16bit = copy(base_16bit);

message_var2_16bit.DataType =

'fixdt(0,16,1,0)';

message_var2_16bit.Min = 0;

message_var2_16bit.Max = 65535;

message_var2_16bit.DocUnits = '';

message_var2_16bit.RTWInfo.CustomAttributes.DefinitionFile =

'DbcTst_Data.c';

message_var2_16bit.RTWInfo.CustomAttributes.HeaderFile =

'DbcTst_Data.h';

message_var2_8bit = copy(base_8bit);

message_var2_8bit.DataType =

'fixdt(0,8,1,0)';

message_var2_8bit.Min = 0;

message_var2_8bit.Max = 255;

message_var2_8bit.DocUnits = '';

message_var2_8bit.RTWInfo.CustomAttributes.DefinitionFile =

'DbcTst_Data.c';

message_var2_8bit.RTWInfo.CustomAttributes.HeaderFile =

'DbcTst_Data.h';

message_var1_16bit = copy(base_16bit);

message_var1_16bit.DataType =

'fixdt(0,16,1,0)';

message_var1_16bit.Min = 0;

message_var1_16bit.Max = 65535;

message_var1_16bit.DocUnits = '';

message_var1_16bit.RTWInfo.CustomAttributes.DefinitionFile =

'DbcTst_Data.c';

message_var1_16bit.RTWInfo.CustomAttributes.HeaderFile =

'DbcTst_Data.h';

test_flag = copy(base_8bit);

test_flag.DataType = 'fixdt(0,8,1,0)';

test_flag.Min = 0;

test_flag.Max = 255;

test_flag.DocUnits = '';

test_flag.RTWInfo.CustomAttributes.DefinitionFile

= 'DbcTst_Data.c';

test_flag.RTWInfo.CustomAttributes.HeaderFile =

'DbcTst_Data.h';

在MATLAB的Workspace中定义8位以及16位的数据定义模板,然后执行M文件。

数据定义模板:

运行后,Workspace中已经生成dbc中的数据定义,只需要把这些数据保存成mat文件即可保存使用。

后续,提供使用这个示例中的dbc文件进行建模的方法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/337311.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

cov/cor中有遗漏值_协调遗漏的效果–使用简单的NIO客户端/服务器测量回送延迟...

cov/cor中有遗漏值在这篇文章中,我演示了许多想法和技术: 如何编写一个简单的非阻塞NIO客户端/服务器 协同遗漏的影响 如何测量百分位数的延迟(相对于简单平均) 如何在计算机上计时延迟回送 我最近正在为客户端服务器应用程序…

C/C++,判断变量的类型

点击蓝字关注我们来源于网络,侵删出于某个奇葩需求,研究了一下c/c如何判断变量类型,整理总结在此,分享给大家,也避免自己以后绕弯。一、c判断变量类型c中,可以利用typeid()来判断变量类型。第一步&#xff…

python访问文件下载地址_用Python脚本去获得skydrive上文件的真实地址链接 + 提供脚本下载v2012-01-18...

之前得知微软提供的免费在线云存储空间Skydrive提供的空间大小达25GB的时候,就像其他人一样想到了可以用来存储音视频和图片,作为文件存储器,以便和别人分享文件。但是后来发现,skydrive中上面文件连接,通过系统提供的…

c/c++语言实现登陆界面

点击蓝字关注我们来源自网络,侵删一.整体功能介绍实现一个登陆界面1 输出一个登陆界面2 用户名能够实现邮箱验证,regex库,密码要不可见3 进度条的模拟实现4 音乐播放二.分步实现1.输出一个登陆界面首先对此功能使用到的函数进行简单的介绍。s…

spark restful_Spark入门:也可以用Java创建轻量级的RESTful应用程序

spark restful最近,我一直在使用Spark (一种Java的Web框架,与Apache Spark 不相关)编写RESTful服务。 当我们计划写这篇文章时,我已经做好了不可避免的接口,样板代码和深层层次结构的Java风格的准备。 令我…

C++的get()函数与getline()函数使用详解

点击蓝字关注我们来源自网络,侵删一.C的get()函数使用详解1.C get()函数get()函数是cin输入流对象的成员函数,它有3种形式:无参数的;有一个参数的;有3个参数的。1) 无参数的其调用形式为cin.get()用来从指定的输入流中…

电脑所有程序里有不一样颜色_12个好玩的电脑屏保,让你成为别人眼中最靓的仔。...

Hello 大家好,这里是工具狂人。作为一个靠打字(哦不,搬砖)为生的新媒体小编,每天多数时候都是对着电脑屏幕,中途有时会拿起手机回复消息、查看短信、刷起微博。刷手机的时间一长,眼前的电脑会自动打开系统的屏保程序&a…

java8 函数式编程_如何使用Java 8函数式编程生成字母序列

java8 函数式编程我偶然发现了用户“ mip”一个有趣的堆栈溢出问题 。 问题是: 我正在寻找一种生成字母序列的方法: A, B, C, ..., Z, AA, AB, AC, ..., ZZ.可以很快将其识别为Excel电子表格的标题,它确实做到了: 到目前为止&a…

C++判断变量/对象/枚举类型的简单方式

点击蓝字关注我们来源于网络&#xff0c;侵删1.关键点<typeinfo>使用typeid()操作符所需包含的头文件。typeid()获取变量类型信息的操作符&#xff0c;其返回值类型为std::typeinfo。我们可使用typeid(n) typeid(int)的方式来判断变量n是否为类型int。注&#xff1a;可以…

python循环输出三角形图案的画_python循环输出三角形图案的例子

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里技术人对外发布原创技术内容的最大平台&…

终端查看命令有哪些功能命令_从命令式功能到纯粹功能式功能,再返回:Monads与范围内的延续...

终端查看命令有哪些功能命令这段视频附带了这篇文章&#xff0c;没有它就不会太有意义 上个月&#xff0c;我在Curry On会议上做了演讲&#xff0c;该会议是与学术&#xff0c;编程语言会议ECOOP共同举办的新会议。 Curry On旨在弥合学术界之间的鸿沟。 我的学术兴趣不包括编程…

C++ 空指针和野指针

点击蓝字关注我们来源于网络&#xff0c;侵删1.空指针指针变量指向内存中编号为0的空间为空指针。空指针指向的内存空间是不可以访问的 。代码&#xff1a;#include<iostream> using namespace std; int main() {int a 10;int * p &a;cout << p << end…

jdbc事务 jta事务_将非事务性资源绑定到JTA事务中的几种模式

jdbc事务 jta事务我最近发表了一篇有关如何将非事务性资源&#xff08;如Web服务/微服务&#xff09;绑定到全局分布式事务中的文章&#xff0c;以便自动处理恢复。 多年来&#xff0c;我经常不得不将“非事务性”系统集成到Java EE应用程序服务器中&#xff0c;而数据一致性通…

sap abap开发从入门到精通_SAP开发-ABAP数据字典(锁)

企业级软件或开发框架&#xff0c;必然支持后台高并发&#xff0c;即支持多人同时访问数据库。SAP作为资深企业管理软件&#xff0c;自然也不例外&#xff0c;ABAP可以很方便的开发出支持高并发的程序&#xff0c;要实现高并发&#xff0c;正确使用锁对象是其中一个重要环节&am…

(acm)C++加速输入的几种方法

点击蓝字关注我们来源于网络&#xff0c;侵删1.CIO流的同步和绑定在C中&#xff0c;cin和cout的速度其实不并不慢&#xff0c;C中的流的IO速度相当的快&#xff0c;其速度与初始设定的缓存区大小和硬盘的IO速度有关。但在C中&#xff0c;为了兼容C的IO(scanf和printf)&#xff…

python引用函数_python 调用函数

Python内置了很多有用的函数&#xff0c;我们可以直接调用。要调用一个函数&#xff0c;需要知道函数的名称和参数&#xff0c;比如求绝对值的函数abs&#xff0c;只有一个参数。可以直接从Python的官方网站查看文档&#xff1a;也可以在交互式命令行通过help(abs)查看abs函数的…

服务器编写_编写下载服务器。 第六部分:描述您发送的内容(内容类型等)...

服务器编写就HTTP而言&#xff0c;客户端下载的只是一堆字节。 但是&#xff0c;客户真的很想知道如何解释这些字节。 它是图像吗&#xff1f; 还是ZIP文件&#xff1f; 本系列的最后一部分描述了如何向客户端提示她下载的内容。 设置 内容类型描述了返回的资源的MIME类型 。 …

python读取xls文件详解_python3解析excel文件

一.需要的依赖 : xlrd二.代码#codingutf-8import xlrd读取Excel每个sheet的第一列和第二列的值,拼接成json串,写入文件def resolveExcel():# 获取excel文件data xlrd.open_workbook("/you/excel/location/?.xlsx",encoding_overrideutf-8)#获取一个excel有多少个sh…

jdbc时区_什么比日期和时区更难? SQL / JDBC中的日期和时区!

jdbc时区在jOOQ邮件列表上&#xff0c;最近有一个有趣的讨论&#xff0c;关于jOOQ当前缺乏对TIMESTAMP WITH TIME ZONE数据类型的现成支持。 没有人说日期&#xff0c;时间和时区很容易&#xff01; 这里有一个有趣的文章&#xff0c;我建议阅读&#xff1a; 虚假的程序员相信…

C语言与C++的区别终于有人说清楚了!

点击蓝字关注我们来源于网络&#xff0c;侵删1、前言在很大程度上&#xff0c;C是C的超集&#xff0c;这意味着一个有效的C程序也是一个有效的C程序。C和C的主要区别是&#xff0c;C支持许多附加特性。但是&#xff0c;C中有许多规则与C稍有不同。这些不同使得C程序作为C程序编…