{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e419c6c3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-05 14:51:35.959 - [INFO] base_model._build_model(907): Start building Doyle-Fuller-Newman model\n",
      "2025-09-05 14:51:36.069 - [INFO] base_battery_model.build_model(1083): Finish building Doyle-Fuller-Newman model\n",
      "2025-09-05 14:51:36.090 - [INFO] parameter_values.process_model(475): Start setting parameters for Doyle-Fuller-Newman model\n",
      "2025-09-05 14:51:36.235 - [INFO] parameter_values.process_model(544): Finish setting parameters for Doyle-Fuller-Newman model\n",
      "2025-09-05 14:51:36.238 - [INFO] discretisation.process_model(142): Start discretising Doyle-Fuller-Newman model\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experimen(0.9220754795837338)\n",
      "Experimen(maximum(minimum(2.0896894721444392e-05 * boundary value(Positive particle concentration [mol.m-3]), 0.9999999999), 1e-10))\n",
      "Experimen(maximum(minimum(3.0456262856849433e-05 * x-average(0.6861280000000001 * r-average(Positive particle concentration [mol.m-3])), 0.9999999999), 1e-10))\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-05 14:51:36.876 - [INFO] discretisation.process_model(250): Finish discretising Doyle-Fuller-Newman model\n",
      "2025-09-05 14:51:36.877 - [INFO] base_solver.solve(699): Start solving Doyle-Fuller-Newman model with IDA KLU solver\n",
      "2025-09-05 14:51:37.006 - [INFO] base_solver.set_up(147): Start solver set-up\n",
      "2025-09-05 14:51:37.263 - [INFO] casadi_algebraic_solver.set_up_root_solver(87): Start building CasADi algebraic solver\n",
      "2025-09-05 14:51:37.274 - [INFO] casadi_algebraic_solver.set_up_root_solver(150): Finish building CasADi algebraic solver\n",
      "2025-09-05 14:51:37.276 - [INFO] base_solver.set_up(283): Finish solver set-up\n",
      "2025-09-05 14:51:37.665 - [INFO] base_solver.solve(924): Finish solving Doyle-Fuller-Newman model (event: Minimum voltage [V])\n",
      "2025-09-05 14:51:37.672 - [INFO] base_solver.solve(925): Set-up time: 402.841 ms, Solve time: 240.981 ms (of which integration time: 240.189 ms), Total time: 643.822 ms\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.00000000e+00 5.85937500e-03 1.17187500e-02 2.34375000e-02\n",
      " 4.68750000e-02 7.03125000e-02 9.37500000e-02 1.40625000e-01\n",
      " 1.87500000e-01 2.34375000e-01 2.81250000e-01 3.75000000e-01\n",
      " 5.62500000e-01 9.37500000e-01 1.68750000e+00 3.18750000e+00\n",
      " 6.18750000e+00 1.21875000e+01 1.75875000e+01 2.24475000e+01\n",
      " 2.73075000e+01 3.06122449e+01 3.08706933e+01 3.11291416e+01\n",
      " 3.16460383e+01 3.26798317e+01 3.47474186e+01 3.68150054e+01\n",
      " 4.09501791e+01 4.92205265e+01 5.74908739e+01 6.12244898e+01\n",
      " 6.15598117e+01 6.18951337e+01 6.25657776e+01 6.39070654e+01\n",
      " 6.65896410e+01 7.19547921e+01 7.73199433e+01 8.80502457e+01\n",
      " 9.18367347e+01 9.21527984e+01 9.24688622e+01 9.31009896e+01\n",
      " 9.43652446e+01 9.68937544e+01 1.01950774e+02 1.12064814e+02\n",
      " 1.22178853e+02 1.22448980e+02 1.22736345e+02 1.23023711e+02\n",
      " 1.23598443e+02 1.24747906e+02 1.27046833e+02 1.31644686e+02\n",
      " 1.36242539e+02 1.45438246e+02 1.53061224e+02 1.53310712e+02\n",
      " 1.53560199e+02 1.54059174e+02 1.55057124e+02 1.57053024e+02\n",
      " 1.61044824e+02 1.69028424e+02 1.76213664e+02 1.83398904e+02\n",
      " 1.83673469e+02 1.83894968e+02 1.84116467e+02 1.84559465e+02\n",
      " 1.85445461e+02 1.87217453e+02 1.90761438e+02 1.97849406e+02\n",
      " 2.04937374e+02 2.14285714e+02 2.14478866e+02 2.14672018e+02\n",
      " 2.15058322e+02 2.15830930e+02 2.17376145e+02 2.20466577e+02\n",
      " 2.26647439e+02 2.32828301e+02 2.39009164e+02 2.44897959e+02\n",
      " 2.45066472e+02 2.45234985e+02 2.45572012e+02 2.46246064e+02\n",
      " 2.47594169e+02 2.50290379e+02 2.55682799e+02 2.61075218e+02\n",
      " 2.66467638e+02 2.75510204e+02 2.75659891e+02 2.75809578e+02\n",
      " 2.76108952e+02 2.76707700e+02 2.77905195e+02 2.80300187e+02\n",
      " 2.85090169e+02 2.89880152e+02 2.94670135e+02 3.04250100e+02\n",
      " 3.06122449e+02 3.06258429e+02 3.06394410e+02 3.06666371e+02\n",
      " 3.07210293e+02 3.08298137e+02 3.10473824e+02 3.14825200e+02\n",
      " 3.23527950e+02 3.32230701e+02 3.36734694e+02 3.36862883e+02\n",
      " 3.36991072e+02 3.37247451e+02 3.37760207e+02 3.38785721e+02\n",
      " 3.40836748e+02 3.44938801e+02 3.53142909e+02 3.61347016e+02\n",
      " 3.67346939e+02 3.67472431e+02 3.67597923e+02 3.67848907e+02\n",
      " 3.68350875e+02 3.69354811e+02 3.71362682e+02 3.75378426e+02\n",
      " 3.83409913e+02 3.91441401e+02 3.97959184e+02 3.98083353e+02\n",
      " 3.98207522e+02 3.98455859e+02 3.98952535e+02 3.99945887e+02\n",
      " 4.01932590e+02 4.05905996e+02 4.09879402e+02 4.13852808e+02\n",
      " 4.21799620e+02 4.27304614e+02]\n"
     ]
    }
   ],
   "source": [
    "# -*- coding: utf-8 -*-\n",
    "\"\"\"\n",
    "20240530 liulishuo\n",
    "Large Cell Type 1 simulation in Pybamm to simulate different charge strategy\n",
    "\"\"\"\n",
    "\n",
    "# %% Initial imports and Model Initialisation\n",
    "\n",
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pybamm\n",
    "import timeit\n",
    "import csv\n",
    "from matplotlib import style\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import math\n",
    "from matplotlib import cbook, cm\n",
    "from matplotlib.colors import LightSource\n",
    "\n",
    "style.use(\"ggplot\")\n",
    "os.chdir(pybamm.__path__[0] + \"/..\")\n",
    "pybamm.set_logging_level(\"INFO\")\n",
    "\n",
    "start = timeit.default_timer()\n",
    "\n",
    "# We are developing a model based on the work from Gregory Offer and his group:\n",
    "# Code: https://docs.pybamm.org/en/latest/source/examples/notebooks/models/composite_particle.html\n",
    "# Publication: A composite electrode model for lithium-ion batteries with silicon/graphite negative electrodes\n",
    "# https://www.sciencedirect.com/science/article/pii/S0378775322001604\n",
    "model = pybamm.lithium_ion.DFN(\n",
    "    {\n",
    "        \"particle phases\": (\"2\", \"1\"),\n",
    "        \"open-circuit potential\": ((\"single\", \"current sigmoid\"), \"single\"),\n",
    "    }\n",
    ")\n",
    "param = pybamm.ParameterValues(\"Chen2020_composite\")\n",
    "\n",
    "\n",
    "# %% Parameter Silicon and Graphite Composite Anode: OCP\n",
    "\n",
    "\n",
    "def silicon_ocp_lithiation_Mark2016(sto):\n",
    "    \"\"\"\n",
    "    silicon Open-circuit Potential (OCP) as a a function of the\n",
    "    stochiometry. The fit is taken from the Enertech cell [1], which is only accurate\n",
    "    for 0 < sto < 1.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] Verbrugge M, Baker D, Xiao X. Formulation for the treatment of multiple\n",
    "    electrochemical reactions and associated speciation for the Lithium-Silicon\n",
    "    electrode[J]. Journal of The Electrochemical Society, 2015, 163(2): A262.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    sto: double\n",
    "       Stochiometry of material (li-fraction)\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        OCP [V]\n",
    "    \"\"\"\n",
    "    p1 = -96.63\n",
    "    p2 = 372.6\n",
    "    p3 = -587.6\n",
    "    p4 = 489.9\n",
    "    p5 = -232.8\n",
    "    p6 = 62.99\n",
    "    p7 = -9.286\n",
    "    p8 = 0.8633\n",
    "\n",
    "    U_lithiation = (\n",
    "            p1 * sto ** 7\n",
    "            + p2 * sto ** 6\n",
    "            + p3 * sto ** 5\n",
    "            + p4 * sto ** 4\n",
    "            + p5 * sto ** 3\n",
    "            + p6 * sto ** 2\n",
    "            + p7 * sto\n",
    "            + p8\n",
    "    )\n",
    "    return U_lithiation\n",
    "\n",
    "\n",
    "def silicon_ocp_delithiation_Mark2016(sto):\n",
    "    \"\"\"\n",
    "    silicon Open-circuit Potential (OCP) as a a function of the\n",
    "    stochiometry. The fit is taken from the Enertech cell [1], which is only accurate\n",
    "    for 0 < sto < 1.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] Verbrugge M, Baker D, Xiao X. Formulation for the treatment of multiple\n",
    "    electrochemical reactions and associated speciation for the Lithium-Silicon\n",
    "    electrode[J]. Journal of The Electrochemical Society, 2015, 163(2): A262.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    sto: double\n",
    "       Stochiometry of material (li-fraction)\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        OCP [V]\n",
    "    \"\"\"\n",
    "    p1 = -51.02\n",
    "    p2 = 161.3\n",
    "    p3 = -205.7\n",
    "    p4 = 140.2\n",
    "    p5 = -58.76\n",
    "    p6 = 16.87\n",
    "    p7 = -3.792\n",
    "    p8 = 0.9937\n",
    "\n",
    "    U_delithiation = (\n",
    "            p1 * sto ** 7\n",
    "            + p2 * sto ** 6\n",
    "            + p3 * sto ** 5\n",
    "            + p4 * sto ** 4\n",
    "            + p5 * sto ** 3\n",
    "            + p6 * sto ** 2\n",
    "            + p7 * sto\n",
    "            + p8\n",
    "    )\n",
    "    return U_delithiation\n",
    "\n",
    "\n",
    "def graphite_ocp_Enertech_Ai2020(sto):\n",
    "    name, (x, y) = graphite_ocp_Enertech_Ai2020_data\n",
    "    return pybamm.Interpolant(x, y, sto, name=name, interpolator=\"cubic\")  # <<<<<<<<<<<<<\n",
    "\n",
    "\n",
    "graphite_ocp_Enertech_Ai2020_data = pybamm.parameters.process_1D_data(\n",
    "    \"graphite_ocp_Enertech_Ai2020_adjusted.csv\", path=r\"/home/ma-user/work/PINNs/data\"\n",
    ")\n",
    "\n",
    "\n",
    "def graphite_ocp(sto):\n",
    "    pass\n",
    "\n",
    "\n",
    "def silicon_carbon_ocp_lithitation(sto):\n",
    "    \"\"\"\n",
    "    silicon Open-circuit Potential (OCP) as a a function of the\n",
    "    stochiometry. The fit is taken from experimental.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    sto: double\n",
    "       Stochiometry of material (li-fraction)\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        OCP [V]\n",
    "    \"\"\"\n",
    "\n",
    "    p1 = 78747.39456627514\n",
    "    p2 = -537621.228905129\n",
    "    p3 = 1634380.3904077213\n",
    "    p4 = -2916559.7725989246\n",
    "    p5 = 3390376.761540382\n",
    "    p6 = -2693119.24150923\n",
    "    p7 = 1491286.0420645564\n",
    "    p8 = -576482.2626947801\n",
    "    p9 = 153284.75177487306\n",
    "    p10 = -27116.713745970923\n",
    "    p11 = 3006.4301240581112\n",
    "    p12 = -188.16538378875455\n",
    "    p13 = 5.668259835601206\n",
    "\n",
    "\n",
    "    U_lithiation = (\n",
    "            p1 * sto ** 12\n",
    "            + p2 * sto ** 11\n",
    "            + p3 * sto ** 10\n",
    "            + p4 * sto ** 9\n",
    "            + p5 * sto ** 8\n",
    "            + p6 * sto ** 7\n",
    "            + p7 * sto ** 6\n",
    "            + p8 * sto ** 5\n",
    "            + p9 * sto ** 4\n",
    "            + p10 * sto ** 3\n",
    "            + p11 * sto ** 2\n",
    "            + p12 * sto\n",
    "            + p13\n",
    "    )\n",
    "    return U_lithiation\n",
    "\n",
    "\n",
    "def silicon_ocp_delithiation(sto):\n",
    "    p1 = -13027.777473819893\n",
    "    p2 = 75323.29761456556\n",
    "    p3 = -190547.44154556046\n",
    "    p4 = 277505.57407041476\n",
    "    p5 = -257507.73343408224\n",
    "    p6 = 159001.30631366727\n",
    "    p7 = -66086.3564643768\n",
    "    p8 = 18204.008919307016\n",
    "    p9 = -3164.805663118186\n",
    "    p10 = 317.0180995794683\n",
    "    p11 = -17.734698736453318\n",
    "    p12 = 1.6931767264993183\n",
    "    p13 = 0.0064687110202551554\n",
    "\n",
    "\n",
    "    U_delithiation = (\n",
    "            p1 * sto ** 12\n",
    "            + p2 * sto ** 11\n",
    "            + p3 * sto ** 10\n",
    "            + p4 * sto ** 9\n",
    "            + p5 * sto ** 8\n",
    "            + p6 * sto ** 7\n",
    "            + p7 * sto ** 6\n",
    "            + p8 * sto ** 5\n",
    "            + p9 * sto ** 4\n",
    "            + p10 * sto ** 3\n",
    "            + p11 * sto ** 2\n",
    "            + p12 * sto\n",
    "            + p13\n",
    "    )\n",
    "    return U_delithiation\n",
    "\n",
    "\n",
    "# %% Parameter Silicon and Graphite Composite Anode: Exchange Current Density\n",
    "\n",
    "\n",
    "def silicon_LGM50_electrolyte_exchange_current_density_Chen2020(\n",
    "        c_e, c_s_surf, c_s_max, T\n",
    "):\n",
    "    \"\"\"\n",
    "    Exchange-current density for Butler-Volmer reactions between silicon and LiPF6 in\n",
    "    EC:DMC.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] Chang-Hui Chen, Ferran Brosa Planella, Kieran O’Regan, Dominika Gastol, W.\n",
    "    Dhammika Widanage, and Emma Kendrick. \"Development of Experimental Techniques for\n",
    "    Parameterization of Multi-scale Lithium-ion Battery Models.\" Journal of the\n",
    "    Electrochemical Society 167 (2020): 080534.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    c_e : :class:`pybamm.Symbol`\n",
    "        Electrolyte concentration [mol.m-3]\n",
    "    c_s_surf : :class:`pybamm.Symbol`\n",
    "        Particle concentration [mol.m-3]\n",
    "    c_s_max : :class:`pybamm.Symbol`\n",
    "        Maximum particle concentration [mol.m-3]\n",
    "    T : :class:`pybamm.Symbol`\n",
    "        Temperature [K]\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Exchange-current density [A.m-2]\n",
    "    \"\"\"\n",
    "\n",
    "    m_ref = (\n",
    "            6.48e-7 * 28700 / 278000\n",
    "    )  # (A/m2)(m3/mol)**1.5 - includes ref concentrations\n",
    "    E_r = 35000\n",
    "    arrhenius = np.exp(E_r / pybamm.constants.R * (1 / 298.15 - 1 / T))\n",
    "\n",
    "    return m_ref * arrhenius * c_e ** 0.5 * c_s_surf ** 0.5 * (c_s_max - c_s_surf) ** 0.5\n",
    "\n",
    "\n",
    "def graphite_LGM50_electrolyte_exchange_current_density_Chen2020(\n",
    "        c_e, c_s_surf, c_s_max, T\n",
    "):\n",
    "    \"\"\"\n",
    "    Exchange-current density for Butler-Volmer reactions between graphite and LiPF6 in\n",
    "    EC:DMC.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] Chang-Hui Chen, Ferran Brosa Planella, Kieran O’Regan, Dominika Gastol, W.\n",
    "    Dhammika Widanage, and Emma Kendrick. \"Development of Experimental Techniques for\n",
    "    Parameterization of Multi-scale Lithium-ion Battery Models.\" Journal of the\n",
    "    Electrochemical Society 167 (2020): 080534.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    c_e : :class:`pybamm.Symbol`\n",
    "        Electrolyte concentration [mol.m-3]\n",
    "    c_s_surf : :class:`pybamm.Symbol`\n",
    "        Particle concentration [mol.m-3]\n",
    "    c_s_max : :class:`pybamm.Symbol`\n",
    "        Maximum particle concentration [mol.m-3]\n",
    "    T : :class:`pybamm.Symbol`\n",
    "        Temperature [K]\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Exchange-current density [A.m-2]\n",
    "    \"\"\"\n",
    "    m_ref = 1e-6  # (A/m2)(m3/mol)**1.5 - includes ref concentrations\n",
    "    E_r = 35000\n",
    "    arrhenius = np.exp(E_r / pybamm.constants.R * (1 / 298.15 - 1 / T))\n",
    "\n",
    "    return m_ref * arrhenius * c_e ** 0.5 * c_s_surf ** 0.5 * (c_s_max - c_s_surf) ** 0.5\n",
    "\n",
    "\n",
    "# %% Parameter Silicon and Graphite Composite Anode: Diffusivity\n",
    "\n",
    "\n",
    "def silicon_diffusivity_experiment(sto, T):\n",
    "    \"\"\"\n",
    "    Silicon diffusivity as a function of stochiometry, in this case the\n",
    "    diffusivity is from \"YWL-1负极 GITT_005_2\".\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    ..\n",
    "        \"YWL-1负极 GITT_005_2\"\n",
    "\n",
    "    ----------\n",
    "    sto: :class:`pybamm.Symbol`\n",
    "        Electrode stochiometry\n",
    "    T: :class:`pybamm.Symbol`\n",
    "        Dimensional temperature\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Solid diffusivity\n",
    "    \"\"\"\n",
    "    p1 = 1726.2909299922517\n",
    "    p2 = -8149.799090338498\n",
    "    p3 = 15561.779568937589\n",
    "    p4 = -15425.03786569191\n",
    "    p5 = 8472.724288643949\n",
    "    p6 = -2552.4646043261605\n",
    "    p7 = 394.4931806600925\n",
    "    p8 = -29.536582374606834\n",
    "    p9 = 2.3762992502388625\n",
    "\n",
    "    U_change = (\n",
    "            p1 * sto ** 8\n",
    "            + p2 * sto ** 7\n",
    "            + p3 * sto ** 6\n",
    "            + p4 * sto ** 5\n",
    "            + p5 * sto ** 4\n",
    "            + p6 * sto ** 3\n",
    "            + p7 * sto ** 2\n",
    "            + p8 * sto\n",
    "            + p9\n",
    "    )\n",
    "\n",
    "    Negative_particle_radius = 9.3e-06\n",
    "    arrhenius = 4 * Negative_particle_radius ** 2 / (9 * 1800 * math.pi)\n",
    "    D_sil_mult = 1 * (2.718281828459045 ** (2.55 * sto))\n",
    "    # D_sil_mult=20\n",
    "    D_silicon = D_sil_mult * arrhenius * (U_change ** 2)\n",
    "\n",
    "    return D_silicon\n",
    "\n",
    "\n",
    "def graphite_diffusivity_experiment(sto, T):\n",
    "    \"\"\"\n",
    "    Graphite diffusivity as a function of stochiometry, in this case the\n",
    "    diffusivity is from \"YWL-1负极 GITT_005_2\".\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    ..\n",
    "\n",
    "    ----------\n",
    "    sto: :class:`pybamm.Symbol`\n",
    "        Electrode stochiometry\n",
    "    T: :class:`pybamm.Symbol`\n",
    "        Dimensional temperature\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Solid diffusivity\n",
    "    \"\"\"\n",
    "\n",
    "    p1 = 5261.735192058068\n",
    "    p2 = -26338.104622526982\n",
    "    p3 = 55361.74766604773\n",
    "    p4 = -63323.87289433848\n",
    "    p5 = 42668.48270969592\n",
    "    p6 = -17111.760390059688\n",
    "    p7 = 3925.101191151728\n",
    "    p8 = -465.9745852796591\n",
    "    p9 = 23.111074947550833\n",
    "\n",
    "    U_change = (\n",
    "            p1 * sto ** 8\n",
    "            + p2 * sto ** 7\n",
    "            + p3 * sto ** 6\n",
    "            + p4 * sto ** 5\n",
    "            + p5 * sto ** 4\n",
    "            + p6 * sto ** 3\n",
    "            + p7 * sto ** 2\n",
    "            + p8 * sto\n",
    "            + p9\n",
    "    )\n",
    "\n",
    "    Negative_particle_radius = 1.3e-05\n",
    "    arrhenius = 4 * Negative_particle_radius ** 2 / (9 * 1800 * math.pi)\n",
    "    D_gra_mult = (2.718281828459045 ** (3.5 * sto)) * 1\n",
    "    # D_gra_mult=80\n",
    "    D_graphite = D_gra_mult * arrhenius * (U_change ** 2)\n",
    "\n",
    "    return D_graphite\n",
    "\n",
    "\n",
    "# %% Parameter LCO Cathode: OCP (reverted)\n",
    "\n",
    "def lco_ocp(sto):\n",
    "    pass\n",
    "\n",
    "\n",
    "def lico2_ocp_Ramadass2004(sto):\n",
    "    \"\"\"\n",
    "    Lithium Cobalt Oxide (LiCO2) Open-circuit Potential (OCP) as a a function of the\n",
    "    stochiometry. The fit is taken from Ramadass 2004. Stretch is considered the\n",
    "    overhang area negative electrode / area positive electrode, in Ramadass 2002.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] P. Ramadass, Bala Haran, Parthasarathy M. Gomadam, Ralph White, and Branko\n",
    "    N. Popov. \"Development of First Principles Capacity Fade Model for Li-Ion Cells.\"\n",
    "    (2004)\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    sto : :class:`pybamm.Symbol`\n",
    "       Stochiometry of material (li-fraction)\n",
    "\n",
    "    \"\"\"\n",
    "\n",
    "    stretch = 1.13\n",
    "    sto = stretch * sto\n",
    "\n",
    "    u_eq = (\n",
    "                   -4.656\n",
    "                   + 88.669 * (sto ** 2)\n",
    "                   - 401.119 * (sto ** 4)\n",
    "                   + 342.909 * (sto ** 6)\n",
    "                   - 462.471 * (sto ** 8)\n",
    "                   + 433.434 * (sto ** 10)\n",
    "           ) / (\n",
    "                   -1\n",
    "                   + 18.933 * (sto ** 2)\n",
    "                   - 79.532 * (sto ** 4)\n",
    "                   + 37.311 * (sto ** 6)\n",
    "                   - 73.083 * (sto ** 8)\n",
    "                   + 95.96 * (sto ** 10)\n",
    "           )\n",
    "\n",
    "    return u_eq\n",
    "\n",
    "\n",
    "def lico2_ocp_Ai2020(sto):\n",
    "    name, (x, y) = lico2_ocp_Ai2020_data\n",
    "    print(pybamm.Interpolant(x, y, sto, name=name, interpolator=\"cubic\"))\n",
    "    return pybamm.Interpolant(x, y, sto, name=name, interpolator=\"cubic\")\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "def lico2_ocp_experiment(sto):\n",
    "    name, (x, y) = lico2_ocp_experiment_data\n",
    "    print(pybamm.Interpolant(x, y, sto, name=name, interpolator=\"cubic\"))\n",
    "    return pybamm.Interpolant(x, y, sto, name=name, interpolator=\"cubic\")  # <<<<<<<#\n",
    "    # return pybamm.Interpolant(x, y , sto, name=name, interpolator=\"cubic\")#<<<<<<<#\n",
    "\n",
    "\n",
    "lico2_ocp_experiment_data = pybamm.parameters.process_1D_data(\n",
    "    \"lico2_ocp_Experiment.csv\", path=r\"/home/ma-user/work/PINNs/data\")\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# %% Parameter LCO Cathode: Diffusivity\n",
    "\n",
    "def lico2_diffusivity_Ramadass2004(sto, T):\n",
    "    \"\"\"\n",
    "    LiCo2 diffusivity as a function of stochiometry, in this case the\n",
    "    diffusivity is taken to be a constant. The value is taken from Ramadass 2004.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] P. Ramadass, Bala Haran, Parthasarathy M. Gomadam, Ralph White, and Branko\n",
    "    N. Popov. \"Development of First Principles Capacity Fade Model for Li-Ion Cells.\"\n",
    "    (2004)\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    sto: :class:`pybamm.Symbol`\n",
    "        Electrode stochiometry\n",
    "    T: :class:`pybamm.Symbol`\n",
    "        Dimensional temperature\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Solid diffusivity\n",
    "    \"\"\"\n",
    "    D_ref = 1 * 10 ** (-14)\n",
    "    E_D_s = 18550\n",
    "    arrhenius = np.exp(E_D_s / pybamm.constants.R * (1 / 298.15 - 1 / T))\n",
    "\n",
    "    return D_ref * arrhenius\n",
    "\n",
    "\n",
    "# Parameter functions for Ai2020\n",
    "def lico2_diffusivity_Dualfoil1998(sto, T):\n",
    "    \"\"\"\n",
    "    LiCo2 diffusivity as a function of stochiometry, in this case the\n",
    "    diffusivity is taken to be a constant. The value is taken from Dualfoil [1].\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] http://www.cchem.berkeley.edu/jsngrp/fortran.html\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    sto: :class:`pybamm.Symbol`\n",
    "        Electrode stochiometry\n",
    "    T: :class:`pybamm.Symbol`\n",
    "        Dimensional temperature, [K]\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Solid diffusivity [m2.s-1]\n",
    "    \"\"\"\n",
    "    D_ref = 5.6 * 10 ** (-15)\n",
    "    E_D_s = 5000\n",
    "    T_ref = 298.15\n",
    "    arrhenius = np.exp(E_D_s / pybamm.constants.R * (1 / T_ref - 1 / T))\n",
    "    return D_ref * arrhenius\n",
    "\n",
    "\n",
    "def lico2_diffusivity_experiment(sto, T):\n",
    "    \"\"\"\n",
    "    LiCo2 diffusivity as a function of stochiometry, the value is taken from experiment.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. 'YWL-1正极 GITT_002_1~2.xlsx'\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    sto: :class:`pybamm.Symbol`\n",
    "        Electrode stochiometry\n",
    "    T: :class:`pybamm.Symbol`\n",
    "        Dimensional temperature, [K]\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Solid diffusivity [m2.s-1]\n",
    "    \"\"\"\n",
    "    p1 = -4.31475992e+04\n",
    "    p2 = 2.02360254e+05\n",
    "    p3 = -4.10928476e+05\n",
    "    p4 = 4.74054591e+05\n",
    "    p5 = -3.42287611e+05\n",
    "    p6 = 1.60430178e+05\n",
    "    p7 = -4.89007954e+04\n",
    "    p8 = 9.42629442e+03\n",
    "    p9 = -1.07559539e+03\n",
    "    p10 = 6.16102953e+01\n",
    "    p11 = -6.97110095e-01\n",
    "    p12 = 7.73570830e-01\n",
    "\n",
    "    U_change = (\n",
    "            p1 * sto ** 11\n",
    "            + p2 * sto ** 10\n",
    "            + p3 * sto ** 9\n",
    "            + p4 * sto ** 8\n",
    "            + p5 * sto ** 7\n",
    "            + p6 * sto ** 6\n",
    "            + p7 * sto ** 5\n",
    "            + p8 * sto ** 4\n",
    "            + p9 * sto ** 3\n",
    "            + p10 * sto ** 2\n",
    "            + p11 * sto\n",
    "            + p12\n",
    "    )\n",
    "\n",
    "    Positive_particle_radius = 13e-06\n",
    "    arrhenius = 4 * Positive_particle_radius ** 2 / (2 * 1800 * math.pi)\n",
    "    # D_li_p_mult=0.29 #should be 2.5\n",
    "    D_li_p_mult = 25 * (2.718281828459045 ** (1.5 * sto))  # should be 2.5\n",
    "    D_li = D_li_p_mult * arrhenius * (U_change ** 2)\n",
    "\n",
    "    return D_li\n",
    "\n",
    "\n",
    "# %% Parameter LCO Cathode: Current Density & Entropic Change\n",
    "\n",
    "def lico2_electrolyte_exchange_current_density_Ramadass2004(c_e, c_s_surf, c_s_max, T):\n",
    "    \"\"\"\n",
    "    Exchange-current density for Butler-Volmer reactions between lico2 and LiPF6 in\n",
    "    EC:DMC.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] P. Ramadass, Bala Haran, Parthasarathy M. Gomadam, Ralph White, and Branko\n",
    "    N. Popov. \"Development of First Principles Capacity Fade Model for Li-Ion Cells.\"\n",
    "    (2004)\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    c_e : :class:`pybamm.Symbol`\n",
    "        Electrolyte concentration [mol.m-3]\n",
    "    c_s_surf : :class:`pybamm.Symbol`\n",
    "        Particle concentration [mol.m-3]\n",
    "    c_s_max : :class:`pybamm.Symbol`\n",
    "        Maximum particle concentration [mol.m-3]\n",
    "    T : :class:`pybamm.Symbol`\n",
    "        Temperature [K]\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Exchange-current density [A.m-2]\n",
    "    \"\"\"\n",
    "    io_p_mult = 1\n",
    "    m_ref = io_p_mult * 10 ** (-6)  # (A/m2)(m3/mol)**1.5\n",
    "    E_r = 39570\n",
    "    arrhenius = np.exp(E_r / pybamm.constants.R * (1 / 298.15 - 1 / T))\n",
    "\n",
    "    return m_ref * arrhenius * c_e ** 0.5 * c_s_surf ** 0.5 * (c_s_max - c_s_surf) ** 0.5\n",
    "\n",
    "\n",
    "def lico2_electrolyte_exchange_current_density_Dualfoil1998(c_e, c_s_surf, c_s_max, T):\n",
    "    \"\"\"\n",
    "    Exchange-current density for Butler-Volmer reactions between lico2 and LiPF6 in\n",
    "    EC:DMC.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [2] http://www.cchem.berkeley.edu/jsngrp/fortran.html\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    c_e : :class:`pybamm.Symbol`\n",
    "        Electrolyte concentration [mol.m-3]\n",
    "    c_s_surf : :class:`pybamm.Symbol`\n",
    "        Particle concentration [mol.m-3]\n",
    "    c_s_max : :class:`pybamm.Symbol`\n",
    "        Maximum particle concentration [mol.m-3]\n",
    "    T : :class:`pybamm.Symbol`\n",
    "        Temperature [K]\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Exchange-current density [A.m-2]\n",
    "    \"\"\"\n",
    "    m_ref = 1 * 2 * 10 ** (-11) * pybamm.constants.F  # need to match the unit from m/s\n",
    "    # (A/m2)(m3/mol)**1.5 - includes ref concentrations\n",
    "    E_r = 5000\n",
    "    arrhenius = np.exp(E_r / pybamm.constants.R * (1 / 298.15 - 1 / T))\n",
    "\n",
    "    return m_ref * arrhenius * c_e ** 0.5 * c_s_surf ** 0.5 * (c_s_max - c_s_surf) ** 0.5\n",
    "\n",
    "\n",
    "def lico2_entropic_change_Ai2020_function(sto):\n",
    "    \"\"\"\n",
    "    Lithium Cobalt Oxide (LiCO2) entropic change in open-circuit potential (OCP) at\n",
    "    a temperature of 298.15K as a function of the stochiometry. The fit is taken\n",
    "    from Ref [1], which is only accurate\n",
    "    for 0.43 < sto < 0.9936.\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] Ai, W., Kraft, L., Sturm, J., Jossen, A., & Wu, B. (2020).\n",
    "    Electrochemical Thermal-Mechanical Modelling of Stress Inhomogeneity\n",
    "    in Lithium-Ion Pouch Cells. Journal of The Electrochemical Society,\n",
    "        167(1), 013512. DOI: 10.1149/2.0122001JES\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    sto: double\n",
    "       Stochiometry of material (li-fraction)\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Entropic change [V.K-1]\n",
    "    \"\"\"\n",
    "\n",
    "    # Since the equation for LiCo2 from this ref. has the stretch factor,\n",
    "    # should this too? If not, the \"bumps\" in the OCV don't line up.\n",
    "    p1 = -3.20392657\n",
    "    p2 = 14.5719049\n",
    "    p3 = -27.9047599\n",
    "    p4 = 29.1744564\n",
    "    p5 = -17.992018\n",
    "    p6 = 6.54799331\n",
    "    p7 = -1.30382445\n",
    "    p8 = 0.109667298\n",
    "\n",
    "    du_dT = (\n",
    "            p1 * sto ** 7\n",
    "            + p2 * sto ** 6\n",
    "            + p3 * sto ** 5\n",
    "            + p4 * sto ** 4\n",
    "            + p5 * sto ** 3\n",
    "            + p6 * sto ** 2\n",
    "            + p7 * sto\n",
    "            + p8\n",
    "    )\n",
    "\n",
    "    return du_dT\n",
    "\n",
    "\n",
    "def lico2_entropic_change_Moura2016(sto, c_s_max):\n",
    "    \"\"\"\n",
    "    Lithium Cobalt Oxide (LiCO2) entropic change in open-circuit potential (OCP) at\n",
    "    a temperature of 298.15K as a function of the stochiometry. The fit is taken\n",
    "    from Scott Moura's FastDFN code [1].\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] https://github.com/scott-moura/fastDFN\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    sto : :class:`pybamm.Symbol`\n",
    "        Stochiometry of material (li-fraction)\n",
    "    \"\"\"\n",
    "    # Since the equation for LiCo2 from this ref. has the stretch factor,\n",
    "    # should this too? If not, the \"bumps\" in the OCV don't line up.\n",
    "    stretch = 1.062\n",
    "    sto = stretch * sto\n",
    "\n",
    "    du_dT = (\n",
    "            0.07645 * (-54.4806 / c_s_max) * ((1.0 / np.cosh(30.834 - 54.4806 * sto)) ** 2)\n",
    "            + 2.1581 * (-50.294 / c_s_max) * ((np.cosh(52.294 - 50.294 * sto)) ** (-2))\n",
    "            + 0.14169 * (19.854 / c_s_max) * ((np.cosh(11.0923 - 19.8543 * sto)) ** (-2))\n",
    "            - 0.2051 * (5.4888 / c_s_max) * ((np.cosh(1.4684 - 5.4888 * sto)) ** (-2))\n",
    "            - (0.2531 / 0.1316 / c_s_max) * ((np.cosh((-sto + 0.56478) / 0.1316)) ** (-2))\n",
    "            - (0.02167 / 0.006 / c_s_max) * ((np.cosh((sto - 0.525) / 0.006)) ** (-2))\n",
    "    )\n",
    "\n",
    "    return du_dT\n",
    "\n",
    "\n",
    "# %% Electrolyte: Diffusivity & Conductivity\n",
    "\n",
    "\n",
    "def electrolyte_diffusivity_Nyman2008(c_e, T):\n",
    "    \"\"\"\n",
    "    Diffusivity of LiPF6 in EC:EMC (3:7) as a function of ion concentration. The data\n",
    "    comes from [1]\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] A. Nyman, M. Behm, and G. Lindbergh, \"Electrochemical characterisation and\n",
    "    modelling of the mass transport phenomena in LiPF6-EC-EMC electrolyte,\"\n",
    "    Electrochim. Acta, vol. 53, no. 22, pp. 6356–6365, 2008.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    c_e: :class:`pybamm.Symbol`\n",
    "        Dimensional electrolyte concentration\n",
    "    T: :class:`pybamm.Symbol`\n",
    "        Dimensional temperature\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Solid diffusivity\n",
    "    \"\"\"\n",
    "\n",
    "    D_c_e = 8.794e-11 * (c_e / 1000) ** 2 - 3.972e-10 * (c_e / 1000) + 4.862e-10\n",
    "\n",
    "    # Nyman et al. (2008) does not provide temperature dependence\n",
    "\n",
    "    return D_c_e\n",
    "\n",
    "\n",
    "def electrolyte_conductivity_Nyman2008(c_e, T):\n",
    "    \"\"\"\n",
    "    Conductivity of LiPF6 in EC:EMC (3:7) as a function of ion concentration. The data\n",
    "    comes from [1].\n",
    "\n",
    "    References\n",
    "    ----------\n",
    "    .. [1] A. Nyman, M. Behm, and G.\n",
    "    , \"Electrochemical characterisation and\n",
    "    modelling of the mass transport phenomena in LiPF6-EC-EMC electrolyte,\"\n",
    "    Electrochim. Acta, vol. 53, no. 22, pp. 6356–6365, 2008.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    c_e: :class:`pybamm.Symbol`\n",
    "        Dimensional electrolyte concentration\n",
    "    T: :class:`pybamm.Symbol`\n",
    "        Dimensional temperature\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :class:`pybamm.Symbol`\n",
    "        Solid diffusivity\n",
    "    \"\"\"\n",
    "\n",
    "    sigma_e = (\n",
    "            0.1297 * (c_e / 1000) ** 3 - 2.51 * (c_e / 1000) ** 1.5 + 3.329 * (c_e / 1000)\n",
    "    )\n",
    "\n",
    "    # Nyman et al. (2008) does not provide temperature dependence\n",
    "\n",
    "    return sigma_e\n",
    "\n",
    "\n",
    "# %% Geometric and Thermal Cell Paramters\n",
    "\n",
    "\n",
    "# Compute geometric cell paramters\n",
    "# N = 26 # From HQ: number of layers\n",
    "cell_width = 0.0412  # From HQ: Cell width [m]\n",
    "cell_length = 0.1047  # From HQ: Cell length [m]\n",
    "cell_height = 0.0027  # From HQ: Cell height [m]\n",
    "nom_capacity = 5.7  # From HQ: Nominal capacity [Ah]\n",
    "anode_thickness = 3.9E-05  # From HQ: Anode thickness (active material) [m]\n",
    "cathode_thickness = 4.0e-05  # From HQ: Cathode thickness (active material) [m]\n",
    "separator_thickness = 7.0e-06  # From HQ: Separator thickness [m]\n",
    "max_Li_concentration_cathode = 50854  # Maximum Li-ion concentration in the cathode [mol/m^3]\n",
    "farady_constant = 96485.33212  # Faraday Constant [C/mol]\n",
    "cathode_condensed_density = 4.0664  # From HQ: [g/cm3]; 4\n",
    "anode_condensed_density = 1.5  # From HQ: [g/cm3]\n",
    "cathode_length = 3.129  # From HQ: Cathode length for whole cell[m]\n",
    "cathode_width = 0.071  # From HQ: Cathode width for whole cell[m]\n",
    "cathode_height = 4.0e-5  # From HQ: Cathode thickness(m) slit cell[m]\n",
    "silicon_carbon_ratio = 0.1\n",
    "lithium_stoichiometry_x_for_anode = 0.03256\n",
    "\n",
    "# cell_surface_single = cell_width*cell_length # Cell surface of single anode/cathode layer\n",
    "cell_surface_total = 2 * (\n",
    "            cell_width * cell_length + cell_width * cell_height + cell_height * cell_length)  # Cell total surface of all\n",
    "cell_volume = cell_height * cell_surface_total  # Cell volume [m^3]\n",
    "areal_capacity = nom_capacity / (cell_surface_total)  # Areal capacity [Ah/m^2]\n",
    "specific_capasity = nom_capacity / (\n",
    "            cathode_condensed_density * cathode_length * cathode_width * cathode_height)  # Specific capasity[Ah/g]\n",
    "\n",
    "cathode_porosity_estimation = 1 - (cathode_condensed_density / 5.1)  # Cathode porosity estimation\n",
    "anode_porosity_estimation = 1 - (anode_condensed_density / 2.26)  # Anode porosity estimation\n",
    "\n",
    "\n",
    "# Cell parameters\n",
    "param[\"Negative current collector thickness [m]\"] = 1.0e-7  # 8.0e-6 from HQ\n",
    "param[\"Positive current collector thickness [m]\"] = 1.0e-7  # 10.0e-6 from HQ\n",
    "param[\"Negative electrode thickness [m]\"] = anode_thickness\n",
    "param[\"Separator thickness [m]\"] = separator_thickness\n",
    "param[\"Positive electrode thickness [m]\"] = cathode_thickness\n",
    "param[\"Positive current collector thickness [m]\"] = 1e-5\n",
    "param[\"Cell cooling surface area [m2]\"] = cell_surface_total\n",
    "param[\"Cell volume [m3]\"] = cell_volume\n",
    "param[\"Nominal cell capacity [A.h]\"] = nom_capacity\n",
    "param[\"Electrode width [m]\"] = cathode_length\n",
    "param[\"Electrode height [m]\"] = cathode_width\n",
    "\n",
    "param['Ambient temperature [K]'] = 300.15\n",
    "param['Initial temperature [K]'] = 300.15\n",
    "param['Reference temperature [K]'] = 300.15\n",
    "\n",
    "\n",
    "# Cathode parameters from Dualfoil1998\\Ai2020\n",
    "param[\"Positive electrode conductivity [S.m-1]\"] = 10.0  # From HQ; PyBAMM literature value is 1\n",
    "param[\"Maximum concentration in positive electrode [mol.m-3]\"] = 47854  # From HQ: 50854\n",
    "###\n",
    "param[\"Positive electrode diffusivity [m2.s-1]\"] = 1e-13  # lico2_diffusivity_Ramadass2004\n",
    "param[\"Positive electrode OCP [V]\"] = lico2_ocp_experiment  # lico2_ocp_Ramadass2004\n",
    "param[\"Positive electrode porosity\"] = 0.297\n",
    "param[\"Positive electrode active material volume fraction\"] = (1 - 0.297) * (\n",
    "            1 - 0.024)  # From HQ; PyBAMM literature value is 0.62\n",
    "param[\"Positive particle radius [m]\"] = 13e-06\n",
    "param[\"Positive electrode Bruggeman coefficient (electrolyte)\"] = 1.5\n",
    "param[\"Positive electrode Bruggeman coefficient (electrode)\"] = 1.5\n",
    "param[\"Positive electrode charge transfer coefficient\"] = 0.5\n",
    "param[\"Positive electrode double-layer capacity [F.m-2]\"] = 0.4\n",
    "param[\"Positive electrode exchange-current density [A.m-2]\"] = lico2_electrolyte_exchange_current_density_Dualfoil1998\n",
    "param[\"Positive electrode density [kg.m-3]\"] = cathode_condensed_density * 1000\n",
    "param[\"Positive electrode specific heat capacity [J.kg-1.K-1]\"] = 1080.2 * 1000\n",
    "param[\"Positive electrode thermal conductivity [W.m-1.K-1]\"] = 1.58  # 2.1\n",
    "param[\n",
    "    \"Positive electrode OCP entropic change [V.K-1]\"] = lico2_entropic_change_Ai2020_function  # lico2_entropic_change_Moura2016\n",
    "param[\"Initial concentration in positive electrode [mol.m-3]\"] = 44125  # C/10\n",
    "# param[\"Initial concentration in positive electrode [mol.m-3]\"] =47125 # Multi ;C/2 47125\n",
    "\n",
    "\n",
    "# %% Anode parameters\n",
    "\n",
    "\n",
    "# Anode parameters  Primary:graphite \n",
    "param[\"Negative electrode conductivity [S.m-1]\"] = 215  # From HQ; PyBAMM literature value is 215.0, prev 100\n",
    "param[\"Primary: Maximum concentration in negative electrode [mol.m-3]\"] = 31507  # From Literature\n",
    "param[\"Primary: Initial concentration in negative electrode [mol.m-3]\"] = 18400  # adjustable, depend on initial SoC\n",
    "param[\"Primary: Negative electrode diffusivity [m2.s-1]\"] = 3.9e-14\n",
    "param[\"Primary: Negative electrode OCP [V]\"] = graphite_ocp_Enertech_Ai2020\n",
    "param[\"Negative electrode porosity\"] = 0.471\n",
    "param[\"Primary: Negative electrode active material volume fraction\"] = (1 - 0.471) * (\n",
    "            1 - 0.04)  # From HQ; Literature value is 0.735\n",
    "param[\"Primary: Negative particle radius [m]\"] = 1.3e-05  # From HQ; Literature value is 5.86e-06\n",
    "param[\"Negative electrode Bruggeman coefficient (electrolyte)\"] = 1.5\n",
    "param[\"Negative electrode Bruggeman coefficient (electrode)\"] = 1.5\n",
    "param[\"Negative electrode charge transfer coefficient\"] = 0.5\n",
    "param[\"Negative electrode double-layer capacity [F.m-2]\"] = 0.2\n",
    "param[\n",
    "    \"Primary: Negative electrode exchange-current density [A.m-2]\"] = graphite_LGM50_electrolyte_exchange_current_density_Chen2020  # calculated by impedance\n",
    "param[\"Primary: Negative electrode density [kg.m-3]\"] = anode_condensed_density * 1000\n",
    "param[\"Negative electrode specific heat capacity [J.kg-1.K-1]\"] = 700.0 * 1300\n",
    "param[\"Negative electrode thermal conductivity [W.m-1.K-1]\"] = 1.7\n",
    "param[\"Primary: Negative electrode OCP entropic change [V.K-1]\"] = 0.0\n",
    "\n",
    "\n",
    "# Separator parameters\n",
    "param[\"Separator porosity\"] = 0.473  # From HQ; Literature value is 0.47\n",
    "param[\"Separator Bruggeman coefficient (electrolyte)\"] = 1.5\n",
    "param[\"Separator density [kg.m-3]\"] = 397.0\n",
    "param[\"Separator specific heat capacity [J.kg-1.K-1]\"] = 700.0\n",
    "param[\"Separator thermal conductivity [W.m-1.K-1]\"] = 0.16\n",
    "\n",
    "\n",
    "# Electrolyte paramters\n",
    "param[\"Initial concentration in electrolyte [mol.m-3]\"] = 1000.0\n",
    "param[\"Cation transference number\"] = 0.363  # From HQ; PyBAMM literature value is 0.2594\n",
    "param[\"Thermodynamic factor\"] = 1.0\n",
    "param[\n",
    "    \"Electrolyte diffusivity [m2.s-1]\"] = 7.5e-11  # From HQ; PyBAMM literature value is electrolyte_diffusivity_Nyman2008\n",
    "param[\"Electrolyte conductivity [S.m-1]\"] = electrolyte_conductivity_Nyman2008\n",
    "\n",
    "# current continuous\n",
    "time_array = np.linspace(0, 7200, 1000)  # 0到7200秒，1000个点\n",
    "current_values = 5 * np.sin(0.005 * time_array)  # 0到10 A 的正弦波\n",
    "\n",
    "# 创建插值函数\n",
    "param[\"Current function [A]\"] = pybamm.Interpolant(\n",
    "    time_array,\n",
    "    current_values,\n",
    "    pybamm.t\n",
    ")\n",
    "# SEI parameters\n",
    "# param[\"Primary: Ratio of lithium moles to SEI moles\"] = 2.0\n",
    "# param[\"Primary: Inner SEI reaction proportion\"] = 0.5\n",
    "# param[\"Primary: Inner SEI partial molar volume [m3.mol-1]\"] = 9.585e-05\n",
    "# param[\"Primary: Outer SEI partial molar volume [m3.mol-1]\"] = 9.585e-05\n",
    "# param[\"Primary: SEI reaction exchange current density [A.m-2]\"] = 1.5e-07\n",
    "# param[\"Primary: SEI resistivity [Ohm.m]\"] = 200000.0\n",
    "# param[\"Primary: Outer SEI solvent diffusivity [m2.s-1]\"] = 2.5000000000000002e-22\n",
    "# param[\"Primary: Bulk solvent concentration [mol.m-3]\"] = 2636.0\n",
    "# param[\"Primary: Inner SEI open-circuit potential [V]\"] = 0.1\n",
    "# param[\"Primary: Outer SEI open-circuit potential [V]\"] = 0.8\n",
    "# param[\"Primary: Inner SEI electron conductivity [S.m-1]\"] = 8.95e-14\n",
    "# param[\"Primary: Inner SEI lithium interstitial diffusivity [m2.s-1]\"] = 1e-20\n",
    "# param[\"Primary: Lithium interstitial reference concentration [mol.m-3]\"] = 15.0\n",
    "# param[\"Primary: Initial inner SEI thickness [m]\"] = 2.5e-09\n",
    "# param[\"Primary: Initial outer SEI thickness [m]\"] = 2.5e-09\n",
    "# param[\"Primary: EC initial concentration in electrolyte [mol.m-3]\"] = 4541.0\n",
    "# param[\"Primary: EC diffusivity [m2.s-1]\"] = 2e-18\n",
    "# param[\"Primary: SEI kinetic rate constant [m.s-1]\"] = 1e-12\n",
    "# param[\"Primary: SEI open-circuit potential [V]\"] = 0.4\n",
    "# param[\"Primary: SEI growth activation energy [J.mol-1]\"] = 0.0\n",
    "# param[\"Positive electrode reaction-driven LAM factor [m3.mol-1]\"] = 0.0\n",
    "\n",
    "\n",
    "if __name__ == '__main__':\n",
    "    # Update cell setting\n",
    "    param.update({\"Upper voltage cut-off [V]\": 5.73})\n",
    "    param.update({\"Lower voltage cut-off [V]\": 2.9})\n",
    "    # param['Open-circuit voltage at 0% SOC [V]'] = 2.9\n",
    "    # param['Open-circuit voltage at 100% SOC [V]'] = 4.53\n",
    "    mult_max = 0.9\n",
    "    in_n_mult = 2\n",
    "    param.update(\n",
    "        {\n",
    "            \"Primary: Maximum concentration in negative electrode [mol.m-3]\": 31507 * mult_max,  # 28700, 32616\n",
    "            \"Primary: Initial concentration in negative electrode [mol.m-3]\": 1300 * in_n_mult / 1.475,\n",
    "            # lithium_stoichiometry_x_for_anode(0% SoC)*32616\n",
    "            \"Primary: Negative electrode diffusivity [m2.s-1]\": graphite_diffusivity_experiment,\n",
    "            # \"Secondary: Negative electrode diffusivity [m2.s-1]\": silicon_diffusivity_experiment,\n",
    "            # \"Secondary: Initial concentration in negative electrode [mol.m-3]\": 5200 * in_n_mult / 1.475,\n",
    "            # lithium_stoichiometry_x_for_anode(0% SoC)*297000\n",
    "            # \"Secondary: Maximum concentration in negative electrode [mol.m-3]\": 126028 * mult_max,\n",
    "            # From HQ; PyBAMM literature value is 278000, 297000\n",
    "            \"Maximum concentration in positive electrode [mol.m-3]\": 47854,  # From HQ: 50854\n",
    "            \"Initial concentration in positive electrode [mol.m-3]\": 44125,  # C/10\n",
    "        }\n",
    "    )\n",
    "    # charging strateg, need modify 1\n",
    "    # experiment_2CP = pybamm.Experiment(\n",
    "    #     [\n",
    "    #         (\n",
    "    #             # \"Discharge at 4 C until 2.9 V\",\n",
    "    #             # \"Rest for 1 hour\",\n",
    "    #             # \"Charge at 19.9999 A until 4.18 V\",\n",
    "    #             # \"Charge at 14.05 A until 4.27 V\",\n",
    "    #             # \"Charge at 11.24 A until 4.27 V\",\n",
    "    #             # \"Charge at 10.116 A until 4.45 V\",\n",
    "    #             # \"Hold at 4.45 V until 5.62 A\",\n",
    "    #             \"Charge at 5.62 A until 4.5 V\",\n",
    "    #             # \"Hold at 4.5 V until 3.934 A\",\n",
    "    #             # \"Charge at 3.934 A until 4.515 V\",\n",
    "    #             # \"Hold at 4.515 V until 0.8149 A\",\n",
    "    #         ),\n",
    "    #     ])\n",
    "   \n",
    "\n",
    "    # Simulation start\n",
    "    sim = pybamm.Simulation(\n",
    "        model,\n",
    "        # Need modify 2\n",
    "        parameter_values=param,\n",
    "        solver=pybamm.IDAKLUSolver(rtol=1e-4, atol=1e-4)\n",
    "    )\n",
    "    t_end = 1500\n",
    "    t_eval = np.linspace(0, t_end, 50)\n",
    "    sim.solve(t_eval=t_eval,calc_esoh=False)\n",
    "    time = sim.solution[\"Time [s]\"].entries\n",
    "    time_shape = np.array(time).shape[0]\n",
    "\n",
    "    x_values = sim.solution[\"x [m]\"].entries # 60 126\n",
    "    x_n_values = sim.solution[\"x_n [m]\"].entries # 60 126\n",
    "    x_p_values = sim.solution[\"x_p [m]\"].entries # 60 126\n",
    "    x_s_values = sim.solution[\"x_s [m]\"].entries # 60 126\n",
    "    r_p_values = sim.solution[\"r_p [m]\"].entries[:,0,:]\n",
    "    r_n_values = sim.solution[\"r_n [m]\"].entries[:,0,:]\n",
    "    x_shape = np.array(x_p_values).shape[0]\n",
    "    time_simulation = np.tile(np.array(time), (x_shape, 1))\n",
    "    r_values = sim.solution[\"r_n [m]\"].entries\n",
    "    U_anode_solid_sim_test = sim.solution[\"Positive electrode potential [V]\"].entries\n",
    "    # print(np.array(time).shape,np.array(x_values).shape,np.array(r_values).shape,U_anode_solid_sim_test.shape) # 56, 60 56, 20 56\n",
    "    volt = sim.solution[\"Voltage [V]\"].entries\n",
    "    current = sim.solution[\"Current [A]\"].entries\n",
    "    current_simulation = np.tile(np.array(current), (x_shape, 1))\n",
    "    # print(r_n_values[:,0,:].shape,\"++++++++++++++++++++++++++++++++++\")\n",
    "    Discharge_capacity = sim.solution[\"Discharge capacity [A.h]\"].entries\n",
    "    Throughput_capacity = sim.solution[\"Throughput capacity [A.h]\"].entries\n",
    "    Total_lithium_capacity = sim.solution[\"Total lithium capacity [A.h]\"].entries\n",
    "\n",
    "    U_anode_solid_sim = sim.solution[\"Negative electrode potential [V]\"].entries\n",
    "    U_anode_el_sim = sim.solution[\"Negative electrolyte potential [V]\"].entries\n",
    "    U_anode_sim = U_anode_solid_sim - U_anode_el_sim\n",
    "    result_U_anode = U_anode_sim\n",
    "\n",
    "    U_sep_el_sim = sim.solution[\"Separator electrolyte potential [V]\"].entries\n",
    "\n",
    "    U_cathode_solid_sim = sim.solution[\"Positive electrode potential [V]\"].entries\n",
    "    U_cathode_el_sim = sim.solution[\"Positive electrolyte potential [V]\"].entries\n",
    "    U_cathode_sim = U_cathode_solid_sim - U_cathode_el_sim\n",
    "    result_U_cathode = U_cathode_sim\n",
    "\n",
    "    # U_temp = U_cathode_el_sim - U_anode_el_sim\n",
    "    # print(U_temp)\n",
    "    print(sim.solution[\"Time [s]\"].entries) \n",
    "    my_data = dict(Time_Simulation=time_simulation.flatten(),\n",
    "                   Current_Simulation=current_simulation.flatten(),\n",
    "                    X_n_Value=np.array(x_n_values).flatten(),\n",
    "                    X_p_Value=np.array(x_p_values).flatten(),\n",
    "                    X_s_Value=np.array(x_s_values).flatten(),\n",
    "                    R_p_Value=np.array(r_p_values).flatten(),\n",
    "                    R_n_Value=np.array(r_n_values).flatten(),\n",
    "                    # Total_Voltage_Simulation=np.array(volt).shape,\n",
    "                    U_anode_solid_sim=np.array(U_anode_solid_sim).flatten(),\n",
    "                    Sep_Voltage_Simulation=np.array(U_sep_el_sim).flatten(),\n",
    "                    Anode_Voltage_Simulation=np.array(result_U_anode).flatten(),\n",
    "                    Cathode_Voltage_Simulation=np.array(result_U_cathode).flatten())\n",
    "                    # Discharge_capacity_Simulation=np.array(Discharge_capacity).shape,\n",
    "                    # Throughput_capacity_Simulation=np.array(Throughput_capacity).shape,\n",
    "                    # Total_lithium_capacity_Simulation=np.array(Total_lithium_capacity).shape)\n",
    "    df_output = pd.DataFrame(dict([(key, pd.Series(value)) for key, value in my_data.items()]))\n",
    "    # Need modify 3\n",
    "    df_output.to_csv(r'/home/ma-user/work/PINNs/data/experiment_1CP_continuous.csv')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffc35c36",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 读取 XLSX 文件，去掉第一行信息\n",
    "file_path = '/home/ma-user/work/PINNs/data/Results_1C.xlsx'  # 替换为你的文件路径\n",
    "data = pd.read_excel(file_path, header=None)\n",
    "\n",
    "# 提取所需的数据\n",
    "x1 = pd.to_numeric(data.iloc[:, 0], errors='coerce')  # 第一列作为第二列的横坐标\n",
    "y1 = pd.to_numeric(data.iloc[:, 1], errors='coerce')  # 第二列数据\n",
    "\n",
    "x2 = pd.to_numeric(data.iloc[:, 5], errors='coerce')  # 第六列作为第七列的横坐标\n",
    "y2 = pd.to_numeric(data.iloc[:, 6], errors='coerce')  # 第七列数据\n",
    "\n",
    "# 绘制图表\n",
    "plt.figure(figsize=(10, 5))\n",
    "\n",
    "# 绘制第二列数据\n",
    "plt.plot(x1, y1, marker='o', markersize = 3, label='Simulation')\n",
    "\n",
    "# 绘制第七列数据\n",
    "plt.plot(x2, y2, marker='.', markersize = 3, label='Origin')\n",
    "\n",
    "# 添加图例和标签\n",
    "plt.title('Simulation VS Origin')\n",
    "plt.xlabel('Time')\n",
    "plt.ylabel('V')\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "PyTorch-2.0.0",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
