Skip to content

MATLAB® Equivalent-Electric-Circuit (EEC) model class

License

Notifications You must be signed in to change notification settings

mhorsche/matlab-eec

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

EQUIVALENT-ELECTRIC-CIRCUIT (EEC) model class for MATLAB®

eec is a MATLAB® class to easily define and model equivalent-electric-circuits, mainly for the purpose to model the electric behaviour of batteries.

Installation

  1. Extract the ZIP file (or clone the git repository) somewhere you can easily reach it.
  2. Add the src/ folder to your path in MATLAB/Octave: e.g.
    • using the "Set Path" dialog in MATLAB, or
    • by running the addpath function from your command window or startup script.

Usage

The basic usage is to define an eec model with an individual set of OCV, R, L, C, RC and RL elements. Exemplarily the command eec('OCV+R') generates a simple model containing a constant open-circuit-voltage in series with a resistor.

After defining a model, an AC or DC analysis can be performed. Therefor a time and current or frequency input vector is necessary. To fit the model parameter to a given reference also the voltage response or the complex impedance is required.

Most functionality is described in the given example:

  1. Generate a new model containing OCV + R L and three RC elements:

    eec_one = eec('OCV,R,L,RC,RC,RC',...
    ...%                                        RC1             RC2             RC3
    ...%               OCV     R       L        R    tau  init  R     tau init  R    tau init
      'InitialValues',[3.6500  0.0300  500e-9   5e-3 1e-3 0     10e-3 0.1 0     0.02 10  0 ]);
  2. Run a simple DC analysis for a constant current pulse of I = -2 A (discharge) and t = 10 sec:

    res = eec_one.dc(linspace(0,10,101),-2);
    eec.plotResponse(res);
  3. Generate a second model containing the same elements but different initial values:

    eec_two = eec('OCV,R,L,RC,RC,RC',...
      'InitialValues',[3.5000  0.0200  300e-9   4.0e-3 500e-6 0 15e-3 300e-3 0  25e-3 15 0 ]);
  4. Run fitting algorithm in time domain to match the reference values, also show results and manual fitting frontend:

    eec_two.dcfit(res.t_s,res.I_A,res.t_s,res.Umodel_V,...
      'Method','analytical',...
    ...%               OCV     R       L        RC1             RC2             RC3
      'LowerBoundary',[2.500   0       0        0     0     0   0     0     0   0     0     NaN ],...
      'UpperBoundary',[4.200   Inf     Inf      10e-3 1.0   0   0.05  10    0   0.1   100   NaN ]);
    eec_two.timeseries(res.t_s,res.I_A,res.t_s,res.Umodel_V);

Time domain

  1. Run a simple AC analysis for a frequency range of f = 0.01 Hz ... 10 kHz:

    res = eec_one.ac(logspace(-2,4,101),"doPlot",true);
  2. Generate a third model containing the same elements but the fitted values from the DC model:

    eec_three = eec('OCV,R,L,RC,RC,RC',...
      'InitialValues',[eec_two.Elements.value]);
  3. Run fitting algorithm in frequency domain to match the reference values, also show results and manual fitting frontend:

    eec_three.acfit(res.f_Hz,res.ZRe_Ohm,res.ZIm_Ohm,...
      'Method','analytical',...
    ...%               OCV     R       L        RC1             RC2             RC3
      'LowerBoundary',[NaN     0       0        0     0     0   0     0     0   0     0    NaN ],...
      'UpperBoundary',[NaN     Inf     Inf      10e-3 1.0   0   0.05  10    0   0.1   100  NaN ]);
    eec_three.nyquist(res.f_Hz,res.ZRe_Ohm,res.ZIm_Ohm);

Frequency domain

For further information and another working example open the live script 'eec_example_DE.mlx'.

Remarks

Most functions accept numerous name-value arguments, inspect the help:

doc eec

To run the DC analysis in spice mode you need to specify the path to the LTspice® executable. To read the results back into MATLAB, the plugin LTspice2Matlab is used.

More information

If you experience bugs or would like to request a feature, please visit the issue tracker.

About

MATLAB® Equivalent-Electric-Circuit (EEC) model class

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages