I don' know why simulink parameter estimation failed. Please help me

77 views (last 30 days)
I want to know battery’s internal parameter (internal resistance, diffusion reisister, tau) when i modelling a battery to ECM using a simscape battey.
For parameter estimation, I use hppc profile for input
i make a new experience in parameter estimation app and choose parameter i want to know. Then Run estimating
Simulated Output cannot follow the experienced output.. Cost is also too high.
For Result parameter is not converged..
what’s wrong.. is it important parameter’s initial value, min, max?
Is Input signal too complicated to estimate parameters?
Please give me some tips. Expert of simulink members..
[Below, Text in report translated in English ]
' Optimization started on 2024-Nov-11, 10:50:02.
Estimation converged on 2024-Nov-11, 11:24:53.
One error occurred in the solver during estimation. For more details on the error, check 'EvalErrors_2' in the results workspace.
'ingyu' has been updated with the estimated parameter values.
The estimated parameter values are recorded in 'EstimatedParams'.
The estimated experiment values are recorded in 'Exp'.
Solver output for estimation:
A local minimum may exist.
lsqnonlin stopped because the final change in the sum of squares relative to the initial value was smaller than the function tolerance.
<Details of the stopping criterion>
Optimization stopped because the relative change in the sum of squares (r) was smaller than options.FunctionTolerance = 1.000000e-03.'
  3 Comments
인규
인규 on 11 Nov 2024
.
EvalErrors_2 is same as EvalErrors.
when i used fast reload option, Error occured.
not using fast option error didn't occured and parameter estimation was completed. But it was not correct.
Walter Roberson
Walter Roberson on 11 Nov 2024
Sorry, I am unable to change how Simulink FastRestart works so that it will permit changing those parameters. You could file an enhancement request to permit parameters to be changed for FastRestart.

Sign in to comment.

Accepted Answer

Yifeng Tang
Yifeng Tang on 20 Nov 2024 at 14:25
Looks like the error message is trying to tell you that the Parameter Estimater cannot change the parameters it tries to estimate. This is because the "compile-time" parameters in Simscape (to be explained later) can't be modified from simulation to simulation when the Fast Restart is turned on. The solution is simple:
(1) NOT recommended: turn off fast restart. This will allow the parameters to be modified, but also add compile time to the start of each simulation.
(2) Do this instead: for the parameters you try to estimate, at every place it's used, make them "run-time". This way, Simscape will keep a placeholder for them and allow the values to be modified from run to run in Fast Restart mode.
See these two documentation pages for more details:
The 2nd page talks about runing run-time parameters with fast restart. It's a common practice when doing parameter estimation.
  6 Comments
인규
인규 on 26 Nov 2024 at 23:54
Hello Yifeng
I will attach the ingyu.slx, For_question.mat file.
There is a battery charge/discharge model and input, output data and battery parameters(R0, R1, tau1, OCV - V0).
I attached the TS_input_Current data, which is about 1/6.5 the size of the actual experimental data.
If the actual experimental data is used for simulation, it typically takes about 3 minutes on average.
So, when conducting parameter estimation using the Parameter Estimator, it seemed to take about two days with the actual data.
Additionally, I configured the solver settings, setting the maximum step size to max(diff(out.tout)).
For the additional output settings, I included AddtOutTimes. The value of AddtOutTimes is TS_input_Current.Time.
Yifeng Tang
Yifeng Tang on 27 Nov 2024 at 4:17
A few things that seem to help with the simulation speed.
1. resample the input data to a lower frequency. The original 0.1 sample time appears unneccessarily small. The current data contains lots of noise as a result. I tried:
load For_question.mat
ts = 1; % sample time
TS_input_ResampleCurrent = resample(TS_input_Current,[1:ts:TS_input_Current.Time(end)]);
figure(101); clf
plot(TS_input_Current)
hold on
plot(TS_input_ResampleCurrent)
and the resulting downsampled input signal appears very close to the original. You may then also allow the max time step to be larger.
2. The additional output really slows things down. Is that necessary for the parameter estimation purpose? I removed it (so using the default "Refine output" with factor 1), and the simulation finishes within a few seconds.
You may use your understanding of the system to decide whether downsampling is acceptable (are the parameters you are estimating related to the fast dynamics and noise at 0.1 sec rate?).
Also consider down sample the reference data for the parameter estimator so it won't try to gather that much data from simulation for comparison.
Doing these will at least get you very close to the optimal values of the parameters you are trying to estimate. If you have to, you can then use the full data set, but start with a much better guess and range. This will require much less iterations to get another estimate.

Sign in to comment.

More Answers (0)

Categories

Find more on Propulsion and Power Systems in Help Center and File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!