-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconstants.jl
448 lines (448 loc) · 17.5 KB
/
constants.jl
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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
# radioactive switches
# solid phase radioactive heating from 26Al active
const hr_al = true
# fluid phase radioactive heating from 60Fe active
const hr_fe = false
# planetary parameters
# planetary radius [m]
const rplanet = 5_000.0
# crust radius [m]
const rcrust = 4_800.0
# surface pressure [Pa]
const psurface = 1.0e+3
# model size, geometry, and resolution
# horizontal model size [m]
const xsize = 14_000.0
# const xsize = 140_000.0
# vertical model size [m]
const ysize = 14_000.0
# const ysize = 140_000.0
# horizontal center of model
const xcenter = xsize / 2
# vertical center of model
const ycenter = ysize / 2
# basic grid resolution in x direction (horizontal)
const Nx = 15
# const Nx = 141
# basic grid resolution in y direction (vertical)
const Ny = 15
# const Ny = 141
# Vx, Vy, P grid resolution in x direction (horizontal)
const Nx1 = Nx + 1
# Vx/Vy/P grid resolution in y direction (vertical)
const Ny1 = Ny + 1
# horizontal grid step [m]
const dx = xsize / (Nx-1)
# vertical grid step [m]
const dy = ysize / (Ny-1)
# basic nodes
# horizontal coordinates of basic grid points [m]
const x = SVector{Nx, Float64}([j for j = 0:dx:xsize])
# const x = [j for j = 0:dx:xsize]
# vertical coordinates of basic grid points [m]
const y = SVector{Ny, Float64}([i for i = 0:dy:ysize])
# const y = [i for i = 0:dy:ysize]
# Vx nodes
# horizontal coordinates of vx grid points [m]
const xvx = SVector{Ny1, Float64}([j for j = 0:dx:xsize+dy])
# const xvx = [j for j = 0:dx:xsize+dy]
# vertical coordinates of vx grid points [m]
const yvx = SVector{Nx1, Float64}([i for i = -dy/2:dy:ysize+dy/2])
# const yvx = [i for i = -dy/2:dy:ysize+dy/2]
# Vy nodes
# horizontal coordinates of vy grid points [m]
const xvy = SVector{Nx1, Float64}([j for j = -dx/2:dx:xsize+dx/2])
# const xvy = [j for j = -dx/2:dx:xsize+dx/2]
# vertical coordinates of vy grid points [m]
const yvy = SVector{Ny1, Float64}([i for i = 0:dy:ysize+dy])
# const yvy = [i for i = 0:dy:ysize+dy]
# P nodes
# horizontal coordinates of p grid points [m]
const xp = SVector{Nx1, Float64}([j for j = -dx/2:dx:xsize+dx/2])
# const xp = [j for j = -dx/2:dx:xsize+dx/2]
# vertical coordinates of p grid points [m]
const yp = SVector{Ny1, Float64}([i for i = -dy/2:dy:ysize+dy/2])
# const yp = [i for i = -dy/2:dy:ysize+dy/2]
# basic grid min/max assignables indices
# minimum assignable basic grid index in x direction
const jmin_basic = 1
# minimum assignable basic grid index in y direction
const imin_basic = 1
# maximum assignable basic grid index in x direction
const jmax_basic = Nx - 1
# maximum assignable basic grid index in y direction
const imax_basic = Ny - 1
# Vx grid min/max assignables indices
# minimum assignable Vx grid index in x direction
const jmin_vx = 1
# minimum assignable Vx grid index in y direction
const imin_vx = 1
# maximum assignable Vx grid index in x direction
const jmax_vx = Nx - 1
# maximum assignable Vx grid index in y direction
const imax_vx = Ny
# Vy grid min/max assignables indices
# minimum assignable Vy grid index in x direction
const jmin_vy = 1
# minimum assignable Vy grid index in y direction
const imin_vy = 1
# maximum assignable Vy grid index in x direction
const jmax_vy = Nx
# maximum assignable Vy grid index in y direction
const imax_vy = Ny - 1
# P grid min/max assignables indices
# minimum assignable P grid index in x direction
const jmin_p = 1
# minimum assignable P grid index in y direction
const imin_p = 1
# maximum assignable P grid index in x direction
const jmax_p = Nx
# maximum assignable P grid index in y direction
const imax_p = Ny
# marker count and initial spacing
# number of markers per cell in horizontal direction
const Nxmc = 4
# number of markers per cell in vertical direction
const Nymc = 4
# marker grid resolution in horizontal direction
const Nxm = (Nx - 1) * Nxmc
# marker grid resolution in vertical direction
const Nym = (Ny - 1) * Nymc
# marker grid step in horizontal direction
const dxm = xsize / Nxm
# marker grid step in vertical direction
const dym = ysize / Nym
# horizontal coordinates of marker grid/launch anchor points [m]
const xxm = SVector{Nxm, Float64}([j for j = dxm/2:dxm:xsize-dxm/2])
# const xxm = [j for j = dxm/2:dxm:xsize-dxm/2]
# vertical coordinates of marker grid/launch anchor points [m]
const yym = SVector{Nxm, Float64}([i for i = dym/2:dym:ysize-dym/2])
# const yym = [i for i = dym/2:dym:ysize-dym/2]
# initialization distance of nearest marker to launch anchor point [m]
const mdis_init = 1.0e30
# number of markers at start
const start_marknum = Nxm * Nym
# marker grid min/max assignables indices
# minimum assignable marker grid index in x direction
const jmin_m = 1
# minimum assignable marker grid index in y direction
const imin_m = 1
# maximum assignable marker grid index in x direction
const jmax_m = Nxm - 1
# maximum assignable marker grid index in y direction
const imax_m = Nym - 1
# marker randomized positions and porosity for testing
const random_markers = true
# const random_markers = false
# physical constants
# gravitational constant [m³*kg⁻¹*s⁻²]
const G = 6.672e-11
# scaled pressure
# pressure scaling coefficient (eqn 7.19-7.21 in Gerya(2019))
# const Kcont = 2.0 * 1.0e15 * inv(dx+dy)
const Kcont = 1.0e20
# planetesimals: fluid phase H₂O -----------------------------------------------
# solid density [kg/m³]
const rhosolidm = SVector{3, Float64}( [3300.0 , 3300.0 , 1.0 ])
# fluid density [kg/m³]
const rhofluidm = SVector{3, Float64}( [1000.0 , 1000.0 , 1.0 ])
# solid viscosity [Pa*s]
const etasolidm = SVector{3, Float64}( [ 1.0e+19, 1.0e+19, 1.0e+16])
# molten solid viscosity [Pa*s]
const etasolidmm = SVector{3, Float64}( [ 1.0e+19, 1.0e+19, 1.0e+16])
# fluid viscosity [Pa*s]
const etafluidm = SVector{3, Float64}( [ 1.0e+12, 1.0e+12, 1.0e-03])
# molten fluid viscosity [Pa*s]
const etafluidmm = SVector{3, Float64}( [ 1.0e-03, 1.0e-03, 1.0e-03])
# solid volumetric heat capacity [kg/m³]
const rhocpsolidm = SVector{3, Float64}( [ 3.3e+06, 3.3e+06, 3.0e+06])
# fluid volumetric heat capacity [kg/m³]
const rhocpfluidm = SVector{3, Float64}( [ 1.0e+06, 1.0e+06, 3.0e+06])
# solid thermal expansion [1/K]
const alphasolidm = SVector{3, Float64}( [ 3.0e-05, 3.0e-05, 0.0 ])
# fluid thermal expansion [1/K]
const alphafluidm = SVector{3, Float64}( [ 5.0e-05, 5.0e-05, 0.0 ])
# solid thermal conductivity [W/m/K]
const ksolidm = SVector{3, Float64}( [ 3.0 , 3.0 , 3000.0 ])
# fluid thermal conductivity [W/m/K]
const kfluidm = SVector{3, Float64}( [ 50.0 , 50.0 , 3000.0 ])
# solid radiogenic heat production [W/m³]
const start_hrsolidm = SVector{3,Float64}([ 0.0 , 0.0 , 0.0 ])
# fluid radiogenic heat production [W/m³]
const start_hrfluidm = SVector{3,Float64}([ 0.0 , 0.0 , 0.0 ])
# solid shear modulus [Pa]
const gggsolidm = SVector{3, Float64}( [ 1.0e+10, 1.0e+10, 1.0e+10])
# solid friction coefficient
const frictsolidm = SVector{3, Float64}( [ 0.6 , 0.6 , 0.0 ])
# solid compressive strength [Pa]
const cohessolidm = SVector{3, Float64}( [ 1.0e+08, 1.0e+08, 1.0e+08])
# solid tensile strength [Pa]
const tenssolidm = SVector{3, Float64}( [ 6.0e+07, 6.0e+07, 6.0e+07])
# standard permeability [m^2]
const kphim0 = SVector{3, Float64}( [ 1.0e-13, 1.0e-13, 1.0e-17])
# initial temperature [K]
const tkm0 = SVector{3, Float64}( [ 170.0 , 170.0 , 170.0 ])
# initial wet solid molar fraction
const XWsolidm_init = SVector{3, Float64}([ 0.50 , 0.50 , NaN ])
# marker property mode (1: dynamic calculations, 9: static parameters)
const marker_property_mode = 9
# coefficient to compute compaction viscosity from shear viscosity
const etaphikoef = 1
# melt-weakening coefficient (16.67)
const αη = 28.0
# ------------------------------------------------------------------------------
# 26Al decay
# 26Al half life [s]
const t_half_al = 717_000 * 31_540_000
# 26Al decay constant
const tau_al = t_half_al / log(2)
# initial ratio of 26Al and 27Al isotopes
const ratio_al = 5.0e-5
# E 26Al [J]
const E_al = 5.0470e-13
# 26Al atoms/kg
const f_al = 1.9e23
# 60Fe decay
# 60Fe half life [s]
const t_half_fe = 2_620_000 * 31_540_000
# 60Fe decay constant
const tau_fe = t_half_fe / log(2)
# initial ratio of 60Fe and 56Fe isotopes
const ratio_fe = 1.0e-6
# E 60Fe [J]
const E_fe = 4.34e-13
# 60Fe atoms/kg
const f_fe = 1.957e24
# melting
# solid phase (silicate) melting temperature [K]
const tmsolidphase = 1416.0#1.0e+6
# fluid phase (H₂O) melting temperature [K]
const tmfluidphase = 273.0
# fluid phase (H₂O) heat of fusion of ice [J/kg]
const Lᶠ = 333.55e3
# porosities
# standard H₂O fraction [porosity]
const phim0 = 0.2
# min porosity
const phimin = 1.0e-4
# max porosity
const phimax = 1.0 - phimin
# thermodynamic parameters: silicate dehydration reaction Wˢ = Dˢ + H₂O
# molar gas constant [JK⁻¹mol⁻¹]
const RG = 8.314#46261815324
# molar mass of water [kg/mol]
const MH₂O = 0.018
# molar mass of dry silicate [kg/mol]
const MD = 0.120
# density of dry silicate [kg/m³]
const ρDˢ = 3300.0
# density of wet silicate [kg/m³]
const ρWˢ = 2600.0
# density of fluid (liquid H₂O) [kg/m³]
const ρH₂Oᶠ = 1000.0
# density of fluid ice (frozen H₂O) [kg/m³]
const ρH₂Oᶠⁱ = 917.0
# molar volume of dry solid [m³/mol]
const VDˢ = MD / ρDˢ
# molar volume of wet solid [m³/mol]
const VWˢ = (MD+MH₂O) / ρWˢ
# molar volume of fluid (liquid H₂O) [m³/mol]
const VH₂Oᶠ = MH₂O / ρH₂Oᶠ
# molar volume of fluid ice (frozen H₂O) [m³/mol]
const VH₂Oᶠⁱ = MH₂O / ρH₂Oᶠⁱ
# enthalpy change for dehydration of the wet silicate [J/mol]
const ΔHWD = 40000.0
# entropy change for dehydration of the wet silicate [J/K/mol]
const ΔSWD = 60.0
# volume change for dehydration of the wet silicate [m³/mol]
const ΔVWD = VDˢ + VH₂Oᶠ - VWˢ
# coefficient of pressure from previous hydrothermomechanical iteration
const pfcoeff = 0.5
# error limit to exit thermochemical iterations
const pferrmax = 1.0e+5
# reaction activation switch
const reaction_active = true
# time to run dehydration reaction to completion [s]
const Δtreaction = 1.0e+10
# log reaction completion rate ln(ρend/ρstart)
const log_completion_rate = log(0.01)
# reaction constant mode (1: [Martin & Fyfe, 1970; Emmanuel & Berkowitz, 2006;
# Iyer et al., 2012], 2: [Bland & Travis, 2017], 9: constant Δtreaction)
const reaction_rate_coeff_mode = 1
# reaction constant parameters mode 1 [Iyer et al., 2012]
# (A: kinetic coefficient, b: kinetic coefficient, c: kinetic coefficient)
A_I = 1.0e-11; b_I = 2.5e-4; c_I = 543.0
# reaction constant parameters mode 2 [Bland & Travis, 2017]
# (Sxo_B: reaction rate at ref T, Tscl_B: empirical scaling factor, To_B: reaction ref T)
Sxo_B = 2.0e-11; Tscl_B = 10.0 ; To_B = 293.0
# reaction constant parameters mode 3 [Travis et al., 2018]
# (Sxo_T: reaction rate at ref T, To_T: reaction ref T, Ea_T: reaction activation energy)
Sxo_T = 2.0e-11; To_T = 293.0; Ea_T = 63.8e3
# mechanical boundary conditions: free slip=-1 / no slip=1
# mechanical boundary condition left
const bcleft = -1
# mechanical boundary condition right
const bcright = -1
# mechanical boundary condition top
const bctop = -1
# mechanical boundary condition bottom
const bcbottom = -1
# hydraulic boundary conditions: free slip=-1 / no slip=1
# hydraulic boundary condition left
const bcfleft = -1
# hydraulic boundary condition right
const bcfright = -1
# hydraulic boundary condition top
const bcftop = -1
# hydraulic boundary condition bottom
const bcfbottom = -1
# extension/shortening velocities
# shortening strain rate
const strainrate = 0.0e-13
# x extension/shortening velocity left
const vxleft = strainrate * xsize / 2
# x extension/shortening velocity right
const vxright= -strainrate * xsize / 2
# y extension/shortening velocity top
const vytop = - strainrate * ysize / 2
# y extension/shortening velocity bottom
const vybottom = strainrate * ysize / 2
# Runge-Kutta integration parameters
# bⱼ Butcher coefficients for RK4
const brk4 = SVector{4, Rational{Int64}}([1//6, 2//6, 2//6, 1//6])
# cⱼ Butcher coefficients for RK4
const crk4 = SVector{3, Float64}([0.5, 0.5, 1.0])
# timestepping parameters
# output storage periodicity
const savematstep = 10
# longest allowed computational timestep [s]
const dt_longest = 1.0e+11
# coefficient to decrease computational timestep
const dtcoefdn = 0.5
# coefficient to increase computational timestep
const dtcoefup = 1.2
# number of iterations before changing computational timestep
const dtstep = 200
# max marker movement per time step [grid steps]
const dxymax = 0.05
# weight of averaged velocity for moving markers
const vpratio = 1 / 3
# max temperature change per time step [K]
const DTmax = 20.0
# subgrid temperature diffusion parameter
const dsubgridt = 0.0
# subgrid stress diffusion parameter
const dsubgrids = 0.0
# length of year [s]
const yearlength = 365.25 * 24 * 3600
# time sum (start) [s]
const start_time = 2.25e6 * yearlength
# time sum (end) [s]
const endtime = 15.0e6 * yearlength
# lower viscosity cut-off [Pa s]
const etamin = 1e+12
# upper viscosity cut-off [Pa s]
const etamax = 1e+23
# maximum number of plastic iterations
const nplast = 100_000
# maximum number of global iterations
const titermax = 10_000
# periodicity of visualization
const visstep = 1
# tolerance level for yielding error()
const yerrmax = 1e+2
# weight for old viscosity
const etawt = 0.0
# max porosity ratio change per time step
const dphimax = 100.01
# const dphimax = 0.01
# starting timestep
const start_step = 1
# maximum number of timesteps to run
const n_steps = 10
# const n_steps = 100
# const n_steps = 30_000
# random number generator seed
const seed = 42
# using MKL Pardiso solver
const use_pardiso = false
# MKL Pardiso solver IPARM control parameters -> ∇ATTN: zero-indexed as in docs:
# https://www.intel.com/content/www/us/en/develop/documentation/onemkl-developer-reference-c/top/sparse-solver-routines/onemkl-pardiso-parallel-direct-sparse-solver-iface/pardiso-iparm-parameter.html
const iparms_dict = Dict([
(0, 1), # in: do not use default
(1, 2), # in: nested dissection from METIS
(2, 0), # in: reserved, set to zero
(3, 0), # in: no CGS/CG iterations
(4, 0), # in: no user permutation
(5, 0), # in: write solution on x or RHS b
(6, 0), # out: number of iterative refinement steps performed
(7, 20), # in: maximum number of iterative refinement steps
(8, 0), # in: tolerance level for relative residual, only with iparm[23]=1
(9, 13), # in: pivoting perturbation
(10, 1), # in: scaling vectors
(11, 1), # in: solve AX=B (no transpose, conjugate transpose): CSC matrix
(12, 1), # in: improved accuracy using (non-)symmetric weighted matching
(13, 0), # out: number of perturbed pivots
(14, 0), # out: peak memory on symbolic factorization
(15, 0), # out: permanent memory on symbolic factorization
(16, 0), # out: size of factors/peak memory on symbolic factorization
(17, -1), # in/out: report number of non-zero elements in the factors
(18, -1), # in/out: report the number of FLOPs to factor matrix A
(19, 0), # out: report CG/CGS diagnostics, iterations
(20, 0), # in: pivoting for symmetric indefinite matrices
(21, 0), # out: inertia: number of positive eigenvalues
(22, 0), # out: inertia: number of negative eigenvalues
(23, 10), # in: parallel factorization control, REQ: iparm[10]==iparm[12]==0
(24, 0), # in: parallel forward/backward solve control
(25, 0), # reserved, set to zero
(26, 1), # in: matrix checker: checks ia, ja sorting order
(27, 0), # in: single or double precision
(28, 0), # reserved, set to zero
(29, 0), # out: number of zero or negative pivots
(30, 0), # in: partial solve
(31, 0), # reserved, set to zero
(32, 0), # reserved, set to zero
(33, 0), # in: optimal number of OpenMP threads for CNR mode
(34, 0), # in: one- or zero-based indexing of columns and rows
(35, 0), # in/out: Schur complement matrix computation control
(36, 0), # in: format for matrix storage: CSR or BSR or VBSR
(37, 0), # reserved, set to zero
(38, 0), # in: enable low-rank update for for multiple similar matrices
(39, 0), # reserved, set to zero
(40, 0), # reserved, set to zero
(41, 0), # reserved, set to zero
(42, 0), # in: compute diagonal of inverse matrix
(43, 0), # reserved, set to zero
(44, 0), # reserved, set to zero
(45, 0), # reserved, set to zero
(46, 0), # reserved, set to zero
(47, 0), # reserved, set to zero
(48, 0), # reserved, set to zero
(49, 0), # reserved, set to zero
(50, 0), # reserved, set to zero
(51, 0), # reserved, set to zero
(52, 0), # reserved, set to zero
(53, 0), # reserved, set to zero
(54, 0), # reserved, set to zero
(55, 0), # in: diagonal and pivoting control
(56, 0), # reserved, set to zero
(57, 0), # reserved, set to zero
(58, 0), # reserved, set to zero
(59, 0), # in: in-core (IC) or out-of-core (OOC) PARDISO mode
(60, 0), # reserved, set to zero
(61, 0), # reserved, set to zero
(62, 0), # out: size of the minimum OOC memory for factorization and sol
(63, 0), # reserved, set to zero
])
# MKL Pardiso solver IPARM control parameters formatted for LinearSolve.jl
const iparms = collect(
(key + 1, iparms_dict[key]) for key in sort!(collect(keys(iparms_dict))))
# LinearSolve.jl solver keyword arguments
const cache_kwargs = (;
nprocs = 4,
verbose = true,
abstol = 1e-8,
reltol = 1e-8,
maxiter = 30,
iparm = iparms,
)