Source code for pybamm.models.submodels.electrolyte_conductivity.integrated_conductivity

#
# Composite electrolyte potential employing integrated Stefan-Maxwell
#
import pybamm

from .base_electrolyte_conductivity import BaseElectrolyteConductivity


[docs] class Integrated(BaseElectrolyteConductivity): """ Integrated model for conservation of charge in the electrolyte derived from integrating the Stefan-Maxwell constitutive equations, from :footcite:t:`BrosaPlanella2021`. Parameters ---------- param : parameter class The parameters to use for this submodel domain : str, optional The domain in which the model holds options : dict, optional A dictionary of options to be passed to the model. """ def __init__(self, param, domain=None, options=None): super().__init__(param, domain, options=options) pybamm.citations.register("BrosaPlanella2021") def _higher_order_macinnes_function(self, x): tol = pybamm.settings.tolerances["macinnes__c_e"] x = pybamm.maximum(x, tol) return pybamm.log(x)
[docs] def get_coupled_variables(self, variables): c_e_av = variables["X-averaged electrolyte concentration [mol.m-3]"] i_boundary_cc = variables["Current collector current density [A.m-2]"] c_e_n = variables["Negative electrolyte concentration [mol.m-3]"] c_e_s = variables["Separator electrolyte concentration [mol.m-3]"] c_e_p = variables["Positive electrolyte concentration [mol.m-3]"] c_e_n0 = pybamm.boundary_value(c_e_n, "left") delta_phi_n_av = variables[ "X-averaged negative electrode surface potential difference [V]" ] phi_s_n_av = variables["X-averaged negative electrode potential [V]"] tor_n = variables["Negative electrolyte transport efficiency"] tor_s = variables["Separator electrolyte transport efficiency"] tor_p = variables["Positive electrolyte transport efficiency"] T_av = variables["X-averaged cell temperature [K]"] T_av_n = pybamm.PrimaryBroadcast(T_av, "negative electrode") T_av_s = pybamm.PrimaryBroadcast(T_av, "separator") T_av_p = pybamm.PrimaryBroadcast(T_av, "positive electrode") RT_F_av = self.param.R * T_av / self.param.F RT_F_av_n = self.param.R * T_av_n / self.param.F RT_F_av_s = self.param.R * T_av_s / self.param.F RT_F_av_p = self.param.R * T_av_p / self.param.F L_n = self.param.n.L L_p = self.param.p.L L_x = self.param.L_x x_n = pybamm.standard_spatial_vars.x_n x_s = pybamm.standard_spatial_vars.x_s x_p = pybamm.standard_spatial_vars.x_p x_n_edge = pybamm.standard_spatial_vars.x_n_edge x_p_edge = pybamm.standard_spatial_vars.x_p_edge chi_av = self.param.chi(c_e_av, T_av) chi_av_n = pybamm.PrimaryBroadcast(chi_av, "negative electrode") chi_av_s = pybamm.PrimaryBroadcast(chi_av, "separator") chi_av_p = pybamm.PrimaryBroadcast(chi_av, "positive electrode") # electrolyte current i_e_n = i_boundary_cc * x_n / L_n i_e_s = pybamm.PrimaryBroadcast(i_boundary_cc, "separator") i_e_p = i_boundary_cc * (L_x - x_p) / L_p i_e = pybamm.concatenation(i_e_n, i_e_s, i_e_p) i_e_n_edge = i_boundary_cc * x_n_edge / L_n i_e_s_edge = pybamm.PrimaryBroadcastToEdges(i_boundary_cc, "separator") i_e_p_edge = i_boundary_cc * (L_x - x_p_edge) / L_p # electrolyte potential indef_integral_n = pybamm.IndefiniteIntegral( i_e_n_edge / (self.param.kappa_e(c_e_n, T_av_n) * tor_n), x_n ) indef_integral_s = pybamm.IndefiniteIntegral( i_e_s_edge / (self.param.kappa_e(c_e_s, T_av_s) * tor_s), x_s ) indef_integral_p = pybamm.IndefiniteIntegral( i_e_p_edge / (self.param.kappa_e(c_e_p, T_av_p) * tor_p), x_p ) integral_n = indef_integral_n integral_s = indef_integral_s + pybamm.boundary_value(integral_n, "right") integral_p = indef_integral_p + pybamm.boundary_value(integral_s, "right") phi_e_const = ( -delta_phi_n_av + phi_s_n_av - ( chi_av * RT_F_av * pybamm.x_average(self._higher_order_macinnes_function(c_e_n / c_e_n0)) ) + pybamm.x_average(integral_n) ) phi_e_n = ( phi_e_const + ( chi_av_n * RT_F_av_n * self._higher_order_macinnes_function(c_e_n / c_e_n0) ) - integral_n ) phi_e_s = ( phi_e_const + ( chi_av_s * RT_F_av_s * self._higher_order_macinnes_function(c_e_s / c_e_n0) ) - integral_s ) phi_e_p = ( phi_e_const + ( chi_av_p * RT_F_av_p * self._higher_order_macinnes_function(c_e_p / c_e_n0) ) - integral_p ) # concentration overpotential eta_c_av = ( chi_av * RT_F_av * ( pybamm.x_average(self._higher_order_macinnes_function(c_e_p / c_e_av)) - pybamm.x_average(self._higher_order_macinnes_function(c_e_n / c_e_av)) ) ) # average electrolyte ohmic losses delta_phi_e_av = -(pybamm.x_average(integral_p) - pybamm.x_average(integral_n)) phi_e_dict = { "negative electrode": phi_e_n, "separator": phi_e_s, "positive electrode": phi_e_p, } variables.update(self._get_standard_potential_variables(phi_e_dict)) variables.update(self._get_standard_current_variables(i_e)) variables.update(self._get_split_overpotential(eta_c_av, delta_phi_e_av)) return variables