基于LabVIEW的电池管理系统与充电机通信协议测试

发布者:创意火舞最新更新时间:2015-03-30 来源: ck365关键字:LabVIEW  电池管理系统  充电机  通信协议测试 手机看文章 扫描二维码
随时随地手机看文章
0 引言

随着近年来电动汽车行业如火如荼的发展,电动汽车技术相关的各种标准也相继推出,其中包括了《电动汽车非车载传导式充电机与电池管理系统之间的通信协议》(GB/T 27930-2011)。该协议是基于CAN应用层协议SAE J1939,J1939 是目前在国内汽车行业中应用广泛的CAN总线应用层协议。只有电池管理系统与充电机之间的正常数据交互才能保证电动汽车进行高效、安全的充电。因此,电池管理系统与充电机通信协议测试是电池管理系统测试的一个必不可少的项目。

本课题来源于北方车辆研究所电池管理系统测试平台项目。美国国家仪器NI PXI CAN采集卡以及Labview为模拟充电机与BMS通信提供了良好的软硬件环境。

LabVIEW是美国国家仪器推出的一种程序开发环境,图形化语言使其与其他的代码类型语言相比之下更为方便直观。以计算机作为运行环境的LabVIEW,充分利用了计算机无可比拟的硬件优势,具有强大的数据处理能力。开发者可以很容易实现多线程编程,极大降低了软件开发的难度。LabVIEW的前面板提供了丰富的类似传统仪器的控件,开发者可以很方便的创建用户界面。

本文重点在于如何用LabVIEW实现SAE J1939多帧传输机制,完成超过8 B 报文的接收重组、拆分发送。以及如何实时判断通信过程出现的错误、指出错误类型、定位错误发生的阶段。

1 SAE J1939 协议

J1939 协议是基于CAN 2.0B 制定的,协议对物理层、数据链路层、网路层以及应用层都进行了相关的规定。本文针对数据链路层的规定进行简单介绍。

1.1 协议数据单元(PDU)

J1939 将CAN 2.0B 的29 位标识符ID 划分为六部分,每部分都代表不同的含义,包括优先级(P)、保留位(R)、数据页(DP)、PDU格式(PF)、特定PDU(PS)、源地址(SA),见表1.

 

 

根据CAN 2.0 总线的仲裁机制,标识符值越小,CAN帧优先级越高,J1939把这一权利赋予了标识符最高三位(P)。R、DP通常为0.SA代表了该帧数据的发送节点的地址,CAN 网络中每个设备都分配了惟一的SA.在介绍PF 与PS之前有必要先介绍下参数组编号(PGN)的概念。每个PGN代表着惟一的参数组(可以包含一个或多个参数),当参数组的数据域大于8 B时,需要遵循J1939的多帧传输机制。PGN 由R、DP、PF 以及PS 组成,见表2.从表2 中可以看出PDU2 格式报文没有目标地址,此类报文只能发送给全局地址。由于PS作为PDU2 格式参数组编号的一部分,因此PDU2 比PDU1能定义更多的参数组编号。

 

 

1.2 多帧传输机制

CAN 2.0B 数据域最多有8 B,而在J1939协议中当一个参数组编号(PGN)所对应的数据超过8 B时,规定了一种多帧传输机制,发送者按此机制拆分发送,接收者按此机制接收重组,因此一个参数组编号所对应的数据最多可以为1 785 B.点对点未发生错误的多帧传输机制如图1 所示,J1939 对传输过程出现错误的情况也规定了相应的处理机制,在此不作介绍。

TP.CM_RTS、TP.CM_CTS、TP.DT、TP.EndofMsgACK均为J1939特定功能报文,其参数组编号也由J1939规定,因此这些参数组编号不能再被用户定义。TP.CM_RTS为消息发送者发送的请求发送帧,由此开始建立多帧传输链接,其数据域包括了此次发送的消息全部字节数、全部数据包数(TP.DT 帧数)以及该消息的参数组编号等信息。接收者根据自己的接收能力,发送准备发送帧TP.CM_CTS,通知发送者下次可发送的数据包数、下一个要发送的数据包编号以及消息的参数组编号。发送者根据接收者的要求开始发送数据包TP.DT,数据包的数据域第一字节代表了该包号,因此一个数据包最多包含消息的7 B.

 

 

这个过程循环进行,直至接收者接收到全部数据包后发送消息结束应答帧TP.EndofMsgACK代表着这次多帧传输的结束。若发送的消息是全局消息,则所有接收者不应有任何应答,整个传输过程如图2所示。

 

 

2 基于LabVIEW实现J1939 协议平台

2.1 硬件接口

利用NI PXI-8513 CAN 接口板卡实现该系统的硬件接口。NI已为开发者提供了该板卡的底层驱动,可以很方便对CAN节点参数进行配置以及接收和发送符合CAN 2.0的消息帧,然而对于多帧传输机制还需开发者自行设计。由于J1939 协议涉及发送者与接收者的应答,因此在基于LabVIEW开发J1939同时也利用C语言开发基于飞思卡尔单片机的电池管理系统中使用的J1939 协议,两者相辅相成,并且利用VECTOR CANoe软件监视总线,以保证程序开发的顺利进行。[page]

2.2 软件实现

利用LabVIEW多线程编程以及生产者消费者结构实现J1939协议。分别为未拆分的发送报文、已拆分发送报文、未重组的接收报文、已重组的接收报文建立队列。创建已重组报文读取线程,已重组报文出队列用于应用层协议。创建接收报文处理线程,用于按多帧传输机制处理接收到的CAN 2.0数据帧,程序流程图如图3所示,经过目的地址过滤报文后,利用条件结构按照报文参数组编号进行分类处理,在计算参数组编号时要注意PDU1与PDU2格式的区别,主要分为以下几种情况:

数据小于7 B的正常数据报文:直接入已处理接收报文队列供应用层使用;请求发送帧TP.CM_RTS:由于两个节点之间同一时间最多只能有一个发送和一个接收的多帧传输链接,若这时已有一个接收链接,则需要发送放弃链接帧TP.ABORT告知发送者,若无接收链接,创建新的接收状态机并插入接收状态机数组。接收状态机为一个数据簇,包含了参数组编号、下一个接收数据包编号、数据包总数、当前已接收字节数、字节总数、以及已接收字节数组。之后应发送准备发送帧TP.CM_CTS 通知发送者发送数据包,同时应开始计时,若发送者响应时间超过规定时间,应发送放弃帧TP.ABORT;准备发送帧TP.CM_CTS:此报文为接收者对发送报文的应答,此次发送状态机已建立,搜索相应状态机,根据准备发送帧要求拆分数据创建数据包TP.DT;数据包TP.DT:搜索相应的接收状态机并核对是否与目前状态机相符,如果相符则对数据进行重组存入状态机的接收字节数组,若不符则发送该参数组编号的放弃链接帧,最后判断多帧传输是否结束,并根据是否为全局报文决定是否发送完成链接帧;完成链接帧TP.EndofMsgACK:表示相应的多帧发送链接已完成,删除相应的发送状态机。广播公告消息TP.

CM_BAM:收到全局消息的请求链接帧,只需建立相应的接收状态机,等待接收数据包,而不需要任何的应答。

 

 

发送报文均先入未拆分发送报文队列;创建未拆分发送报文处理线程,用于按多帧传输机制处理发送报文,程序流程图如图4所示,若发送报文数据超过8 B则需要通过多帧传输机制拆分发送。

 

 

2.3 J1939平台应用效果

定义电池管理系统BMS和LabVIEW的J1939协议地址分别为244和86.首先由BMS发送PGN为256的9 B报文给LabVIEW,CANoe监视到总线时序如图5所示。

 

 

由第一帧ID可以看出源地址为0xF4(244),目的地址为0×56(86),PGN为0xEC00,因此该帧为链接管理帧TP.CM,并且Data 域控制字节(第1 字节)为0×10,综上该帧为BMS 发送给LabVIEW的请求发送帧,并由Data域可以看出此次报文共有0×09字节(第2,3字节),数据包共有0×02 包(第4 字节),PGN 为0×0100(第6,7,8 字节)。同理第二帧为LabVIEW发送的准备发送帧,通知BMS 从第0×01 包(第3 字节)开始发送0×02(第2 字节)包数据包。待接收到BMS发送的两帧TP.DT,LabVIEW发送TP.EndofMsgACK 代表此次多帧传输完成。Lab-VIEW接收重组后的数据如图6所示。

 

 

同理分析LabVIEW 作为发送节点的情况,总线时序图如图7所示,LabVIEW拆分前的发送数据如图8所示。综上分析,利用LabVIEW 开发平台很好地实现了J1939协议。[page]

 

 

 

 

3 通信协议测试软件的开发

通信协议将整个通信分为多个阶段:充电握手阶段、充电参数配置阶段、充电阶段、充电结束阶段。每个通信阶段均涉及充电机与BMS 的信息交互,每次信息交互均有超时限制。为了实现对通信协议进行测试,不仅要模拟充电机与BMS 进行通信,还要实时监测通信的状态,判断通信过程是否出错并解析BMS 发送的信息。测试软件主要测试通信阶段出现的时序错乱以及信息交互超时这两种错误。

在已开发J1939协议基础上进行测试软件的开发,J1939协议提供了两个接口:需要发送报文直接入未处理发送报文队列、已处理接收报文出队列供应用层使用。通信阶段改变利用LabVIEW 状态机结构来实现。

创建充电机接收状态、充电机发送状态两个数据簇,记录接收报文是否已被接收、发送报文是否已被发送以及发送的时间。利用单独程序线程通过这两个数据簇实时判断是否有错误发生。

应用效果如图9所示,为了试验是否能准确测试出错误类型,有意将BMS 程序设置为不发送电池充电需求报文,测试软件指示超时类型代码为5,即电池充电需求报文超时,接收错误类型主要为通信顺序出错。通过对每个接收超时类型以及顺序出错类型进行测试,结果表明能很好地实现对通信协议进行测试。

 

 

4 结语

在LabVIEW开发平台上,利用其强大的数据处理能力以及丰富实用的程序结构实现了J1939协议,在此基础上开发电动汽车非车载传导式充电机与电池管理系统之间的通信协议测试软件,不仅可以辅助BMS的程序开发,还可以作为BMS测试平台的部分功能评价BMS合格与否。通过与BMS进行通信,并利用CANoe对总线进行监视,试验结果表明该测试软件可以实现J1939协议,能完成多帧传输机制,并且可以测试出通信协议中出现的通信流程错乱以及通信超时错误,可以满足要求。

关键字:LabVIEW  电池管理系统  充电机  通信协议测试 引用地址:基于LabVIEW的电池管理系统与充电机通信协议测试

上一篇:基于LabVIEW的改进d-q变换电压暂降分析
下一篇:虚拟仪器在手机电路板自动测试系统的解决方案

推荐阅读最新更新时间:2024-03-30 22:55

labview编程技巧之如何进行数组排序
  Labview编程技巧-----如何进行数组排序   数组排序是经常用到的,LABVIEW提供了对一维数组的排序节点.   这是个多态VI,支持多种数据类型,包括簇,如果是簇数组,它首先按照第一个元素进行排序,如果第一个元素相同,则比较第二个元素.   一维数组的排序是非常简单的,我们经常遇到的是对多个数组进行排序的问题,比如一个TABLE,它实际上是一个2维字符串数组,如果要求安列进行排序,这在数据库查询时经常用到.   问题可以简化成:   ARRAY1   ARRAY2   ARRAY3...   我们可以很容易第对ARRAY1进行排序,如何根据ARRAY1排序的结果对ARRAY2,ARRAY3进行相
[测试测量]
<font color='red'>labview</font>编程技巧之如何进行数组排序
动力电池市场崛起,BMS前途一片大好?
新能源汽车与传统燃油汽车最大的区别是用 动力电池 作为动力驱动,而作为衔接电池组、整车系统和电机的重要纽带, BMS 电池管理系统 的重要性不言而喻,BMS是动力电池组的核心技术,小部件蕴含大智慧,也是整车企业最为关注的环节。   BMS属于动力电池系统的一部分,总的来说,BMS负责管理及维护各个电池单元,防止电池出现过充电和过放电,延长电池的使用寿命,监控电池的状态。     目前,在全球BMS市场中亚太地区占据着最大市场份额,据预测,伴随着新能源近年来的发展,未来几年全球BMS市场规模将继续扩大。       市场热度如此之高,成本控制显得十分重要。电池系统的成本构成中,电池组占据了大部,约67%,而BMS系统则占据了第
[嵌入式]
学习LabVIEW(七)——ZXing.NET解码
这次用LabVIEW实现了对图像文件中的二维码的解码。解码引擎依然使用ZXing.NET。ZXing.NET的主页上给出了一个简单的解码的例子,我们就参考这个例子,实现了今天的LabVIEW程序。 为了实现解码,首先需要构造BarcodeReader类的实例,如之前在 《学习LabVIEW(一) 调用ZXing.NET》 中所述,使用 互连接口- .NET- 构造器节点 即可。在 选择构造器 对话框中点击 浏览按钮 ,在弹出的文件对话框中选中zxing.dll,和之前都是一样的。构造函数选择无参数的版本即可,如下图所示: BarcodeReader在解码时需要传入一个代码了二维码图像的Bitmap对象。
[测试测量]
新型智能充电机充电模式
锂离子电池组充电机充电不均衡易使其产生过充放电问题,严重损害其使用寿命。本文提出了一种新型智能充电机充电模式,使电池组更加安全、可靠地充电机充电,能够延长其使用寿命,增加安全性,降低使用成本。 1、车载锂离子电池管理系统 作为电动汽车电池的监测“大脑”,电池管理系统(BMS)在混合动力电动汽车中可以实现对电池剩余电量的监测,预测电池的功率强度,便于对整个电池系统的了解和整车系统的掌控。 在纯电动汽车中,BMS具有预测电池剩余电量、预测行驶里程和故障诊断等智能调节功能。BMS对锂离子电池的作用尤为明显,可以改善电池的使用状态、延长电池使用寿命、增加电池安全性。BMS将是未来电动汽车发展的关键技术。   车载动力电池系统及充电机充电
[嵌入式]
labview数据文件操作
今天做的是 产生0 9共10个数据,然后按行写入与VI相同路径下的文本文件这里要求每个数字占一行,要用到控件 格式化写入字符串 程序如下图 这里要禁用索引,打开文件最好用open and creat 属性
[测试测量]
NI 25周年 发布LabVIEW 2011
新闻发布——2011年8月1日——美国国家仪器有限公司(National Instruments,简称NI)于公司总部德克萨斯州奥斯汀市主办的NIWeek上揭开了 NI LabVIEW 2011的面纱——备受赞誉的LabVIEW软件迎来了25周年。LabVIEW将加速提升工程师与科学家研发和部署测试测量和控制系统的效率,以应对和解决一些世界上最艰巨的工程挑战。LabVIEW 2011 通过新的工程实例库及其对大量硬件设备和部署目标的交互支持极大地增进了效率。这其中包含新的多核NI CompactRIO控制器及当今业界性能最强大的射频向量信号分析器之一的NI PXIe-5665。LabVIEW 2011还支持内置在最新的Micros
[测试测量]
当移动技术遇到LabVIEW
5种方法将移动技术加入到你的测控系统中 2011年,Steve Jobs宣布“后PC时代”的到来。同年,智能手机和平板电脑的全球销量超越了传统的笔记本电脑和台式电脑。尽管个人电脑不会因此被淘汰,但很明显的是,移动技术正在从根本上改变着我们获取和使用信息的方式。 智能手机和平板电脑被创造的初衷就是为了满足消费者,如今,它们也已经被应用到了很多消费领域中。比如在健康保护领域,它们可以帮助使用者远程访问病人数据;在教育领域,它们可以被用作交互式的课本。类似的,移动技术也对数据采集领域造成了革命性影响。 通过将移动技术与数据采集设备结合,工程师和科学家创造出了极具便携性和互联性的测量系统,这让他们可以在更多场合进行测量。
[网络通信]
当移动技术遇到<font color='red'>LabVIEW</font>
基于USB和LabVIEW的温度报警系统设计
O 引言 通用串行总线USB(Universal Serial Bus)具有较高的传输速率、支持即插即用和热插拔、易于扩展以及可靠性高、成本低、功耗低等特点,USB2.0接口的传输速率高达480Mbps,完全能满足PC机和外设进行大量数据交换的要求。 LabVIEW是美国国家仪器公司开发的一种虚拟仪器平台,提供了丰富的数据采集、分析和存储函数以及包括RS232/485等各种仪器通信总线标准的所有功能函数,但是LabVIEW开发的虚拟仪器通常是建立在LabVIEW支持的价格昂贵的数据采集板卡之上,本文选用单片机小系统对温度进行采集。 1 系统组成及工作原理 系统框图如图l所示,整个系统包括温度采集、温度传输和温度处理3
[工业控制]
基于USB和<font color='red'>LabVIEW</font>的温度报警系统设计
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
最新测试测量文章
换一换 更多 相关热搜器件
随便看看
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved