pyprobe.analysis.base.degradation_mode_analysis_functions module#

A module containing functions for degradation mode analysis.

ocv_curve_fit(SOC, fitting_target_data, x_pe, ocp_pe, x_ne, ocp_ne, fitting_target, optimizer, x_guess)#

Fit half cell open circuit potential curves to full cell OCV data.

Parameters:
  • SOC (NDArray[np.float64]) – The full cell SOC.

  • fitting_target_data (NDArray[np.float64]) – The full cell OCV data.

  • x_pe (NDArray[np.float64]) – The cathode stoichiometry data.

  • ocp_pe (NDArray[np.float64]) – The cathode OCP data.

  • x_ne (NDArray[np.float64]) – The anode stoichiometry data.

  • ocp_ne (NDArray[np.float64]) – The anode OCP data.

  • fitting_target (str) – The target for the curve fitting.

  • optimizer (str) – The optimization algorithm to use.

  • x_guess (NDArray[np.float64]) – The initial guess for the fitting parameters.

Returns:

The optimized fitting parameters.

Return type:

NDArray

calc_electrode_capacities(x_pe_lo, x_pe_hi, x_ne_lo, x_ne_hi, cell_capacity)#

Calculate the electrode capacities.

Parameters:
  • x_pe_lo (float) – The cathode stoichiometry at lowest cell SOC.

  • x_pe_hi (float) – The cathode stoichiometry at highest cell SOC.

  • x_ne_lo (float) – The anode stoichiometry at lowest cell SOC.

  • x_ne_hi (float) – The anode stoichiometry at highest cell SOC.

  • cell_capacity (float) – The cell capacity.

Returns:

  • NDArray: The cathode capacity.

  • NDArray: The anode capacity.

  • NDArray: The lithium inventory.

Return type:

Tuple[float, float, float]

calc_full_cell_OCV(SOC, x_pe_lo, x_pe_hi, x_ne_lo, x_ne_hi, x_pe, ocp_pe, x_ne, ocp_ne)#

Calculate the full cell OCV.

Parameters:
  • SOC (NDArray[np.float64]) – The full cell SOC.

  • x_pe_lo (float) – The cathode stoichiometry at lowest cell SOC.

  • x_pe_hi (float) – The cathode stoichiometry at highest cell SOC.

  • x_ne_lo (float) – The cathode stoichiometry at lowest cell SOC.

  • x_ne_hi (float) – The anode stoichiometry at highest cell SOC.

  • x_pe (NDArray[np.float64]) – The cathode stoichiometry data.

  • ocp_pe (NDArray[np.float64]) – The cathode OCP data.

  • x_ne (NDArray[np.float64]) – The anode stoichiometry data.

  • ocp_ne (NDArray[np.float64]) – The anode OCP data.

Returns:

The full cell OCV.

Return type:

NDArray

calc_full_cell_OCV_composite(SOC, z_pe_lo, z_pe_hi, z_ne_lo, z_ne_hi, x_pe, ocp_pe, x_c1, ocp_c1, x_c2, ocp_c2, comp1_frac)#

Calculate the full cell OCV.

Parameters:
  • SOC (NDArray[np.float64]) – The full cell SOC.

  • z_pe_lo (float) – The cathode stoichiometry at the lowest cell SOC.

  • z_pe_hi (float) – The cathode stoichiometry at the highest cell SOC.

  • z_ne_lo (float) – The anode stoichiometry at the lowest cell SOC.

  • z_ne_hi (float) – The anode stoichiometry at the highest cell SOC.

  • x_pe (NDArray[np.float64]) – The cathode stoichiometry data.

  • ocp_pe (NDArray[np.float64]) – The cathode OCP data.

  • x_c1 (NDArray[np.float64]) – The anode component 1 stoichiometry data.

  • ocp_c1 (NDArray[np.float64]) – The anode component 1 OCP data.

  • x_c2 (NDArray[np.float64]) – The anode component 2 stoichiometry data.

  • ocp_c2 (NDArray[np.float64]) – The anode component 2 OCP data.

  • comp1_frac (float) – The fraction of the first anode component.

Returns:

The full cell OCV.

Return type:

NDArray[np.float64]

calculate_dma_parameters(cell_capacity, pe_capacity, ne_capacity, li_inventory)#

Calculate the DMA parameters.

Parameters:
  • cell_capacity (ndarray[tuple[int, ...], dtype[float64]]) – The cell capacity.

  • pe_capacity (ndarray[tuple[int, ...], dtype[float64]]) – The cathode capacity.

  • ne_capacity (ndarray[tuple[int, ...], dtype[float64]]) – The anode capacity.

  • li_inventory (ndarray[tuple[int, ...], dtype[float64]]) – The lithium inventory.

Returns:

The SOH, LAM_pe, LAM_ne, and LLI.

Return type:

Tuple[float, float, float, float]

average_OCV_curves(charge_SOC, charge_OCV, charge_current, discharge_SOC, discharge_OCV, discharge_current)#

Average the charge and discharge OCV curves.

Parameters:
  • charge_SOC (ndarray[tuple[int, ...], dtype[float64]]) – The charge SOC.

  • charge_OCV (ndarray[tuple[int, ...], dtype[float64]]) – The charge OCV.

  • charge_current (ndarray[tuple[int, ...], dtype[float64]]) – The charge current.

  • discharge_SOC (ndarray[tuple[int, ...], dtype[float64]]) – The discharge SOC.

  • discharge_OCV (ndarray[tuple[int, ...], dtype[float64]]) – The discharge OCV.

  • discharge_current (ndarray[tuple[int, ...], dtype[float64]]) – The discharge current.

Returns:

An average between the charge and discharge OCV curves.

Return type:

Tuple[NDArray[np.float64], NDArray[np.float64]]