forked from pybamm-team/PyBaMM
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmemory_unit_benchmarks.py
102 lines (82 loc) · 3.21 KB
/
memory_unit_benchmarks.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import pybamm
from benchmarks.benchmark_utils import set_random_seed
import numpy as np
class MemCreateExpression:
R: pybamm.Parameter
model: pybamm.BaseModel
def setup(self):
set_random_seed()
def mem_create_expression(self):
self.R = pybamm.Parameter("Particle radius [m]")
D = pybamm.Parameter("Diffusion coefficient [m2.s-1]")
j = pybamm.Parameter("Interfacial current density [A.m-2]")
F = pybamm.Parameter("Faraday constant [C.mol-1]")
c0 = pybamm.Parameter("Initial concentration [mol.m-3]")
self.model = pybamm.BaseModel()
c = pybamm.Variable("Concentration [mol.m-3]", domain="negative particle")
N = -D * pybamm.grad(c)
dcdt = -pybamm.div(N)
self.model.rhs = {c: dcdt}
lbc = pybamm.Scalar(0)
rbc = -j / F / D
self.model.boundary_conditions = {
c: {"left": (lbc, "Neumann"), "right": (rbc, "Neumann")}
}
self.model.initial_conditions = {c: c0}
self.model.variables = {
"Concentration [mol.m-3]": c,
"Surface concentration [mol.m-3]": pybamm.surf(c),
"Flux [mol.m-2.s-1]": N,
}
return self.model
class MemParameteriseModel(MemCreateExpression):
r: pybamm.SpatialVariable
geometry: dict
def setup(self):
set_random_seed()
MemCreateExpression.mem_create_expression(self)
def mem_parameterise(self):
param = pybamm.ParameterValues(
{
"Particle radius [m]": 10e-6,
"Diffusion coefficient [m2.s-1]": 3.9e-14,
"Interfacial current density [A.m-2]": 1.4,
"Faraday constant [C.mol-1]": 96485,
"Initial concentration [mol.m-3]": 2.5e4,
}
)
self.r = pybamm.SpatialVariable(
"r", domain=["negative particle"], coord_sys="spherical polar"
)
self.geometry = {
"negative particle": {self.r: {"min": pybamm.Scalar(0), "max": self.R}}
}
param.process_model(self.model)
param.process_geometry(self.geometry)
return param
class MemDiscretiseModel(MemParameteriseModel):
def setup(self):
set_random_seed()
MemCreateExpression.mem_create_expression(self)
MemParameteriseModel.mem_parameterise(self)
def mem_discretise(self):
MemCreateExpression.mem_create_expression(self)
MemParameteriseModel.mem_parameterise(self)
submesh_types = {"negative particle": pybamm.Uniform1DSubMesh}
var_pts = {self.r: 20}
mesh = pybamm.Mesh(self.geometry, submesh_types, var_pts)
spatial_methods = {"negative particle": pybamm.FiniteVolume()}
disc = pybamm.Discretisation(mesh, spatial_methods)
disc.process_model(self.model)
return disc
class MemSolveModel(MemDiscretiseModel):
def setup(self):
set_random_seed()
MemCreateExpression.mem_create_expression(self)
MemParameteriseModel.mem_parameterise(self)
MemDiscretiseModel.mem_discretise(self)
def mem_solve(self):
solver = pybamm.ScipySolver()
t = np.linspace(0, 3600, 600)
solver.solve(self.model, t)
return solver