1. Introduction
Replacing traditional fuel vehicles with new energy vehicles is an effective way to deal with the energy crisis and environmental pollution [
1]. Lithium-ion batteries have become the main source of power for electric vehicles owing to their low cost and low pollution. The state of charge (SOC) estimation is one of the core functions of battery management systems of electric vehicles, which can avoid overcharge and over-discharge of batteries, achieve balanced management of battery packs, and effectively guide users to charge the batteries. Accurate estimation of the SOC can improve battery working efficiency, prolong battery life, and play an important role in ensuring the stable and safe operation of battery packs [
2].
At present, the SOC estimation methods mainly include the ampere-hour integration (Ah) method, open-circuit voltage (OCV) method, model-based method, and data-driven method [
3]. Despite the Ah integration method being widely used in practical applications as its simple principle, its error will increase with the accumulation of errors as it is an open-loop form of estimation method, which leads to the deterioration of estimation accuracy [
4,
5]. The OCV method obtains the relationship between the open circuit voltage and the SOC through the discharge experiments and then estimates the SOC based on the relationship above. However, this method requires a long battery resting time, which is time-consuming and difficult to apply to online estimation [
6,
7,
8]. The data-driven method achieves accurate state estimation by obtaining a black-box model through training a large amount of data. But its internal algorithm is complex, which leads to excessive computation, and its accuracy will be significantly reduced when the amount of data is small [
9,
10,
11]. It is widely used for model-based methods as it has low complexity, high precision, and easy parameter identification complexity [
12,
13]. Model-based filtering algorithms include the Kalman filter (KF) and Particle filter (PF). For the reason of the traditional KF algorithm can only deal with linear problems, many improved KF algorithms are derived. Qiu et al. [
14] used the least squares method to identify the parameters of the battery model and then combined it with the extended Kalman filter (EKF) algorithm to estimate the SOC. The results show that the method could accurately estimate the SOC. Tan et al. [
15] proposed an improved unscented Kalman filter (UKF) algorithm for the problem that the voltage observation data is susceptible to environmental interference, which could cause a decrease in the accuracy. The results show that the algorithm has strong robustness and high precision. Liu et al. [
16] proposed a Drift-Ah integration method for the influence of drift current on SOC estimation and used the volumetric Kalman filter (CKF) algorithm to estimate the SOC. The results show that the method can effectively reduce the influence of drift current and improve estimation accuracy. Li et al. [
17] proposed an improved CKF algorithm for the noise in the CKF algorithm that cannot satisfy the real-time dynamic characteristics during the iterative process. The experimental results show that the proposed method has higher estimation accuracy and better stability than the EKF algorithm. Tang et al. [
18] proposed a method that fuses the EKF algorithm, HIF algorithm, and AEKF algorithm to estimate SOC estimation, which shows a lower computational burden.
However, the improved KF algorithms are still limited to the Gaussian noise environment and difficult to apply in practical scenarios, while the PF algorithm [
19,
20,
21] has a greater application prospect for it is not limited by Gaussian noise. Wu et al. [
22] proposed an adaptive PF algorithm based on a multi-model to solve the problem of accuracy degradation of the multi-target tracking problem with unknown noise statistics when solved by the traditional filter. The results show that the algorithm has strong anti-interference ability and high accuracy. Li et al. [
23] used the PF algorithm to process underwater acoustic signals under non-Gaussian conditions. The simulation results show that the PF algorithm has significantly improved tracking performance compared with the EKF algorithm. Shao et al. [
24] used the PF algorithm to estimate the SOC and validated the accuracy under electric vehicle driving conditions in Beijing. The results show that the PF algorithm has better estimation performance and has the same computational complexity compared with the EKF algorithm and UKF algorithm. Aiming at the problem that the reduction of the SOC estimation accuracy due to errors introduced by drift current when the current sensor collected the current, Liu et al. [
25] used the drift current as a parameter of the temperature compensation model. Then a two-particle filter estimator was designed to estimate the SOC and the drift current at the same time. The results showed that the algorithm has high SOC estimation accuracy and good robustness. After several iterations of the conventional particle filter algorithm, the particle diversity decreases, and the weight difference becomes larger. Since the likelihood function used in particle update is a normal distribution, only a small part of the particles will increase in weight after the update, while most particles will degenerate. Eventually, only a small number of particles can represent the posterior probability distribution, resulting in a significant decrease in estimation accuracy. To improve the particle diversity, Zhao et al. [
26] used the EKF as the proposed distribution of the PF algorithm. The simulation experiments showed that the algorithm significantly improves the accuracy of SOC, but the method is computationally intensive. Wu et al. [
27] proposed an unscented particle filter (UPF) algorithm by improving the PF algorithm with the UKF algorithm. The results showed that the algorithm is more stable and has better performance than the PF algorithm, but the method lacks practicality. Bi et al. [
28] optimized the update process of the PF algorithm by using an artificial immune algorithm to increase the diversity of particles. The results showed that the estimation accuracy was improved by about 40% compared with that before optimization, but the method caused an excessive computation as a large number of particles were adopted.
As the research listed above, some algorithms have complex update processes and an excessive number of particles, which lead to poor practicality and degradation of SOC estimation accuracy. This paper proposes an improved particle swarm-optimized particle filter (IPSO-PF). It uses a particle swarm algorithm to effectively overcome the problem of decreasing particle diversity in the PF algorithm. The overall framework of the article is rough as follows.
Section 2 will establish a second-order RC equivalent circuit model. The proposed IPSO-PF algorithm will be introduced in
Section 3.
Section 4 will use the particle swarm algorithm to identify the parameters offline and compare the SOC estimation results with the EKF, PF, PSO-PF, and IPSO-PF algorithms. Then the estimation accuracy of the proposed algorithm is verified by experiments. Specifically, the contributions are presented as follows.
- (1)
The PSO algorithm is used to identify the parameters of the second-order RC model to obtain a battery model with high accuracy.
- (2)
This paper designs self-mutation and mutual learning of particles to drive particles to high-likelihood regions, which effectively suppresses the degradation of particle weights without increasing the number of particles and increasing particle diversity.
- (3)
Compared with the PF algorithm, the IPSO-PF algorithm has better particle diversity and much higher estimation accuracy in any SOC stage under different driving conditions.
3. SOC Estimation Based on IPSO-PF Algorithm
The core idea of the IPSO-PF algorithm is to iteratively optimize the prior state sets of particle filtering by using an improved particle swarm optimization algorithm and then update and resample it with the latest observations to obtain more accurate posterior state sets, thus realizing an improvement of the particle filtering algorithm. This section introduces the basic principles of the PF algorithm and the IPSO algorithms, respectively, and applies the IPSO-PF algorithm to the SOC estimation.
3.1. PF Algorithm
Particle filtering is a recursive Bayesian filter based on Monte Carlo sampling, and the core idea is to achieve integrated operations with weighted sums by using discrete random samples. Assume that the state space model of the nonlinear system is represented as follows:
where
is the input,
is the output. The PF algorithm uses the system model prediction to obtain the prior probability density, then get the posterior probability density by correcting the prior probability density through the latest observations, and finally achieve the state estimation. The specific steps of the PF algorithm are shown as follows:
Step 1. k = 0, initialize the particle sets: , .
Step 2. k = 1, 2, …, T, execute the following steps:
3.2. IPSO Algorithm
The likelihood function used by the PF algorithm is a normal distribution type, which is prone to excessive differences between particles, then causes degradation of particles, and finally leads to the reduction of the estimation accuracy. For the defects of the PF, this paper uses an improved particle swarm algorithm [
31] to optimize the sampling process before the particle filtering update period. Traditional particle swarm algorithm is prone to fall into local optimal solutions in the iterative search process, so this paper makes the following improvements: the particle population is divided into three parts, and different update strategies are used to realize the self-mutation and mutual learning of particles so that the algorithm can jump out of the local optimum, accelerate convergence and improve the estimation accuracy. The size of the fitness value reflects the distance of the particle from the real state. The fitness values of the particle population are sorted from small to large and then divided into three parts according to the mean value
and the standard deviation
, as shown in
Figure 4.
The mean value
and the standard deviation
are defined as follows:
Particles with a smaller portion of the fitness values (population S) are far from the true state and need to accelerate closer to the global optimal state. The updated rule is as follows:
where
is the learning factor,
is the particle at the average fitness position. The right side of Equation (21) consists of three parts: the first item indicates the ability of the particle to maintain its position, the second item indicates that the particle learns from particles close to the true state, the third item indicates that the particle is pulled by the particles located in the intermediate states and can avoid particle degradation.
Particles with a middle portion of the fitness values (population M) are in the intermediate state that plays a role in balancing global search and local development, therefore adopting the standard update rule, namely the Equation (11). The nonlinear differential decreasing strategy is used to update the inertia weights. In the early stage of the iteration, the inertia weight is large, and the particle can perform a large range of global searches. In the late stage of the iteration, the inertia weight is small, and the particle has a strong local development ability.
Particles with a large portion of the fitness values (population L) are close to the true state, therefore using self-variation updates to avoid falling into local optimum:
where
indicates the adaptive factor,
indicates the Cauchy random number. Equation (22) is the adaptive Cauchy formula which controls the particles to carry out the global search in the early stage of the iteration and accelerates the convergence in the late stage of the iteration.
3.3. SOC Estimation
The IPSO-PF algorithm can be obtained by introducing the IPSO algorithm into the sampling process of the PF algorithm. The IPSO algorithm takes the set of prior particles computed by the PF algorithm as the elementary particles, yielding sets closer to the truly distributed states through the self-variation of the particles themselves and the mutual learning between the populations. Then the PF algorithm updates this set to obtain the posterior set. The specific steps of the IPSO-PF algorithm are shown as follows.
Step 1. k = 0, initialize the particle sets: , .
Step 2. k = 1, 2, …, T, execute the following steps:
Then, the SOC estimation is performed using the proposed IPSO-PF algorithm. The flowchart of SOC estimation is shown in
Figure 5. Firstly, the battery model parameters are obtained by the particle swarm algorithm offline. Secondly, the prior state sets of the current moment are generated by sampling the estimation state of the previous moment through the system model. Thirdly, the prior state sets are divided into three subsets according to fitness, and different strategies are used to realize the update of the sets. Then, the weights of the optimized particle state sets are normalized, and the posterior state sets of the current moment are obtained after resampling. Finally, the state can be estimated.
4. Experimental Results and Analysis
In this paper, a LiNiMnCo/Graphite lithium-ion battery is selected as the research object, and its basic information is shown in
Table 1. The experimental temperature is set to 25 °C, and the sampling period is set to 1s. The number of particles of the PF algorithm and PSO algorithm are both set to 100, the number of iterations of the PSO and IPSO-PF algorithm is set to 200, the maximum and minimum inertia weights are set to 0.9 and 0.4, respectively, and the learning factors
,
and
are set as 2.
In order to validate the accuracy of the model and the SOC estimation. The Dynamic Street Test (DST), the Federal Urban Driving Schedule (FUDS), the Intense Driving Schedule (US06 Supplemental FTP Driving Schedule, US06), and the Beijing Dynamic Stress Test (BJDST) from the University of Maryland battery data [
32] are selected for the experiment. All tests were performed for 80% battery level and 50% battery level at 0 °C, 25 °C and 45 °C. We chose the data that the battery tests were performed for 80% initial SOC at 25 °C as they are the most commonly used data. Firstly, the battery is discharged to 80% SOC, then the battery is discharged according to the four working conditions, and the current and voltage are recorded. The current curves are obtained as shown in
Figure 6,
Figure 7,
Figure 8 and
Figure 9. It can be seen that the current fluctuation frequency of the four conditions is high, and the charge/discharge ratio is large, which is relatively close to the actual usage.
4.1. Model Verification
The root mean square error of terminal voltage is used as an index to evaluate the accuracy of the model, and the parameters of the charging process and the discharging process are identified respectively, then the average values are taken as the model parameters. The fitness curve and parameter identification results are shown in
Figure 10 and
Table 2, respectively. It can be seen from
Figure 10 that the fitness converges to 0.83% after only 50 iterations, which shows the fast convergence speed of the particle swarm algorithm. Meanwhile, we also compare the computation costs and accuracy of the first-order, second-order, and third-order RC models. The results are shown in
Table 3. It can be seen from the RMSE of
Table 3 that the third order has little improvement in accuracy compared to the second order, while the first order has poor accuracy compared to the second order. Since the parameters are identified offline and the time difference is not significant, the computation time can be neglected. Therefore, it can be considered that the second-order RC model is the optimal choice. In addition, the model parameter identification results are consistent with our theoretical expectations, and we need to verify further whether it is in line with the practical application under different driving conditions.
In order to verify the accuracy of the second-order RC model, the four driving condition data are selected for verification. Since electric vehicles that drive under extreme loads during actual driving are relatively rare, the battery data from 80% to 10% SOC are selected for experiments in this paper. The battery is discharged according to the current shown in
Figure 6 and
Figure 7, and the terminal voltage and SOC of the battery are recorded. The above currents are used to simulate the model, and the terminal voltage of the battery model is obtained. The error curves of the model terminal voltage are shown in
Figure 11,
Figure 12,
Figure 13 and
Figure 14. As can be seen, the errors of the voltage of the battery model are controlled within 20 mV overall, and the fluctuation range is small. The maximum errors are only 34.4 mV, 29.9 mV, 35.7 mV, and 21.6 mV, respectively, which shows that the second-order RC equivalent circuit model built in this paper has high accuracy and can well reflect the dynamic working characteristics of the battery.
4.2. SOC Estimation Verification
In order to verify the superiority of the algorithm proposed in this paper, the algorithm is verified using the DST driving condition, and the experimental results are shown in
Figure 15,
Figure 16 and
Figure 17. As can be seen from
Figure 15 and
Figure 16, the difference in particle weights of the PF algorithm is big, and the number of particles with large weights is gradually reduced while the particles with small weights are gradually degraded. Therefore, the sets of particles will gradually deviate from the true state and eventually leads to a decrease in the estimation accuracy. In contrast, the particle weights of the IPSO-PF algorithm have smaller differences and are more uniformly distributed, which can effectively guarantee the diversity of particles and prevent particle degradation, thus improving the estimation accuracy. It can be further illustrated by
Figure 17 that the SOC estimation results of the IPSO-PF algorithm are closer to the true value. The EKF algorithm has the worst performance, and it gradually diverges at the end of the estimation phase, resulting in a maximum error approaching 2%. The estimation error of the PF algorithm dissipates with the increase of time, and the maximum error of the PSO-PF algorithm is too large due to the population falling into the local optimal solution, while the IPSO-PF algorithm controls the error within a certain range.
To intuitively compare the estimation performance of the different algorithms under DST driving conditions, three evaluation indexes of Root Mean Squared Error (RMSE), Mean Absolute Error (MAE), and Max Error (ME) are given in this paper, and the results are shown in
Table 4. It can be further seen from the error results that the errors of EKF are larger than that of PF because it is not suitable for non-Gaussian noise environments. The RMSE of IPSO-PF decreases by 0.7% compared with EKF and decreases by 0.41% compared with PF, and the error is controlled within 1%, while the other three algorithms are more than 1%, which proves that the proposed algorithm has good estimation accuracy.
Theoretically, the computational complexity of the IPSO-PF algorithm increases compared to the PF algorithm due to the inclusion of the PSO algorithm, but it is not much different from that of the PSO-PF algorithm. We ran all the algorithms on the MATLAB 2016b platform of an AMD I7-6500U processor with 3.20 GHz and 16 GB memory and calculated the computational complexity. The EKF, PF, PSO-PF, and IPSO-PF algorithms take 0.89 s, 6.32 s, 8.16 s, and 8.73 s, respectively. Although the EKF algorithm has the lowest complexity, it has poor estimation accuracy in non-Gaussian scenarios. The complexity of the proposed algorithm is almost the same as that of the PSO-PF algorithm and slightly inferior to the PF algorithm, but with a significant improvement in accuracy. Therefore, it further demonstrates the superiority of the IPSO-PF algorithm.
In order to verify the generalizability of the proposed algorithm under different driving conditions, the FUDS, US06, and BJDST data are used for SOC estimation, and then compare the estimation results with the PF and PSO-PF algorithm. The experimental results and errors are shown in
Figure 18. As is shown in
Figure 18a,c,e, the PF algorithm, the PSO-PF algorithm, and the IPSO-PF algorithm can effectively estimate the SOC, and the estimation results of the IPSO-PF algorithm are closer to the true value. It can be seen from
Figure 18b,d,f that the estimation errors of the IPSO-PF algorithm are significantly lower and fluctuate less under different driving conditions compared with the EKF, PF, and PSO-PF algorithms. The three error evaluation indexes are shown in
Table 5,
Table 6 and
Table 7. According to the results, the ME of the IPSO-PF algorithm is limited to 0.9%, and the MAE is limited to 0.28%, which is less than the ME and MAE of the PF algorithm and the PSO-PF algorithm. The experimental results show that the proposed algorithm effectively solves the problem of estimation error increase due to particle degradation and has good estimation performance. The RMSEs of the IPSO-PF algorithm in FUDS, US06, and BJDST conditions are 0.25%, 0.34%, and 0.33%, respectively, which are at least 55% lower than those of the EKF algorithm, 45% lower than those of the PF algorithm and 22% lower than those of the PSO-PF algorithm, effectively improving the estimation accuracy of the SOC, indicating that the IPSO-PF algorithm has good generalizability and superiority.
The experimental results show that the PF algorithm has an inaccurate posterior estimation accuracy due to particle weight degradation. In contrast, the IPSO-PF algorithm improves the estimation accuracy and shows good generalization by driving all particles closer to the true state.
5. Conclusions
Considering the problem that the PF algorithm adopts the normal distribution type likelihood function in the updating stage, which leads to particle degradation caused by the large difference of weights between particles, this paper proposes an IPSO-PF algorithm. The algorithm introduces the particle swarm optimization algorithm into the sampling process before the update of the PF algorithm, and through the self-variation and mutual learning of the particles, the particles with smaller weights tend to the true state by learning, which suppresses the weight degradation. The particles with larger weights avoid falling into the local optimum by self-variation, which promotes global development. Finally, it makes all particles closer to the true state distribution and improves the estimation performance of the PF algorithm.
The experimental results show that the algorithm proposed in this paper has good estimation accuracy under four actual driving conditions, with the root mean square error within 0.4% and the maximum error within 0.9%, and all of them are smaller than the PF algorithm, and PSO-PF algorithm, which fully verifies the superiority and generalization of the algorithm proposed in this paper.
This paper does not consider the convergence speed of a wrong initial SOC, and the experiments are performed at 25 °C. Therefore, we will make improvements to the convergence of the algorithm and increase the experiments under different temperature conditions to increase the reliability of the algorithm in the future.