每日文献【2020|001】基于自适应回归扩展卡尔曼滤波的电动汽车动力电池全生命周期的荷电状态估算方法

本文主要是介绍每日文献【2020|001】基于自适应回归扩展卡尔曼滤波的电动汽车动力电池全生命周期的荷电状态估算方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

每日文献 |
带你坚持阅读
掌握行业最前沿技术

扫描下方二维码,进入微信公众号

文献 |
刘 芳,马杰,苏卫星等
基于自适应回归扩展卡尔曼滤波的电动汽车动力电池全生命周期的荷电状态估算方法
电工技术学报


该文针对传统扩展卡尔曼滤波(EKF)算法对电池数学模型精确的高度依赖与动态电池模型难以精确获得之间的矛盾问题,提出一种完全数据驱动的基于改进EKF算法的动力电池全生命周期荷电状态(SOC)估计方法。该方法为数据驱动的SOC估计方法和基于模型的SOC估计方法的良好结合,其优点在于:一方面抑制数据驱动方法存在累积误差的问题,并保留其良好的动态特性;另一方面改善基于模型的算法过度依赖电池模型的缺点,并保留其很好的鲁棒特性。该方法的创新之处在于将等效电路中难以获知的一部分视为以电池电流为输入,以内部电压为输出,以电池内部阻抗为时变参数的黑箱系统,并加以动态在线辨识,获得实时的动力电池真实状态,从而保证电池模型的准确性和动态性,真正实现动力电池全生命周期的SOC估算。

电池管理系统(Battery Management System, BMS)对电动汽车动力电池至关重要。其主要任务之一是通过估计动力电池的荷电状态(State of Charge, SOC)、健康状态(State of Health, SOH)、功率状态(State of
Power, SOP)等关键状态,确保动力电池在最佳运行状态下的安全性,已达到安全运行目的的同时,延长动力电池的使用寿命。

目前工程应用最为普遍的安时积分法,其计算复杂度较低,且易于实现,因此得到工程界的广泛认可,但其也有一定的局限性,如初始SOC不精确影响SOC估算精度,另外BMS检测的电流信号难免存在噪声、漂移等,而单纯的安时积分法会因此而无限制累积这种误差,导致其估算精度会逐渐下降,为此,工程上的解决办法为在动力电池截止电压处对其进行SOC修正。

基于模型的扩展卡尔曼滤波(Extended Kalman Filter, EKF)算法,因存在根据观测值矫正SOC的过程,而具有很好的鲁棒性,且准确性较高,但其估算精度高度依赖动力电池模型结构以及模型参数。

单纯基于数据的SOC估算方法,如基于神经网络的SOC估算方法,以及基于支持向量机(Support Vector Machine, SVM)的SOC估算方法等。此类算法不再依赖于动力电池模型结构以及电池参数,而是将动力电池视为黑箱,以可测得量作为输入(如电压、电流等),SOC作为输出,进行大量的模型训练,已获得精确的SOC 估算结果,此类算法完全基于数据,因此对数据质量较为依赖。数据不准确会影响神经网络训练的结果,另外此类算法网络结构复杂,前期需要大量数据训练。

回归(Auto Regression, AR)模型适用于平稳过程时间序列的预测模型,由于其是线性结构,因此计算量相对简单且具有在线更新特点;另外,AR模型完全基于数据驱动,而过程数据能够在动力电池全生命周期内真实地反应内部参数老化过程,因此采用AR模型对动力电池内部进行在线动态估算,能够较好地捕捉动力电池老化过程的变化。

综合AR模型以及EKF算法各自的优势,本文提出了一种完全数据驱动的基于AR-EKF的电动汽车动力电池全生命周期的SOC估算方法。基于AR-EKF算法的完整的SOC估计算法流程如下图所示。
在这里插入图片描述

电池模组实验验证解结果对比如下:
在这里插入图片描述

结论

本文提出了一种数据驱动的基于AE-EKF的电动汽车电池全生命周期的SOC估算方法。该方法将数据驱动的SOC 估计方法与基于模型的SOC估计方法有效地结合起来,可以避免数据驱动的SOC算法无法消除累积误差的问题,改善了基于模型的SOC估计方法过于依赖电池模型精度而导致的不适用于电动汽车等运行环境复杂多变且需要动力电池全生命周期的SOC估计要求。本文提出的SOC估计算法将内部电池阻抗模型视为具有慢时变特性的黑盒模型,进而采用基于AR模型对其动态建模分析,避免了由于电池一致性差、难以应用实验室测试数据的缺点,同时满足电池内部阻抗全生命周期的动态预估要求,使得本文提出的SOC 估计算法具有良好的动态特性。由于本文的主要思想是基于传统EKF的SOC估计方法,因此具有闭环校正SOC的结构,使得本文提出的动力电池全生命周期的SOC算法保留了传统EKF 算法的良好收敛性以及鲁棒特性。最后通过仿真验证说明了本文提出的数据驱动的基于AR-EKF的动力电池全生命周期SOC估计算法的实用性和有效性。

这篇关于每日文献【2020|001】基于自适应回归扩展卡尔曼滤波的电动汽车动力电池全生命周期的荷电状态估算方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

[word] word设置上标快捷键 #学习方法#其他#媒体

word设置上标快捷键 办公中,少不了使用word,这个是大家必备的软件,今天给大家分享word设置上标快捷键,希望在办公中能帮到您! 1、添加上标 在录入一些公式,或者是化学产品时,需要添加上标内容,按下快捷键Ctrl+shift++就能将需要的内容设置为上标符号。 word设置上标快捷键的方法就是以上内容了,需要的小伙伴都可以试一试呢!

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备

电脑不小心删除的文件怎么恢复?4个必备恢复方法!

“刚刚在对电脑里的某些垃圾文件进行清理时,我一不小心误删了比较重要的数据。这些误删的数据还有机会恢复吗?希望大家帮帮我,非常感谢!” 在这个数字化飞速发展的时代,电脑早已成为我们日常生活和工作中不可或缺的一部分。然而,就像生活中的小插曲一样,有时我们可能会在不经意间犯下一些小错误,比如不小心删除了重要的文件。 当那份文件消失在眼前,仿佛被时间吞噬,我们不禁会心生焦虑。但别担心,就像每个问题

iptables(7)扩展模块state

简介         前面文章我们已经介绍了一些扩展模块,如iprange、string、time、connlimit、limit,还有扩展匹配条件如--tcp-flags、icmp。这篇文章我们介绍state扩展模块  state          在 iptables 的上下文中,--state 选项并不是直接关联于一个扩展模块,而是与 iptables 的 state 匹配机制相关,特

邮件群发推送的方法技巧?有哪些注意事项?

邮件群发推送的策略如何实现?邮件推送怎么评估效果? 电子邮件营销是现代企业进行推广和沟通的重要工具。有效的邮件群发推送不仅能提高客户参与度,还能促进销售增长。AokSend将探讨一些关键的邮件群发推送方法和技巧,以帮助企业优化其邮件营销策略。 邮件群发推送:目标受众 了解他们的需求、兴趣和行为习惯有助于你设计出更具吸引力和相关性的邮件内容。通过收集和分析数据,创建详细的客户画像,可以更精

上采样(upsample)的方法

上采样(upsample)的方法   在神经网络中,扩大特征图的方法,即upsample/上采样的方法   1)unpooling:恢复max的位置,其余部分补零   2)deconvolution(反卷积):先对input补零,再conv   3)插值方法,双线性插值等;   4)扩张卷积,dilated conv;

青龙面板部署通用教程,含服务器、路由器、X86等部署方法

1. 拉取镜像/更新镜像 docker pull whyour/qinglong:latest 2. 删除镜像 docker rmi whyour/qinglong:latest 3. 启动容器 普通服务器 docker run -dit \-v $PWD/ql/config:/ql/config \-v $PWD/ql/log:/ql/log \-v $PWD/ql/db:

# bash: chkconfig: command not found 解决方法

bash: chkconfig: command not found 解决方法 一、chkconfig 错误描述: 这个错误表明在 Bash 环境下,尝试执行 chkconfig 命令,但是系统找不到这个命令。chkconfig 命令是一个用于管理 Linux 系统中服务的启动和停止的工具,通常它是 initscripts 包的一部分,但在最新的 Linux 发行版中可能已经被 syste

Python几种建表方法运行时间的比较

建立一个表[0,1,2,3.......10n],下面几种方法都能实现,但是运行时间却截然不同哦 import time#方法一def test1(n):list=[]for i in range(n*10):list=list+[i]return list#方法二def test2(n):list=[]for i in range(n*10):list.append(i)#方法三d