【研发日记】吃透新能源充电协议(一)——GB27930实例报文解析

本文主要是介绍【研发日记】吃透新能源充电协议(一)——GB27930实例报文解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

前言

背景介绍

充电协议框架

充电握手阶段

充电准备阶段

充电传输阶段

充电结束阶段

错误处理阶段

总结

参考资料


前言

        近期在一个嵌入式开发项目中,用到了新能源充电协议,期间在翻阅各种资料文件时,一些地方还是容易理解偏差的。所以利用晚上和周末时间,把这些内容标注了一下,尽可能地把它们解释透彻。后面会用若干篇文章把这些内容总结分享出来,一方面备着将来翻看,另一方面也希望能够帮到这一领域的粉丝朋友们。

背景介绍

        GB/T 27930规定了电动汽车快充时,充电机与车辆之间通过CAN交互的通信协议。其在充电中发挥的作用如下图所示:

充电协议框架

        GB/T 27930的通信协议,在充电总体流程中所处的阶段如下图所示:

 

充电握手阶段

        充电握手阶段的实例报文如下图所示:

        CHM(Charger Handshake Message,充电机握手报文)是充电交互的第一个报文,是由充电机发起的,目的是向车辆发起请求,告诉车辆即将要准备充电了。在发送CHM之前,充电机需要先做完如下四件事情:

1,检查CC1信号,确保充电枪与车辆之间的机械连接已到位;

2,等待用户在充电桩的屏幕上完成扫码(或刷卡)操作,确保可以付充电费;

3,充电枪的锁钩锁止,确保机械连接不会意外断开;

4,充电桩给车辆的低压辅助供电线路通电,确保完全亏电的车辆在这也能启动。

        BHM(BMS Handshake Message,车辆握手报文)是车辆端发出的第一个交互报文,目的是回应充电机的CHM请求,告诉充电机可以开始充电流程。在发送BHM之前,车辆要先检查CC2信号,从车辆的角度确保机械连接已到位。

        CRM(Charger Recognize Message,充电机辨识报文),充电机收到BHM后开始发送该报文,目的是向车辆报告自己的基本信息(充电桩编号、充电桩位置),并辨识车辆的基本信息,如果辨识成功,就会将RecognitionResult置为0xAA(初始值为0x00)。在发送CRM之前,充电机要先进行绝缘自检,确保充电机的DC高压与外壳和大地之间不会漏电。

        BRM(BMS Recognize Message,车辆辨识报文),车辆收到CRM后开始发送该报文,目的是向充电机报告自己的基本信息(比如车辆VIN、电压平台、电池容量、硬件生产信息和软件开发信息等)。

充电准备阶段

        充电准备(参数配置)阶段的实例报文如下图所示:

        BCP(Battery Charge Parameter,动力蓄电池充电参数报文),车辆收到辨识成功的CRM后开始发送该报文,目的是向充电机报告自己的充电参数,其中最关键的是最大充电电压和最大充电电流,告诉充电机后面的输出不要超过该上限。

        CTS(Charger Time Synchronization,充电机时间同步报文),充电机收到BCP后开始发送该报文,目的是在充电机和车辆之间建立一个统一的时间基准。比如车辆断网了,车上的时间就会存在误差,这时候就可以使用CTS里的时间进行校准。在有些场景中,这个报文是不需要的,所以该报文是非必须的可选项

        CML(Charger Maximum Limit,充电机最大输出能力报文),充电机收到BCP后开始发送该报文,目的是向车辆报告自己的输出能力范围:最大最小充电电压,最大最小充电电流。以便车辆端的充电策略计算充电速度和剩余充电时间。

        BRO(BMS Ready OK,BMS充电准备就绪报文),车辆收到CML后开始发送该报文,目的是向充电机报告自己是否为充电传输做好准备了。初始BmsReadyForCharging=0x00时,代表车辆已经开始准备了但是还没准备好。这时候车辆在做的准备工作是闭合电池包的主继电器,然后进行绝缘自检,确保车辆的DC高压与车体和大地之间不会漏电。由于是先闭合主继电器后绝缘自检,并且充电枪也已经插好了,所以如果充电枪和线缆有绝缘不良也会被检测到。当BmsReadyForCharging=0xAA时,代表车辆已经做完准备工作了。

        CRO(Charger Ready OK,充电机输出准备就绪报文),充电机收到BRO后开始发送该报文,目的是向车辆报告自己是否为充电传输做好准备了。初始ChargerReadyForCharging=0x00时,代表充电机正在做准备工作——闭合充电机的主继电器。当ChargerReadyForCharging=0xAA时,代表充电机已经做完准备工作了。

充电传输阶段

        充电传输阶段的实例报文如下图所示:

        Tips:CCS和BSM中都有多余未使用的Byte和bit,默认使用0xFF和1填充

        BCL(Battery Charge Lead,电池充电需求报文),车辆收到0XAA的CRO后开始发送该报文,目的是向充电机报告自己的充电需求信息(充电电压、充电电流、恒压充电还是恒流充电)。这些充电需求信息是事实更新的,主要随着BMS的充电策略变化。

        BCS(Battery Charge Status,电池充电总状态报文),车辆发送BCL时同时开始发送该报文,目的是向充电机报告自己当前的实时充电状态(电压、电流、SOC等),这些信息源于BMS自己的传感器采集和计算。

        CCS(Charger Charge Status,充电机充电状态报文),充电机收到BCL和BCS后开始发送该报文,目的是向车辆报告自己当前的实时输出状态(电压、电流、累计时间等),这些信息源于充电机自己的传感器采集和计算。充电机在发送CCS的同时,要根据BCL中的需求来调整输出电压和输出电流。在恒压充电模式下,充电机的输出的电压应满足电压需求值,输出的电流不能超过电流需求值。在恒流充电模式下,充电机输出的电流应满足电流需求值,输出的电压不能超过电压需求值。

        BSM(Battery Status Message,BMS发送动力蓄电池状态信息报文),车辆收到CCS后开始发送该报文,目的是向充电机报告自己的电池状态信息(最大单体电压的位号,最大最小单体温度和位号,过压,过SOC,过流,过温,绝缘状态、连接器状态等),确保在电池包出现异常时能够及时停止充电

充电结束阶段

        充电结束阶段的实例报文如下图所示:

        CST(Charger Stop,充电机中止充电报文),要停止充电时,如果是充电机主动停止就直接发送该报文,如果是车辆主动停止就在收到BST后发送该报文,目的是向车辆报告自己即将停止充电,以及停止的原因。停止原因大体分为如下4种:

1,用户在给充电机设定的条件达到了,比如设定的充50度电,或者设定的充80元电费;

2,人为停止充电,比如用户在充电机屏幕上点击了停止充电,或者在充电机App上远程停止充电;

3,充电机故障或错误,比如充电机过热,或者充电机的电压电流异常等;

4,响应车辆发起的停止充电命令;

        BST(BMS Stop,BMS中止充电报文),要停止充电时,如果是车辆主动停止就直接发送该报文,如果是充电机主动停止就在收到CST后发送该报文,目的是向充电机报告自己即将停止充电,以及停止充电的原因。停止原因大体分为如下4种:

1,电池包充满了,或者用户给车辆设置了某个SOC达到了;

2,电池包的总电压达到了BMS的管理值;

3,电池包的最高单体电压达到了BMS的管理值;

4,响应充电机发起的停止充电命令;

        BSD(BMS Statistics Data,BMS统计数据报文),前面的CST和BST互发之后,充电机开始发送该报文,目的是向充电机报告本次充电过程后的统计结果(SOC,最大最小单体电压,最大最小单体温度)。

        CSD(Charger Statistics Data,充电机统计数据报文),充电机收到BSD后开始发送该报文,目的是向车辆报告本次充电过程后的统计结果(累计充电时长、充电度数等)。在发送CSD之前,充电机要先停止电量输出,确保CSD的计算是准确的,也确保后面不会带载切断继电器。

        在BSD发送CSD之后,充电机和车辆还需要继续做完如下四件事情:

1,车辆检测实际电流小于5A后,切断电池包继电器

2,充电机检测实际电流小于5A后,切断充电机继电器

3,充电机切断辅助供电电源线路;

4,用户处理充电机的结算等后续流程,解锁钩子,用户拔枪。

 

错误处理阶段

        下期继续

总结

        GB/T 27930通信协议各个阶段的报文和相应动作,汇总在一起如下图所示:

 

        以上就是本人在研发中使用新能源充电协议 GB/T 27930时,一些个人理解和分析的总结,主要介绍了该充电协议的工作原理,展示了具体的实例报文,并分析了它的特点和应用。

        后续还会分享另外几个最近解锁的新能源新充电协议新技能,欢迎评论区留言、点赞、收藏和关注,这些鼓励和支持都将成文本人持续分享的动力。

        另外,上述例程使用的Demo工程,可以到笔者的主页查找和下载。

参考资料

    GB/T 18487.1-2023 电动汽车传导充电系统  第1部分:通用要求GB/T 27930-2023 非车载传导式充电机与电动汽车之间的数字通信协议

        版权声明,原创文章,转载和引用请注明出处和链接,侵权必究!

这篇关于【研发日记】吃透新能源充电协议(一)——GB27930实例报文解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

Oracle Expdp按条件导出指定表数据的方法实例

《OracleExpdp按条件导出指定表数据的方法实例》:本文主要介绍Oracle的expdp数据泵方式导出特定机构和时间范围的数据,并通过parfile文件进行条件限制和配置,文中通过代码介绍... 目录1.场景描述 2.方案分析3.实验验证 3.1 parfile文件3.2 expdp命令导出4.总结

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

Java解析JSON的六种方案

《Java解析JSON的六种方案》这篇文章介绍了6种JSON解析方案,包括Jackson、Gson、FastJSON、JsonPath、、手动解析,分别阐述了它们的功能特点、代码示例、高级功能、优缺点... 目录前言1. 使用 Jackson:业界标配功能特点代码示例高级功能优缺点2. 使用 Gson:轻量

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

MySQL的索引失效的原因实例及解决方案

《MySQL的索引失效的原因实例及解决方案》这篇文章主要讨论了MySQL索引失效的常见原因及其解决方案,它涵盖了数据类型不匹配、隐式转换、函数或表达式、范围查询、LIKE查询、OR条件、全表扫描、索引... 目录1. 数据类型不匹配2. 隐式转换3. 函数或表达式4. 范围查询之后的列5. like 查询6