Manual
User Manual:
Open the PDF directly: View PDF .
Page Count: 298 [warning: Documents this large are best viewed by clicking the View PDF Link!]
- Introduction
- List of tutorials
- The physical equations
- Strain rate and spin tensor
- The heat transport equation - energy conservation equation
- The momentum conservation equations
- The mass conservation equations
- The equations in ASPECT manual
- The Boussinesq approximation: an Incompressible flow
- Stokes equation for elastic medium
- The strain rate tensor in all coordinate systems
- Boundary conditions
- Meaningful physical quantities
- The need for numerical modelling
- The building blocks of the Finite Element Method
- Solving the heat transport equation with linear Finite Elements
- Solving the flow equations with the FEM
- Strong and weak forms
- Which velocity-pressure pair for Stokes?
- The compatibility condition (or LBB condition)
- Families
- The bi/tri-linear velocity - constant pressure element (Q1P0)
- The bi/tri-quadratic velocity - discontinuous linear pressure element (Q2 P-1)
- The bi/tri-quadratic velocity - bi/tri-linear pressure element (Q2 Q1)
- The stabilised bi/tri-linear velocity - bi/tri-linear pressure element (Q1Q1-stab)
- The MINI triangular element (P1+P1)
- The quadratic velocity - linear pressure triangle (P2P1)
- The Crouzeix-Raviart triangle (P2+P-1)
- The Rannacher-Turek element - rotated Q1P0
- Other elements
- The penalty approach for viscous flow
- The mixed FEM for viscous flow
- Solving the elastic equations
- A quick tour of similar literature
- The case against the Q1P0 element
- Additional techniques and features
- The SUPG formulation for the energy equation
- Dealing with a free surface
- Convergence criterion for nonlinear iterations
- The method of manufactured solutions
- Analytical benchmark I - "Donea & Huerta"
- Analytical benchmark II - "Dohrmann & Bochev 2D"
- Analytical benchmark III - "Dohrmann & Bochev 3D"
- Analytical benchmark IV - "Bercovier & Engelman"
- Analytical benchmark V - "VJ"
- Analytical benchmark VI - "Ilinca & Pelletier"
- Analytical benchmark VII - "grooves"
- Analytical benchmark VIII - "Kovasznay"
- Geodynamical benchmarks
- Assigning values to quadrature points
- Matrix (Sparse) storage
- Mesh generation
- Visco-Plasticity
- Pressure smoothing
- Pressure scaling
- Pressure normalisation
- Solving the Stokes system
- The consistent boundary flux (CBF)
- The value of the timestep
- Mappings
- Exporting data to vtk format
- Runge-Kutta methods
- Am I in or not? - finding reduced coordinates
- Error measurements and convergence rates
- The initial temperature field
- Kinematic boundary conditions
- Computing gradients - the recovery process
- Tracking materials and/or interfaces
- Static condensation
- Measuring incompressibility
- Periodic boundary conditions
- Removing rotational nullspace
- Picard and Newton
- Defect correction formulation
- fieldstone_01: simple analytical solution
- fieldstone_02: Stokes sphere
- fieldstone_03: Convection in a 2D box
- fieldstone_04: The lid driven cavity
- fieldstone_05: SolCx benchmark
- fieldstone_06: SolKz benchmark
- fieldstone_07: SolVi benchmark
- fieldstone_08: the indentor benchmark
- fieldstone_09: the annulus benchmark
- fieldstone_10: Stokes sphere (3D) - penalty
- fieldstone_11: stokes sphere (3D) - mixed formulation
- fieldstone_12: consistent pressure recovery
- fieldstone_13: the Particle in Cell technique (1) - the effect of averaging
- fieldstone_f14: solving the full saddle point problem
- fieldstone_f15: saddle point problem with Schur complement approach - benchmark
- fieldstone_f16: saddle point problem with Schur complement approach - Stokes sphere
- fieldstone_17: solving the full saddle point problem in 3D
- fieldstone_18: solving the full saddle point problem with Q2Q1 elements
- fieldstone_19: solving the full saddle point problem with Q3Q2 elements
- fieldstone_20: the Busse benchmark
- fieldstone_21: The non-conforming Q1 P0 element
- fieldstone_22: The stabilised Q1 Q1 element
- fieldstone_23: compressible flow (1) - analytical benchmark
- fieldstone_24: compressible flow (2) - convection box
- fieldstone_25: Rayleigh-Taylor instability (1) - instantaneous
- fieldstone_26: Slab detachment benchmark (1) - instantaneous
- fieldstone_27: Consistent Boundary Flux
- fieldstone_28: convection 2D box - Tosi et al, 2015
- fieldstone_29: open boundary conditions
- fieldstone_30: conservative velocity interpolation
- fieldstone_31: conservative velocity interpolation 3D
- fieldstone_32: 2D analytical sol. from stream function
- fieldstone_33: Convection in an annulus
- fieldstone_34: the Cartesian geometry elastic aquarium
- fieldstone_35: 2D analytical sol. in annulus from stream function
- fieldstone_36: the annulus geometry elastic aquarium
- fieldstone_37: marker advection and population control
- fieldstone_38: Critical Rayleigh number
- fieldstone_40: Rayleigh-Taylor instability
- fieldstone_42: 1D diffusion
- fieldstone: Gravity: buried sphere
- Problems, to do list and projects for students
- Three-dimensional applications
- Codes in geodynamics
- Matrix properties
- Donâ•Žt be a hero - unless you have to
- A FANTOM, an ELEFANT and a GHOST
- Some useful Python commands
- Some useful maths
The Finite Element Method in Geodynamics
C. Thieulot
June 16, 2019
Contents
1 Introduction 7
1.1 Philosophy ............................................ 7
1.2 Acknowledgments......................................... 7
1.3 Essentialliterature........................................ 7
1.4 Installation ............................................ 7
1.5 Whatisafieldstone?....................................... 8
1.6 Why the Finite Element method? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
1.7 Notations ............................................. 8
1.8 Colour maps for visualisation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
2 List of tutorials 9
3 The physical equations 11
3.1 Strainrateandspintensor ................................... 11
3.2 The heat transport equation - energy conservation equation . . . . . . . . . . . . . . . . . 11
3.3 The momentum conservation equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
3.4 The mass conservation equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
3.5 The equations in ASPECT manual . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
3.6 The Boussinesq approximation: an Incompressible flow . . . . . . . . . . . . . . . . . . . . 14
3.7 Stokes equation for elastic medium . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
3.8 The strain rate tensor in all coordinate systems . . . . . . . . . . . . . . . . . . . . . . . . 16
3.8.1 Cartesiancoordinates .................................. 16
3.8.2 Polarcoordinates..................................... 16
3.8.3 Cylindrical coordinates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
3.8.4 Sphericalcoordinates................................... 16
3.9 Boundaryconditions....................................... 17
3.9.1 TheStokesequations................................... 17
3.9.2 The heat transport equation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
3.10 Meaningful physical quantities . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
3.11 The need for numerical modelling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
4 The building blocks of the Finite Element Method 21
4.1 Numericalintegration ...................................... 21
4.1.1 in1D-theory ...................................... 21
4.1.2 in1D-examples..................................... 23
4.1.3 in2D/3D-theory .................................... 24
4.2 Themesh ............................................. 24
4.3 AbitofFEterminology..................................... 24
4.4 Elements and basis functions in 1D . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
4.4.1 Linear basis functions (Q1) ............................... 25
4.4.2 Quadratic basis functions (Q2) ............................. 25
4.4.3 Cubic basis functions (Q3) ............................... 26
4.5 Elements and basis functions in 2D . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
1
4.5.1 Bilinear basis functions in 2D (Q1)........................... 29
4.5.2 Biquadratic basis functions in 2D (Q2)......................... 31
4.5.3 Eight node serendipity basis functions in 2D (Q(8)
2).................. 32
4.5.4 Bicubic basis functions in 2D (Q3) ........................... 33
4.5.5 Linear basis functions for triangles in 2D (P1)..................... 34
4.5.6 Quadratic basis functions for triangles in 2D (P2)................... 34
4.5.7 Cubic basis functions for triangles (P3) ........................ 35
4.6 Elements and basis functions in 3D . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
4.6.1 Linear basis functions in tetrahedra (P1)........................ 36
4.6.2 Triquadratic basis functions in 3D (Q2) ........................ 37
5 Solving the heat transport equation with linear Finite Elements 38
5.1 Thediffusionequationin1D .................................. 38
5.2 The advection-diffusion equation in 1D . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
5.3 The advection-diffusion equation in 2D . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
6 Solving the flow equations with the FEM 50
6.1 Strongandweakforms...................................... 50
6.2 Which velocity-pressure pair for Stokes? . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
6.2.1 The compatibility condition (or LBB condition) . . . . . . . . . . . . . . . . . . . . 50
6.2.2 Families.......................................... 50
6.2.3 The bi/tri-linear velocity - constant pressure element (Q1×P0)........... 51
6.2.4 The bi/tri-quadratic velocity - discontinuous linear pressure element (Q2×P−1) . 51
6.2.5 The bi/tri-quadratic velocity - bi/tri-linear pressure element (Q2×Q1) ...... 51
6.2.6 The stabilised bi/tri-linear velocity - bi/tri-linear pressure element (Q1×Q1-stab) 52
6.2.7 The MINI triangular element (P+
1×P1)........................ 52
6.2.8 The quadratic velocity - linear pressure triangle (P2×P1).............. 52
6.2.9 The Crouzeix-Raviart triangle (P+
2×P−1) ...................... 52
6.2.10 The Rannacher-Turek element - rotated Q1×P0................... 53
6.2.11 Otherelements...................................... 53
6.3 The penalty approach for viscous flow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
6.4 The mixed FEM for viscous flow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
6.4.1 inthreedimensions.................................... 56
6.4.2 Goingfrom3Dto2D .................................. 61
6.5 Solving the elastic equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
6.6 A quick tour of similar literature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
6.7 The case against the Q1×P0element ............................. 63
7 Additional techniques and features 65
7.1 The SUPG formulation for the energy equation . . . . . . . . . . . . . . . . . . . . . . . . 65
7.2 Dealingwithafreesurface.................................... 65
7.3 Convergence criterion for nonlinear iterations . . . . . . . . . . . . . . . . . . . . . . . . . 65
7.4 The method of manufactured solutions . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
7.4.1 Analytical benchmark I - ”Donea & Huerta” . . . . . . . . . . . . . . . . . . . . . 66
7.4.2 Analytical benchmark II - ”Dohrmann & Bochev 2D” . . . . . . . . . . . . . . . . 67
7.4.3 Analytical benchmark III - ”Dohrmann & Bochev 3D” . . . . . . . . . . . . . . . . 68
7.4.4 Analytical benchmark IV - ”Bercovier & Engelman” . . . . . . . . . . . . . . . . . 69
7.4.5 Analytical benchmark V - ”VJ” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
7.4.6 Analytical benchmark VI - ”Ilinca & Pelletier” . . . . . . . . . . . . . . . . . . . . 70
7.4.7 Analytical benchmark VII - ”grooves” . . . . . . . . . . . . . . . . . . . . . . . . . 71
7.4.8 Analytical benchmark VIII - ”Kovasznay” . . . . . . . . . . . . . . . . . . . . . . . 73
7.5 Geodynamicalbenchmarks ................................... 74
7.6 Assigning values to quadrature points . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
7.7 Matrix(Sparse)storage ..................................... 78
7.7.1 2D domain - One degree of freedom per node . . . . . . . . . . . . . . . . . . . . . 78
7.7.2 2D domain - Two degrees of freedom per node . . . . . . . . . . . . . . . . . . . . 79
2
7.7.3 infieldstone........................................ 80
7.8 Meshgeneration ......................................... 81
7.8.1 Quadrilateral-based meshes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
7.8.2 Delaunay triangulation and Voronoi cells . . . . . . . . . . . . . . . . . . . . . . . 82
7.8.3 Tetrahedra ........................................ 83
7.8.4 Hexahedra ........................................ 83
7.8.5 Adaptive Mesh Refinement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
7.9 Visco-Plasticity.......................................... 87
7.9.1 Tensorinvariants..................................... 87
7.9.2 Scalarviscoplasticity................................... 88
7.9.3 About the yield stress value Y............................. 88
7.10Pressuresmoothing........................................ 89
7.11Pressurescaling.......................................... 91
7.12Pressurenormalisation...................................... 92
7.12.1 Basic idea and naive implementation . . . . . . . . . . . . . . . . . . . . . . . . . . 92
7.12.2 Implementation – the real deal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
7.13SolvingtheStokessystem .................................... 93
7.13.1 when using the penalty formulation . . . . . . . . . . . . . . . . . . . . . . . . . . 93
7.13.2 Conjugate gradient and the Schur complement approach . . . . . . . . . . . . . . 93
7.13.3 Conjugate gradient and the Schur complement approach . . . . . . . . . . . . . . 95
7.13.4 The Augmented Lagrangian approach . . . . . . . . . . . . . . . . . . . . . . . . . 99
7.13.5 TheGMRESapproach.................................. 100
7.14 The consistent boundary flux (CBF) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
7.14.1 applied to the Stokes equation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
7.14.2 applied to the heat equation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
7.14.3 implementation - Stokes equation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102
7.15Thevalueofthetimestep .................................... 104
7.16Mappings ............................................. 105
7.16.1 Onatriangle ....................................... 105
7.17 Exporting data to vtk format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106
7.18Runge-Kuttamethods ...................................... 108
7.18.1 Using RK methods to advect particles/markers . . . . . . . . . . . . . . . . . . . . 108
7.19 Am I in or not? - finding reduced coordinates . . . . . . . . . . . . . . . . . . . . . . . . . 110
7.19.1 Two-dimensional space . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110
7.19.2 Three-dimensional space . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110
7.20 Error measurements and convergence rates . . . . . . . . . . . . . . . . . . . . . . . . . . 113
7.20.1 Aboutextrapolation ................................... 114
7.21 The initial temperature field . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115
7.21.1 Single layer with imposed temperature b.c. . . . . . . . . . . . . . . . . . . . . . . 115
7.21.2 Single layer with imposed heat flux b.c. . . . . . . . . . . . . . . . . . . . . . . . . 116
7.21.3 Single layer with imposed heat flux and temperature b.c. . . . . . . . . . . . . . . 116
7.21.4 Halfcoolingspace .................................... 116
7.21.5 Platemodel........................................ 116
7.21.6 McKenzieslab ...................................... 116
7.22 Kinematic boundary conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 120
7.22.1 In-out flux boundary conditions for lithospheric models . . . . . . . . . . . . . . . 120
7.23 Computing gradients - the recovery process . . . . . . . . . . . . . . . . . . . . . . . . . . 121
7.23.1 Globalrecovery...................................... 121
7.23.2 Local recovery - centroid average over patch . . . . . . . . . . . . . . . . . . . . . . 121
7.23.3 Local recovery - nodal average over patch . . . . . . . . . . . . . . . . . . . . . . . 121
7.23.4 Local recovery - least squares over patch . . . . . . . . . . . . . . . . . . . . . . . . 121
7.23.5 Link to pressure smoothing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121
7.24 Tracking materials and/or interfaces . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122
7.24.1 The Particle-in-cell technique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122
7.24.2 The level set function technique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122
7.24.3 The field/composition technique . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122
3
7.24.4 Hybridmethods ..................................... 122
7.25Staticcondensation........................................ 123
7.26 Measuring incompressibility . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124
7.27 Periodic boundary conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125
7.28 Removing rotational nullspace . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126
7.28.1 Threedimensions..................................... 127
7.28.2 Twodimensions ..................................... 127
7.29PicardandNewton ....................................... 129
7.29.1 Picarditerations ..................................... 129
7.30 Defect correction formulation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130
8fieldstone 01: simple analytical solution 131
9fieldstone 02: Stokes sphere 133
10 fieldstone 03: Convection in a 2D box 134
11 fieldstone 04: The lid driven cavity 137
11.1 the lid driven cavity problem (ldc=0) ............................. 137
11.2 the lid driven cavity problem - regularisation I (ldc=1).................... 137
11.3 the lid driven cavity problem - regularisation II (ldc=2) ................... 137
12 fieldstone 05: SolCx benchmark 139
13 fieldstone 06: SolKz benchmark 141
14 fieldstone 07: SolVi benchmark 142
15 fieldstone 08: the indentor benchmark 144
16 fieldstone 09: the annulus benchmark 146
17 fieldstone 10: Stokes sphere (3D) - penalty 148
18 fieldstone 11: stokes sphere (3D) - mixed formulation 149
19 fieldstone 12: consistent pressure recovery 150
20 fieldstone 13: the Particle in Cell technique (1) - the effect of averaging 152
21 fieldstone f14: solving the full saddle point problem 156
22 fieldstone f15: saddle point problem with Schur complement approach - benchmark
159
23 fieldstone f16: saddle point problem with Schur complement approach - Stokes
sphere 162
24 fieldstone 17: solving the full saddle point problem in 3D 164
24.0.1 Constantviscosity .................................... 166
24.0.2 Variableviscosity..................................... 167
25 fieldstone 18: solving the full saddle point problem with Q2×Q1elements 169
26 fieldstone 19: solving the full saddle point problem with Q3×Q2elements 171
27 fieldstone 20: the Busse benchmark 173
28 fieldstone 21: The non-conforming Q1×P0element 175
4
29 fieldstone 22: The stabilised Q1×Q1element 176
29.1 The Donea & Huerta benchmark . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 178
29.2 The Dohrmann & Bochev benchmark . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179
29.3 The falling block experiment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179
30 fieldstone 23: compressible flow (1) - analytical benchmark 180
31 fieldstone 24: compressible flow (2) - convection box 183
31.1Thephysics ............................................ 183
31.2Thenumerics ........................................... 183
31.3Theexperimentalsetup ..................................... 185
31.4Scaling............................................... 185
31.5Conservationofenergy1..................................... 186
31.5.1 under BA and EBA approximations . . . . . . . . . . . . . . . . . . . . . . . . . . 186
31.5.2 under no approximation at all . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 187
31.6Conservationofenergy2..................................... 187
31.7 The problem of the onset of convection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 188
31.8 results - BA - Ra = 104..................................... 190
31.9 results - BA - Ra = 105..................................... 192
31.10results - BA - Ra = 106..................................... 193
31.11results - EBA - Ra = 104.................................... 194
31.12results - EBA - Ra = 105.................................... 196
31.13Onsetofconvection........................................ 197
32 fieldstone 25: Rayleigh-Taylor instability (1) - instantaneous 199
33 fieldstone 26: Slab detachment benchmark (1) - instantaneous 201
34 fieldstone 27: Consistent Boundary Flux 203
35 fieldstone 28: convection 2D box - Tosi et al, 2015 207
35.0.1 Case 0: Newtonian case, a la Blankenbach et al., 1989 . . . . . . . . . . . . . . . . 208
35.0.2 Case1........................................... 209
35.0.3 Case2........................................... 211
35.0.4 Case3........................................... 213
35.0.5 Case4........................................... 215
35.0.6 Case5........................................... 217
36 fieldstone 29: open boundary conditions 219
37 fieldstone 30: conservative velocity interpolation 222
37.1Couetteflow............................................ 222
37.2SolCx ............................................... 222
37.3Streamlineflow.......................................... 222
38 fieldstone 31: conservative velocity interpolation 3D 223
39 fieldstone 32: 2D analytical sol. from stream function 224
39.1Backgroundtheory........................................ 224
39.2Asimpleapplication ....................................... 224
40 fieldstone 33: Convection in an annulus 228
41 fieldstone 34: the Cartesian geometry elastic aquarium 230
5
42 fieldstone 35: 2D analytical sol. in annulus from stream function 232
42.1Linkingwithourpaper...................................... 235
42.2 No slip boundary conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235
42.3 Free slip boundary conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236
43 fieldstone 36: the annulus geometry elastic aquarium 238
44 fieldstone 37: marker advection and population control 241
45 fieldstone 38: Critical Rayleigh number 242
46 fieldstone 40: Rayleigh-Taylor instability 244
47 fieldstone 42: 1D diffusion 246
48 fieldstone: Gravity: buried sphere 247
49 Problems, to do list and projects for students 249
A Three-dimensional applications 251
B Codes in geodynamics 252
C Matrix properties 255
C.1 Symmetricmatrices ....................................... 255
C.2 Schurcomplement ........................................ 255
D Dont be a hero - unless you have to 257
E A FANTOM, an ELEFANT and a GHOST 259
F Some useful Python commands 262
F.1 Sparsematrices.......................................... 262
F.2 conditionnumber......................................... 262
G Some useful maths 263
G.1 Inverseofa3x3matrix ..................................... 263
G.2 Inverseofa3x3matrix ..................................... 263
6
WARNING: this is work in progress
1 Introduction
1.1 Philosophy
This document was writing with my students in mind, i.e. 3rd and 4th year Geology/Geophysics students
at Utrecht University. I have chosen to use as little jargon as possible unless it is a term that is commonly
found in the geodynamics literature (methods paper as well as application papers). There is no mathe-
matical proof of any theorem or statement I make. These are to be found in generic Numerical Analysic,
Finite Element and Linear Algebra books. If you find that this books lacks references to Sobolev spaces,
Hilbert spaces, and other spaces, this book is just not for you.
The codes I provide here are by no means optimised as I value code readability over code efficiency. I
have also chosen to avoid resorting to multiple code files or even functions to favour a sequential reading of
the codes. These codes are not designed to form the basis of a real life application: Existing open source
highly optimised codes shoud be preferred, such as ASPECT [339, 282], CITCOM, LAMEM, PTATIN,
PYLITH, ...
All kinds of feedback is welcome on the text (grammar, typos, ...) or on the code(s). You will have
my eternal gratitude if you wish to contribute an example, a benchmark, a cookbook.
All the python scripts and this document are freely available at
https://github.com/cedrict/fieldstone
1.2 Acknowledgments
I have benefitted from many discussions, lectures, tutorials, coffee machine discussions, debugging ses-
sions, conference poster sessions, etc ... over the years. I wish to name these instrumental people in
particular and in alphabetic order: Wolfgang Bangerth, Jean Braun, Rens Elbertsen, Philippe Fullsack,
Menno Fraters, Anne Glerum, Timo Heister, Robert Myhill, John Naliboff, E. Gerry Puckett, Melchior
Schuh-Senlis, Lukas van de Wiel, Arie van den Berg, Tom Weir, and the whole ASPECT family/team.
1.3 Essential literature
http://www-udc.ig.utexas.edu/external/becker/Geodynamics557.pdf
1.4 Installation
If numpy, scipy or matplotlib are not installed on your machine, here is how you can install them:
python3.6 -m pip install --user numpy scipy matplotlib
To install the umfpack solver:
pip install --upgrade scikit-umfpack --user
7
1.5 What is a fieldstone?
Simply put, it is stone collected from the surface of fields where it occurs naturally. It also stands for the
bad acronym: finite element deformation of stones which echoes the primary application of these codes:
geodynamic modelling.
1.6 Why the Finite Element method?
The Finite Element Method (FEM) is by no means the only method to solve PDEs in geodynamics, nor
is it necessarily the best one. Other methods are employed very succesfully, such as the Finite Difference
Method (FDM), the Finite Volume Method (FVM), and to a lesser extent the Discrete Element Method
(DEM) [166, 167, 208], or the Element Free Galerkin Method (EFGM) [276]. I have been using FEM
since 2008 and I do not have real experience to speak of in FVM or FDM so I concentrate in this book
on what I know best.
1.7 Notations
Scalars such as temperature, density, pressure, etc ... are simply obtained in L
A
T
E
X by using the math
mode, e.g. T,ρ,p. Although it is common to lump vectors and matrices/tensors together by using bold
fonts, I have decided in the interest of clarity to distinguish between those: vectors are denoted by an
arrow atop the quantity, e.g.
ν,g, while matrices and tensors are in bold M,σ, etc ...
Also I use the ·notation between two vectors to denote a dot product u ·v =uivior a matrix-vector
multiplication M·a =Mij aj. If there is no ·between vectors, it means that the result a
b=aibjis a
matrix (it is a dyadic product1. Case in point,
∇ ·
νis the velocity divergence while
∇
νis the velocity
gradient tensor.
1.8 Colour maps for visualisation
In an attempt to homogenise the figures obtained with ParaView, I have decided to use a fixed colour
scale for each field throughout this document. These colour scales were obtained from this link and are
Perceptually Uniform Colour Maps [338].
Field colour code
Velocity/displacement CET-D1A
Pressure CET-L17
Velocity divergence CET-L1
Density CET-D3
Strain rate CET-R2
Viscosity CET-R3
Temperature CET-D9
1https://en.wikipedia.org/wiki/Dyadics
8
2 List of tutorials
tutorial number
element outer solver formulation physical problem
3D
temperature
time stepping
nonlinear
compressible
analytical benchmark
numerical benchmark
elastomechanics
1Q1×P0penalty analytical benchmark †
2Q1×P0penalty Stokes sphere
3Q1×P0penalty Blankenbach et al., 1989 † †
4Q1×P0penalty Lid driven cavity
5Q1×P0penalty SolCx benchmark
6Q1×P0penalty SolKz benchmark
7Q1×P0penalty SolVi benchmark
8Q1×P0penalty Indentor †
9Q1×P0penalty annulus benchmark
10 Q1×P0penalty Stokes sphere †
11 Q1×P0full matrix mixed Stokes sphere †
12 Q1×P0penalty analytical benchmark
+ consistent press recovery
13 Q1×P0penalty Stokes sphere
+ markers averaging
14 Q1×P0full matrix mixed analytical benchmark
15 Q1×P0Schur comp. CG mixed analytical benchmark
16 Q1×P0Schur comp. PCG mixed Stokes sphere
17 Q2×Q1full matrix mixed Burstedde benchmark †
18 Q2×Q1full matrix mixed analytical benchmark
19 Q3×Q2full matrix mixed analytical benchmark
20 Q1×P0penalty Busse et al., 1993 †††
21 Q1×P0R-T penalty analytical benchmark
22 Q1×Q1-
stab
full matrix mixed analytical benchmark
23 Q1×P0mixed analytical benchmark †
24 Q1×P0mixed convection box † † †
9
tutorial number
element outer solver formulation physical problem
3D
temperature
time stepping
nonlinear
compressible
analytical benchmark
numerical benchmark
elastomechanics
25 Q1×P0full matrix mixed Rayleigh-Taylor instability
26 Q1×P0full matrix mixed Slab detachment †
27 Q1×P0full matrix mixed CBF benchmarks † †
28 Q1×P0full matrix mixed Tosi et al, 2015 † † † †
29 Q1×P0full matrix mixed Open Boundary conditions †
30 Q1, Q2X X Cons. Vel. Interp (cvi) † †
31 Q1, Q2X X Cons. Vel. Interp (cvi) † † †
32 Q1×P0full matrix mixed analytical benchmark †
33 Q1×P0penalty convection in annulus †††
34 Q1elastic Cartesian aquarium † † †
35
36 Q1elastic annulus aquarium † † †
37 Q1, Q2X X population control, bmw test † †
38 Critical Rayleigh number
39 Q2×Q1full matrix mixed
XX
Analytical benchmark means that an analytical solution exists while numerical benchmark means that a comparison with other code(s) has been carried
out.
10
3 The physical equations
Symbol meaning unit
tTime s
x, y, z Cartesian coordinates m
r, θ Polar coordinates m,-
r, θ, z Cylindrical coordinates m,-,m
r, θ, φ Spherical coordinates m,-,-
νvelocity vector m·s−1
ρmass density kg/m3
ηdynamic viscosity Pa·s
λpenalty parameter Pa·s
Ttemperature K
∇gradient operator m−1
∇· divergence operator m−1
ppressure Pa
˙
ε(
ν) strain rate tensor s−1
αthermal expansion coefficient K−1
kthermal conductivity W/(m ·K)
CpHeat capacity J/K
Hintrinsic specific heat production W/kg
βTisothermal compressibility Pa−1
τdeviatoric stress tensor Pa
σfull stress tensor Pa
3.1 Strain rate and spin tensor
The velocity gradient is given in Cartesian coordinates by:
∇
ν=
∂u
∂x
∂v
∂x
∂w
∂x
∂u
∂y
∂v
∂y
∂w
∂y
∂u
∂z
∂v
∂z
∂w
∂z
It can be decomposed into its symmetric and skew-symmetric parts according to:
∇
ν=
∇s
ν+
∇w
ν
The symmetric part is called the strain rate (or rate of deformation):
˙
(
ν) = 1
2
∇
ν+
∇
νT
The skew-symmetric tensor is called spin tensor (or vorticity tensor):
˙
R(
ν) = 1
2
∇
ν−
∇
νT
3.2 The heat transport equation - energy conservation equation
Let us start from the heat transport equation as shown in Schubert, Turcotte and Olson [476]:
ρCp
DT
Dt −αT Dp
Dt =
∇ · k
∇T+Φ+ρH
with D/Dt being the total derivatives so that
DT
Dt =∂T
∂t +
ν·
∇TDp
Dt =∂p
∂t +
ν·
∇p
Solving for temperature, this equation is often rewritten as follows:
11
ρCp
DT
Dt −
∇ · k
∇T=αT Dp
Dt +Φ+ρH
A note on the shear heating term Φ: In many publications, Φ is given by Φ = τij ∂jui=τ:
∇
ν.
Φ = τij ∂jui
= 2η˙εd
ij ∂jui
= 2η1
2˙εd
ij ∂jui+ ˙εd
ji∂iuj
= 2η1
2˙εd
ij ∂jui+ ˙εd
ij ∂iuj
= 2η˙εd
ij
1
2(∂jui+∂iuj)
= 2η˙εd
ij ˙εij
= 2η˙
εd:˙
ε
= 2η˙
εd:˙
εd+1
3(
∇ ·
ν)1
= 2η˙
εd:˙
εd+ 2η˙
εd:1(
∇ ·
ν)
= 2η˙
εd:˙
εd(1)
Finally
Φ = τ:
∇
ν= 2η˙
εd:˙
εd= 2η( ˙εd
xx)2+ ( ˙εd
yy)2+ 2( ˙εd
xy)2
3.3 The momentum conservation equations
Because the Prandlt number is virtually zero in Earth science applications the Navier Stokes equations
reduce to the Stokes equation:
∇ · σ+ρg = 0
Since
σ=−p1+τ
it also writes
−
∇p+
∇ · τ+ρg = 0
Using the relationship τ= 2η˙
εdwe arrive at
−
∇p+
∇ · (2η˙
εd) + ρg = 0
3.4 The mass conservation equations
The mass conservation equation is given by
Dρ
Dt +ρ
∇ ·
ν= 0
or,
∂ρ
∂t +
∇ · (ρ
ν)=0
In the case of an incompressible flow, then ∂ρ/∂t = 0 and
∇ρ= 0, i.e. Dρ/Dt = 0 and the remaining
equation is simply:
∇ ·
ν= 0
12
3.5 The equations in ASPECT manual
The following is lifted off the ASPECT manual. We focus on the system of equations in a d= 2- or
d= 3-dimensional domain Ω that describes the motion of a highly viscous fluid driven by differences in
the gravitational force due to a density that depends on the temperature. In the following, we largely
follow the exposition of this material in Schubert, Turcotte and Olson [476].
Specifically, we consider the following set of equations for velocity u, pressure pand temperature T:
−
∇ · 2η˙
ε(
ν)−1
3(
∇ ·
ν)1+
∇p=ρg in Ω,(2)
∇ · (ρv) = 0 in Ω,(3)
ρCp∂T
∂t +
ν·
∇T−
∇ · k
∇T=ρH
+ 2η˙ε(v)−1
3(
∇ ·
ν)1:˙ε(v)−1
3(
∇ ·
ν)1(4)
+αT v·
∇pin Ω,
where ˙
ε(
ν) = 1
2(
∇
ν+
∇
νT) is the symmetric gradient of the velocity (often called the strain rate).
In this set of equations, (367) and (368) represent the compressible Stokes equations in which v=
v(x, t) is the velocity field and p=p(x, t) the pressure field. Both fields depend on space xand time
t. Fluid flow is driven by the gravity force that acts on the fluid and that is proportional to both the
density of the fluid and the strength of the gravitational pull.
Coupled to this Stokes system is equation (369) for the temperature field T=T(x, t) that contains
heat conduction terms as well as advection with the flow velocity v. The right hand side terms of this
equation correspond to
•internal heat production for example due to radioactive decay;
•friction (shear) heating;
•adiabatic compression of material;
In order to arrive at the set of equations that ASPECT solves, we need to
•neglect the ∂p/∂t.WHY?
•neglect the ∂ρ/∂t .WHY?
from equations above.
—————————————-
Also, their definition of the shear heating term Φ is:
Φ = kB(∇·v)2+ 2η˙
εd:˙
εd
For many fluids the bulk viscosity kBis very small and is often taken to be zero, an assumption known
as the Stokes assumption: kB=λ+ 2η/3 = 0. Note that ηis the dynamic viscosity and λthe second
viscosity. Also,
τ= 2η˙
ε+λ(∇·v)1
but since kB=λ+ 2η/3 = 0, then λ=−2η/3 so
τ= 2η˙
ε−2
3η(∇·v)1= 2η˙
εd
13
3.6 The Boussinesq approximation: an Incompressible flow
[from Aspect manual] The Boussinesq approximation assumes that the density can be considered con-
stant in all occurrences in the equations with the exception of the buoyancy term on the right hand side
of (367). The primary result of this assumption is that the continuity equation (368) will now read
∇·v= 0
This implies that the strain rate tensor is deviatoric. Under the Boussinesq approximation, the equations
are much simplified:
−∇ · [2η˙
ε(v)] + ∇p=ρgin Ω,(5)
∇ · (ρv) = 0 in Ω,(6)
ρ0Cp∂T
∂t +v· ∇T−∇·k∇T=ρH in Ω (7)
Note that all terms on the rhs of the temperature equations have disappeared, with the exception of the
source term.
14
3.7 Stokes equation for elastic medium
What follows is mostly borrowed from Becker & Kaus lecture notes.
The strong form of the PDE that governs force balance in a medium is given by
∇·σ+f=0
where σis the stress tensor and fis a body force.
The stress tensor is related to the strain tensor through the generalised Hooke’s law:
σij =X
kl
Cijklkl (8)
where Cis the fourth-order elastic tensor. In the case of an isotropic material, this relationship simplifies
to
σij =λkkδij + 2µij or, σ=λ(∇·u)1+ 2µ(9)
where λis the Lam´e parameter and µis the shear modulus2. The term ∇·uis the isotropic dilation.
The strain tensor is related to the displacement as follows:
=1
2(∇u+∇uT)
The incompressibility (bulk modulus), K, is defined as p=−K∇·uwhere pis the pressure with
p=−1
3T r(σ)
=−1
3[λ(∇·u)T r[1]+2µT r[]]
=−1
3[λ(∇·u)3 + 2µ(∇·u)]
=−[λ+2
3µ](∇·u) (10)
so that K=λ+2
3µ.
Remark. Eq. (8) and (9) are analogous to the ones that one has to solve in the context of viscous flow
using the penalty method. In this case λis the penalty coefficient, uis the velocity, and µis then the
dynamic viscosity.
The Lam´e parameter and the shear modulus are also linked to νthe poisson ratio, and E, Young’s
modulus:
λ=µ2ν
1−2ν=νE
(1 + ν)(1 −2ν)with E= 2µ(1 + ν)
The shear modulus, expressed often in GPa, describes the material’s response to shear stress. The poisson
ratio describes the response in the direction orthogonal to uniaxial stress. The Young modulus, expressed
in GPa, describes the material’s strain response to uniaxial stress in the direction of this stress.
2It is also sometimes written G
15
3.8 The strain rate tensor in all coordinate systems
The strain rate tensor ˙
εis given by
˙
ε=1
2(
∇
ν+
∇
νT) (11)
3.8.1 Cartesian coordinates
˙εxx =∂u
∂x (12)
˙εyy =∂v
∂y (13)
˙εzz =∂w
∂z (14)
˙εyx = ˙εxy =1
2∂u
∂y +∂v
∂x (15)
˙εzx = ˙εxz =1
2∂u
∂z +∂w
∂x (16)
˙εzy = ˙εyz =1
2∂v
∂z +∂w
∂y (17)
3.8.2 Polar coordinates
˙εrr =∂vr
∂r (18)
˙εθθ =vr
r+1
r
∂vθ
∂θ (19)
˙εθr = ˙εrθ =1
2∂vθ
∂r −vθ
r+1
r
∂vr
∂θ (20)
3.8.3 Cylindrical coordinates
http://eml.ou.edu/equation/FLUIDS/STRAIN/STRAIN.HTM
3.8.4 Spherical coordinates
˙εrr =∂vr
∂r (21)
˙εθθ =vr
r+1
r
∂vθ
∂θ (22)
˙εφφ =1
rsin θ
∂vφ
∂φ (23)
˙εθr = ˙εrθ =1
2r∂
∂r (vθ
r) + 1
r
∂vr
∂θ (24)
˙εφr = ˙εrφ =1
21
rsin θ
∂vr
∂φ +r∂
∂r (vφ
r)(25)
˙εφθ = ˙εθφ =1
2sin θ
r
∂
∂θ (vφ
sin θ) + 1
rsin θ
∂vθ
∂φ (26)
16
3.9 Boundary conditions
In mathematics, the Dirichlet (or first-type) boundary condition is a type of boundary condition, named
after Peter Gustav Lejeune Dirichlet. When imposed on an ODE or PDE, it specifies the values that a
solution needs to take on along the boundary of the domain. Note that a Dirichlet boundary condition
may also be referred to as a fixed boundary condition.
The Neumann (or second-type) boundary condition is a type of boundary condition, named after Carl
Neumann. When imposed on an ordinary or a partial differential equation, the condition specifies the
values in which the derivative of a solution is applied within the boundary of the domain.
It is possible to describe the problem using other boundary conditions: a Dirichlet boundary condition
specifies the values of the solution itself (as opposed to its derivative) on the boundary, whereas the Cauchy
boundary condition, mixed boundary condition and Robin boundary condition are all different types of
combinations of the Neumann and Dirichlet boundary conditions.
3.9.1 The Stokes equations
You may find the following terms in the computational geodynamics literature:
•free surface: this means that no force is acting on the surface, i.e. σ·n =
0. It is usually used on
the top boundary of the domain and allows for topography evolution.
•free slip:
ν·n = 0 and (σ·n)×n =
0. This condition ensures a frictionless flow parallel to the
boundary where it is prescribed.
•no slip: this means that the velocity (or displacement) is exactly zero on the boundary, i.e.
ν=
0.
•prescribed velocity:
ν=
νbc
•stress b.c.:
•open .b.c.: see fieldstone 29.
3.9.2 The heat transport equation
There are two types of boundary conditions for this equation: temperature boundary conditions (Dirichlet
boundary conditions) and heat flux boundary conditions (Neumann boundary conditions).
17
3.10 Meaningful physical quantities
•Velocity (m/s):
•Root mean square velocity (m/s):
νrms =RΩ|
ν|2dΩ
RΩdΩ1/2
=1
VΩZΩ|
ν|2dΩ1/2
(27)
Remark. VΩis usually computed numerically at the same time νvrms is computed.
In Cartesian coordinates, for a cuboid domain of size Lx ×Ly×Lz, the νrms is simply given by:
νrms = 1
LxLyLzZLx
0ZLy
0ZLz
0
(u2+v2+w2)dxdydz!1/2
(28)
In the case of an annulus domain, although calculations are carried out in Cartesian coordinates,
it makes sense to look at the radial velocity component vrand the tangential velocity component
vθ, and their respective root mean square averages:
vr|rms =1
VΩZΩ
v2
rdΩ1/2
(29)
vθ|rms =1
VΩZΩ
v2
θdΩ1/2
(30)
•Pressure (Pa):
•Stress (Pa):
•Strain (X):
•Strain rate (s−1):
•Rayleigh number (X):
•Prandtl number (X):
•Nusselt number (X): the Nusselt number (Nu) is the ratio of convective to conductive heat transfer
across (normal to) the boundary. The conductive component is measured under the same conditions
as the heat convection but with a (hypothetically) stagnant (or motionless) fluid.
In practice the Nusselt number Nu of a layer (typically the mantle of a planet) is defined as follows:
Nu = q
qc
(31)
where qis the heat transferred by convection while qc=k∆T/D is the amount of heat that would
be conducted through a layer of thickness Dwith a temperature difference ∆Tacross it with k
being the thermal conductivity.
For 2D Cartesian systems of size (Lx,Ly) the Nu is computed [61]
Nu =
1
LxRLx
0k∂T
∂y (x, y =Ly)dx
−1
LxRLx
0kT (x, y = 0)/Lydx =−LyRLx
0
∂T
∂y (x, y =Ly)dx
RLx
0T(x, y = 0)dx
i.e. it is the mean surface temperature gradient over the mean bottom temperature.
finish. not happy with definition. Look at literature
Note that in the case when no convection takes place then the measured heat flux at the top is the
one obtained from a purely conductive profile which yields Nu=1.
18
Note that a relationship Ra ∝Nuαexists between the Rayleigh number Ra and the Nusselt number
Nu in convective systems, see [576] and references therein.
Turning now to cylindrical geometries with inner radius R1and outer radius R2, we define f=
R1/R2. A small value of fcorresponds to a high degree of curvature. We assume now that
R2−R1= 1, so that R2= 1/(1 −f) and R1=f/(1 −f). Following [309], the Nusselt number at
the inner and outer boundaries are:
Nuinner =fln f
1−f
1
2πZ2π
0∂T
∂r r=R1
dθ (32)
Nuouter =ln f
1−f
1
2πZ2π
0∂T
∂r r=R2
dθ (33)
Note that a conductive geotherm in such an annulus between temperatures T1and T2is given by
Tc(r) = ln(r/R2)
ln(R1/R2)=ln(r(1 −f))
ln f
so that ∂Tc
∂r =1
r
1
ln f
We then find:
Nuinner =fln f
1−f
1
2πZ2π
0∂Tc
∂r r=R1
dθ =fln f
1−f
1
R1
1
ln f= 1 (34)
Nuouter =ln f
1−f
1
2πZ2π
0∂Tc
∂r r=R2
dθ =ln f
1−f
1
R2
1
ln f= 1 (35)
As expected, the recovered Nusselt number at both boundaries is exactly 1 when the temperature
field is given by a steady state conductive geotherm.
derive formula for Earth size R1 and R2
•Temperature (K):
•Viscosity (Pa.s):
•Density (kg/m3):
•Heat capacity cp(J.K−1.kg−1): It is the measure of the heat energy required to increase the
temperature of a unit quantity of a substance by unit degree.
•Heat conductivity, or thermal conductivity k(W.m−1.K−1). It is the property of a material that
indicates its ability to conduct heat. It appears primarily in Fourier’s Law for heat conduction.
•Heat diffusivity: κ=k/(ρcp) (m2.s−1). Substances with high thermal diffusivity rapidly adjust
their temperature to that of their surroundings, because they conduct heat quickly in comparison
to their volumetric heat capacity or ’thermal bulk’.
•thermal expansion α(K−1): it is the tendency of a matter to change in volume in response to a
change in temperature.
check aspect manual The 2D cylindrical shell benchmarks by Davies et al. 5.4.12
19
3.11 The need for numerical modelling
The gouverning equations we have seen in this chapter require the use of numerical solution techniques
for three main reasons:
•the advection term in the energy equation couples velocity and temperature;
•the constitutive law (the relationship between stress and strain rate) often depends on velocity (or
rather, strain rate), temperature, pressure, ...
•Even when the coefficients of the PDE’s are linear, often their spatial variability, coupled to poten-
tially complex domain geometries prevent arriving at the analytical solution.
20
4 The building blocks of the Finite Element Method
4.1 Numerical integration
As we will see later, using the Finite Element method to solve problems involves computing integrals
which are more often than not too complex to be computed analytically/exactly. We will then need to
compute them numerically.
[wiki] In essence, the basic problem in numerical integration is to compute an approximate solution
to a definite integral Zb
a
f(x)dx
to a given degree of accuracy. This problem has been widely studied and we know that if f(x) is a
smooth function, and the domain of integration is bounded, there are many methods for approximating
the integral to the desired precision.
There are several reasons for carrying out numerical integration.
•The integrand f(x) may be known only at certain points, such as obtained by sampling. Some
embedded systems and other computer applications may need numerical integration for this reason.
•A formula for the integrand may be known, but it may be difficult or impossible to find an an-
tiderivative that is an elementary function. An example of such an integrand is f(x) = exp(−x2),
the antiderivative of which (the error function, times a constant) cannot be written in elementary
form.
•It may be possible to find an antiderivative symbolically, but it may be easier to compute a numerical
approximation than to compute the antiderivative. That may be the case if the antiderivative is
given as an infinite series or product, or if its evaluation requires a special function that is not
available.
4.1.1 in 1D - theory
The simplest method of this type is to let the interpolating function be a constant function (a polynomial
of degree zero) that passes through the point ((a+b)/2, f((a+b)/2)).
This is called the midpoint rule or rectangle rule.
Zb
a
f(x)dx '(b−a)f(a+b
2)
insert here figure
The interpolating function may be a straight line (an affine function, i.e. a polynomial of degree 1)
passing through the points (a, f(a)) and (b, f(b)).
This is called the trapezoidal rule.
Zb
a
f(x)dx '(b−a)f(a) + f(b)
2
insert here figure
For either one of these rules, we can make a more accurate approximation by breaking up the interval
[a, b] into some number n of subintervals, computing an approximation for each subinterval, then adding
up all the results. This is called a composite rule, extended rule, or iterated rule. For example, the
composite trapezoidal rule can be stated as
Zb
a
f(x)dx 'b−a
n f(a)
2+
n−1
X
k=1
f(a+kb−a
n) + f(b)
2!
where the subintervals have the form [kh, (k+ 1)h], with h= (b−a)/n and k= 0,1,2, . . . , n −1.
21
a) b)
The interval [−2,2] is broken into 16 sub-intervals. The blue lines correspond to the approximation of
the red curve by means of a) the midpoint rule, b) the trapezoidal rule.
There are several algorithms for numerical integration (also commonly called ’numerical quadrature’,
or simply ’quadrature’) . Interpolation with polynomials evaluated at equally spaced points in [a, b] yields
the NewtonCotes formulas, of which the rectangle rule and the trapezoidal rule are examples. If we allow
the intervals between interpolation points to vary, we find another group of quadrature formulas, such
as the Gauss(ian) quadrature formulas. A Gaussian quadrature rule is typically more accurate than a
NewtonCotes rule, which requires the same number of function evaluations, if the integrand is smooth
(i.e., if it is sufficiently differentiable).
An n−point Gaussian quadrature rule, named after Carl Friedrich Gauss, is a quadrature rule con-
structed to yield an exact result for polynomials of degree 2n−1 or less by a suitable choice of the points
xiand weights wifor i= 1, . . . , n.
The domain of integration for such a rule is conventionally taken as [−1,1], so the rule is stated as
Z+1
−1
f(x)dx =
n
X
iq=1
wiqf(xiq)
In this formula the xiqcoordinate is the i-th root of the Legendre polynomial Pn(x).
It is important to note that a Gaussian quadrature will only produce good results if the function f(x)
is well approximated by a polynomial function within the range [−1,1]. As a consequence, the method
is not, for example, suitable for functions with singularities.
Gauss-Legendre points and their weights.
As shown in the above table, it can be shown that the weight values must fulfill the following condition:
X
iq
wiq= 2 (36)
and it is worth noting that all quadrature point coordinates are symmetrical around the origin.
Since most quadrature formula are only valid on a specific interval, we now must address the problem
of their use outside of such intervals. The solution turns out to be quite simple: one must carry out a
change of variables from the interval [a, b] to [−1,1].
We then consider the reduced coordinate r∈[−1,1] such that
r=2
b−a(x−a)−1
22
This relationship can be reversed such that when ris known, its equivalent coordinate x∈[a, b] can be
computed:
x=b−a
2(1 + r) + a
From this it follows that
dx =b−a
2dr
and then Zb
a
f(x)dx =b−a
2Z+1
−1
f(r)dr 'b−a
2
n
X
iq=1
wiqf(riq)
4.1.2 in 1D - examples
example 1 Since we know how to carry out any required change of variables, we choose for simplicity
a=−1, b= +1. Let us take for example f(x) = π. Then we can compute the integral of this function
over the interval [a, b] exactly:
I=Z+1
−1
f(x)dx =πZ+1
−1
dx = 2π
We can now use a Gauss-Legendre formula to compute this same integral:
Igq =Z+1
−1
f(x)dx =
nq
X
iq=1
wiqf(xiq) =
nq
X
iq=1
wiqπ=π
nq
X
iq=1
wiq
| {z }
=2
= 2π
where we have used the property of the weight values of Eq.(36). Since the actual number of points was
never specified, this result is valid for all quadrature rules.
example 2 Let us now take f(x) = mx +pand repeat the same exercise:
I=Z+1
−1
f(x)dx =Z+1
−1
(mx +p)dx = [1
2mx2+px]+1
−1= 2p
Igq =Z+1
−1
f(x)dx=
nq
X
iq=1
wiqf(xiq)=
nq
X
iq=1
wiq(mxiq+p)= m
nq
X
iq=1
wiqxiq
| {z }
=0
+p
nq
X
iq=1
wiq
| {z }
=2
= 2p
since the quadrature points are symmetric w.r.t. to zero on the x-axis. Once again the quadrature is able
to compute the exact value of this integral: this makes sense since an n-point rule exactly integrates a
2n−1 order polynomial such that a 1 point quadrature exactly integrates a first order polynomial like
the one above.
example 3 Let us now take f(x) = x2. We have
I=Z+1
−1
f(x)dx =Z+1
−1
x2dx = [1
3x3]+1
−1=2
3
and
Igq =Z+1
−1
f(x)dx=
nq
X
iq=1
wiqf(xiq)=
nq
X
iq=1
wiqx2
iq
•nq= 1: x(1)
iq = 0, wiq= 2. Igq = 0
•nq= 2: x(1)
q=−1/√3, x(2)
q= 1/√3, w(1)
q=w(2)
q= 1. Igq =2
3
•It also works ∀nq>2 !
23
4.1.3 in 2D/3D - theory
Let us now turn to a two-dimensional integral of the form
I=Z+1
−1Z+1
−1
f(x, y)dxdy
The equivalent Gaussian quadrature writes:
Igq '
nq
X
iq=1
nq
X
jq
f(xiq, yjq)wiqwjq
4.2 The mesh
4.3 A bit of FE terminology
We introduce here some terminology for efficient element descriptions [266]:
•For triangles/tetrahedra, the designation Pm×Pnmeans that each component of the velocity is
approximated by continuous piecewise complete Polynomials of degree mand pressure by continuous
piecewise complete Polynomials of degree n. For example P2×P1means
u∼a1+a2x+a3y+a4xy +a5x2+a6y2
with similar approximations for v, and
p∼b1+b2x+b3y
Both velocity and pressure are continuous across element boundaries, and each triangular element
contains 6 velocity nodes and three pressure nodes.
•For the same families, Pm×P−nis as above, except that pressure is approximated via piecewise
discontinuous polynomials of degree n. For instance, P2×P−1is the same as P2P1except that
pressure is now an independent linear function in each element and therefore discontinuous at
element boundaries.
•For quadrilaterals/hexahedra, the designation Qm×Qnmeans that each component of the velocity
is approximated by a continuous piecewise polynomial of degree min each direction on the quadri-
lateral and likewise for pressure, except that the polynomial is of degree n. For instance, Q2×Q1
means
u∼a1+a2x+a3y+a4xy +a5x2+a6y2+a7x2y+a8xy2+a9x2y2
and
p∼b1+b2x+b3y+b4xy
•For these same families, Qm×Q−nis as above, except that the pressure approximation is not
continuous at element boundaries.
•Again for the same families, Qm×P−nindicates the same velocity approximation with a pressure
approximation that is a discontinuous complete piecewise polynomial of degree n(not of degree n
in each direction !)
•The designation P+
mor Q+
mmeans that some sort of bubble function was added to the polynomial
approximation for the velocity. You may also find the term ’enriched element’ in the literature.
•Finally, for n= 0, we have piecewise-constant pressure, and we omit the minus sign for simplicity.
Another point which needs to be clarified is the use of so-called ’conforming elements’ (or ’non-
conforming elements’). Following again [266], conforming velocity elements are those for which the
basis functions for a subset of H1for the continuous problem (the first derivatives and their squares are
integrable in Ω). For instance, the rotated Q1×P0element of Rannacher and Turek (see section ??) is
such that the velocity is discontinous across element edges, so that the derivative does not exist there.
Another typical example of non-conforming element is the Crouzeix-Raviart element [140].
24
4.4 Elements and basis functions in 1D
4.4.1 Linear basis functions (Q1)
Let f(r) be a C1function on the interval [−1 : 1] with f(−1) = f1and f(1) = f2.
Let us assume that the function f(r) is to be approximated on [−1,1] by the first order polynomial
f(r) = a+br (37)
Then it must fulfill
f(r=−1) = a−b=f1
f(r= +1) = a+b=f2
This leads to
a=1
2(f1+f2)b=1
2(−f1+f2)
and then replacing a, b in Eq. (37) by the above values on gets
f(r) = 1
2(1 −r)f1+1
2(1 + r)f2
or
f(r) =
2
X
i=1
Ni(r)f1
with
N1(r) = 1
2(1 −r)
N2(r) = 1
2(1 + r) (38)
4.4.2 Quadratic basis functions (Q2)
Let f(r) be a C1function on the interval [−1 : 1] with f(−1) = f1,f(0) = f2and f(1) = f3.
Let us assume that the function f(r) is to be approximated on [−1,1] by the second order polynomial
f(r) = a+br +cr2(39)
Then it must fulfill
f(r=−1) = a−b+c=f1
f(r= 0) = a=f2
f(r= +1) = a+b+c=f3
25
This leads to
a=f2b=1
2(−f1 + f3) c=1
2(f1+f3−2f2)
and then replacing a, b, c in Eq. (39) by the above values on gets
f(r) = 1
2r(r−1)f1+ (1 −r2)f2+1
2r(r+ 1)f3
or,
f(r) =
3
X
i=1
Ni(r)fi
with
N1(r) = 1
2r(r−1)
N2(r) = (1 −r2)
N3(r) = 1
2r(r+ 1) (40)
4.4.3 Cubic basis functions (Q3)
The 1D basis polynomial is given by
f(r) = a+br +cr2+dr3
with the nodes at position -1,-1/3, +1/3 and +1.
f(−1) = a−b+c−d=f1
f(−1/3) = a−b
3+c
9−d
27 =f2
f(+1/3) = a−b
3+c
9−d
27 =f3
f(+1) = a+b+c+d=f4
Adding the first and fourth equation and the second and third, one arrives at
f1+f4= 2a+ 2c f2+f3= 2a+2c
9
and finally:
a=1
16 (−f1+ 9f2+ 9f3−f4)
c=9
16 (f1−f2−f3+f4)
Combining the original 4 equations in a different way yields
2b+ 2d=f4−f1
2b
3+2d
27 =f3−f2
so that
b=1
16 (f1−27f2+ 27f3−f4)
d=9
16 (−f1+ 3f2−3f3+f4)
Finally,
26
f(r) = a+b+cr2+dr3
=1
16(−1 + r+ 9r2−9r3)f1
+1
16(9 −27r−9r2+ 27r3)f2
+1
16(9 + 27r−9r2−27r3)f3
+1
16(−1−r+ 9r2+ 9r3)f4
=
4
X
i=1
Ni(r)fi
where
N1=1
16(−1 + r+ 9r2−9r3)
N2=1
16(9 −27r−9r2+ 27r3)
N3=1
16(9 + 27r−9r2−27r3)
N4=1
16(−1−r+ 9r2+ 9r3)
Verification:
•Let us assume f(r) = C, then
ˆ
f(r) = XNi(r)fi=X
i
NiC=CX
i
Ni=C
so that a constant function is exactly reproduced, as expected.
•Let us assume f(r) = r, then f1=−1, f2=−1/3, f3= 1/3 and f4= +1. We then have
ˆ
f(r) = XNi(r)fi
=−N1(r)−1
3N2(r) + 1
3N3(r) + N4(r)
= [−(−1 + r+ 9r2−9r3)
−1
3(9 −27r−9r2−27r3)
+1
3(9 + 27r−9r2+ 27r3)
+(−1−r+ 9r2+ 9r3)]/16
= [−r+ 9r+ 9r−r]/16 + ...0...
=r(41)
The basis functions derivative are given by
27
∂N1
∂r =1
16(1 + 18r−27r2)
∂N2
∂r =1
16(−27 −18r+ 81r2)
∂N3
∂r =1
16(+27 −18r−81r2)
∂N4
∂r =1
16(−1 + 18r+ 27r2)
Verification:
•Let us assume f(r) = C, then
∂ˆ
f
∂r =X
i
∂Ni
∂r fi
=CX
i
∂Ni
∂r
=C
16[(1 + 18r−27r2)
+(−27 −18r+ 81r2)
+(+27 −18r−81r2)
+(−1 + 18r+ 27r2)]
= 0
•Let us assume f(r) = r, then f1=−1, f2=−1/3, f3= 1/3 and f4= +1. We then have
∂ˆ
f
∂r =X
i
∂Ni
∂r fi
=1
16[−(1 + 18r−27r2)
−1
3(−27 −18r+ 81r2)
+1
3(+27 −18r−81r2)
+(−1 + 18r+ 27r2)]
=1
16[−2 + 18 + 54r2−54r2]
= 1
4.5 Elements and basis functions in 2D
Let us for a moment consider a single quadrilateral element in the xy-plane, as shown on the following
figure:
28
Let us assume that we know the values of a given field uat the vertices. For a given point Minside
the element in the plane, what is the value of the field uat this point? It makes sense to postulate that
uM=u(xM, yM) will be given by
uM=φ(u1, u2, u3, u4, xM, yM)
where φis a function to be determined. Although φis not unique, we can decide to express the value
uMas a weighed sum of the values at the vertices ui. One option could be to assign all four vertices the
same weight, say 1/4 so that uM= (u1+u2+u3+u4)/4, i.e. uMis simply given by the arithmetic mean
of the vertices values. This approach suffers from a major drawback as it does not use the location of
point Minside the element. For instance, when (xM, yM)→(x2, y2) we expect uM→u2.
In light of this, we could now assume that the weights would depend on the position of Min a
continuous fashion:
u(xM, yM) =
4
X
i=1
Ni(xM, yM)ui
where the Niare continous (”well behaved”) functions which have the property:
Ni(xj, yj) = δij
or, in other words:
N3(x1, y1) = 0 (42)
N3(x2, y2) = 0 (43)
N3(x3, y3) = 1 (44)
N3(x4, y4) = 0 (45)
The functions Niare commonly called basis functions.
Omitting the Msubscripts for any point inside the element, the velocity components uand vare
given by:
ˆu(x, y) =
4
X
i=1
Ni(x, y)ui(46)
ˆv(x, y) =
4
X
i=1
Ni(x, y)vi(47)
Rather interestingly, one can now easily compute velocity gradients (and therefore the strain rate tensor)
since we have assumed the basis functions to be ”well behaved” (in this case differentiable):
˙xx(x, y) = ∂u
∂x =
4
X
i=1
∂Ni
∂x ui(48)
˙yy(x, y) = ∂v
∂y =
4
X
i=1
∂Ni
∂y vi(49)
˙xy (x, y) = 1
2
∂u
∂y +1
2
∂v
∂x =1
2
4
X
i=1
∂Ni
∂y ui+1
2
4
X
i=1
∂Ni
∂x vi(50)
How we actually obtain the exact form of the basis functions is explained in the coming section.
4.5.1 Bilinear basis functions in 2D (Q1)
In this section, we place ourselves in the most favorables case, i.e. the element is a square defined by
−1< r < 1, −1< s < 1 in the Cartesian coordinates system (r, s):
29
3===========2
| | (r_0,s_0)=(-1,-1)
| | (r_1,s_1)=(+1,-1)
| | (r_2,s_2)=(+1,+1)
| | (r_3,s_3)=(-1,+1)
| |
0===========1
This element is commonly called the reference element. How we go from the (x, y) coordinate system
to the (r, s) once and vice versa will be dealt later on. For now, the basis functions in the above reference
element and in the reduced coordinates system (r, s) are given by:
N1(r, s)=0.25(1 −r)(1 −s)
N2(r, s)=0.25(1 + r)(1 −s)
N3(r, s)=0.25(1 + r)(1 + s)
N4(r, s)=0.25(1 −r)(1 + s)
The partial derivatives of these functions with respect to rans sautomatically follow:
∂N1
∂r (r, s) = −0.25(1 −s)∂N1
∂s (r, s) = −0.25(1 −r)
∂N2
∂r (r, s) = +0.25(1 −s)∂N2
∂s (r, s) = −0.25(1 + r)
∂N3
∂r (r, s) = +0.25(1 + s)∂N3
∂s (r, s) = +0.25(1 + r)
∂N4
∂r (r, s) = −0.25(1 + s)∂N4
∂s (r, s) = +0.25(1 −r)
Let us go back to Eq.(47). And let us assume that the function v(r, s) = Cso that vi=Cfor
i= 1,2,3,4. It then follows that
ˆv(r, s) =
4
X
i=1
Ni(r, s)vi=C
4
X
i=1
Ni(r, s) = C[N1(r, s) + N2(r, s) + N3(r, s) + N4(r, s)] = C
This is a very important property: if the vfunction used to assign values at the vertices is constant, then
the value of ˆvanywhere in the element is exactly C. If we now turn to the derivatives of vwith respect
to rand s:
∂ˆv
∂r (r, s) =
4
X
i=1
∂Ni
∂r (r, s)vi=C
4
X
i=1
∂Ni
∂r (r, s) = C[−0.25(1 −s)+0.25(1 −s)+0.25(1 + s)−0.25(1 + s)] = 0
∂ˆv
∂s (r, s) =
4
X
i=1
∂Ni
∂s (r, s)vi=C
4
X
i=1
∂Ni
∂s (r, s) = C[−0.25(1 −r)−0.25(1 + r)+0.25(1 + r)+0.25(1 −r)] = 0
We reassuringly find that the derivative of a constant field anywhere in the element is exactly zero.
30
If we now choose v(r, s) = ar +bs with aand btwo constant scalars, we find:
ˆv(r, s) =
4
X
i=1
Ni(r, s)vi(51)
=
4
X
i=1
Ni(r, s)(ari+bsi) (52)
=a
4
X
i=1
Ni(r, s)ri
| {z }
r
+b
4
X
i=1
Ni(r, s)si
| {z }
s
(53)
=a[0.25(1 −r)(1 −s)(−1) + 0.25(1 + r)(1 −s)(+1) + 0.25(1 + r)(1 + s)(+1) + 0.25(1 −r)(1 + s)(−1)]
+b[0.25(1 −r)(1 −s)(−1) + 0.25(1 + r)(1 −s)(−1) + 0.25(1 + r)(1 + s)(+1) + 0.25(1 −r)(1 + s)(+1)]
=a[−0.25(1 −r)(1 −s)+0.25(1 + r)(1 −s)+0.25(1 + r)(1 + s)−0.25(1 −r)(1 + s)]
+b[−0.25(1 −r)(1 −s)−0.25(1 + r)(1 −s)+0.25(1 + r)(1 + s)+0.25(1 −r)(1 + s)]
=ar +bs (54)
verify above eq. This set of bilinear shape functions is therefore capable of exactly representing a bilinear
field. The derivatives are:
∂ˆv
∂r (r, s) =
4
X
i=1
∂Ni
∂r (r, s)vi(55)
=a
4
X
i=1
∂Ni
∂r (r, s)ri+b
4
X
i=1
∂Ni
∂r (r, s)si(56)
=a[−0.25(1 −s)(−1) + 0.25(1 −s)(+1) + 0.25(1 + s)(+1) −0.25(1 + s)(−1)]
+b[−0.25(1 −s)(−1) + 0.25(1 −s)(−1) + 0.25(1 + s)(+1) −0.25(1 + s)(+1)]
=a
4[(1 −s) + (1 −s) + (1 + s) + (1 + s)]
+b
4[(1 −s)−(1 −s) + (1 + s)−(1 + s)]
=a(57)
Here again, we find that the derivative of the bilinear field inside the element is exact: ∂ˆv
∂r =∂v
∂r .
However, following the same methodology as above, one can easily prove that this is no more true
for polynomials of degree strivtly higher than 1. This fact has serious consequences: if the solution to
the problem at hand is for instance a parabola, the Q1shape functions cannot represent the solution
properly, but only by approximating the parabola in each element by a line. As we will see later, Q2
basis functions can remedy this problem by containing themselves quadratic terms.
4.5.2 Biquadratic basis functions in 2D (Q2)
This element is part of the so-called LAgrange family.
citation needed
Inside an element the local numbering of the nodes is as follows:
3=====6=====2
| | | (r_0,s_0)=(-1,-1) (r_4,s_4)=( 0,-1)
| | | (r_1,s_1)=(+1,-1) (r_5,s_5)=(+1, 0)
7=====8=====5 (r_2,s_2)=(+1,+1) (r_6,s_6)=( 0,+1)
| | | (r_3,s_3)=(-1,+1) (r_7,s_7)=(-1, 0)
| | | (r_8,s_8)=( 0, 0)
0=====4=====1
The basis polynomial is then
f(r, s) = a+br +cs +drs +er2+fs2+gr2s+hrs2+ir2s2
31
The velocity shape functions are given by:
N0(r, s) = 1
2r(r−1)1
2s(s−1)
N1(r, s) = 1
2r(r+ 1)1
2s(s−1)
N2(r, s) = 1
2r(r+ 1)1
2s(s+ 1)
N3(r, s) = 1
2r(r−1)1
2s(s+ 1)
N4(r, s) = (1 −r2)1
2s(s−1)
N5(r, s) = 1
2r(r+ 1)(1 −s2)
N6(r, s) = (1 −r2)1
2s(s+ 1)
N7(r, s) = 1
2r(r−1)(1 −s2)
N8(r, s) = (1 −r2)(1 −s2)
and their derivatives by:
∂N0
∂r =1
2(2r−1)1
2s(s−1) ∂N0
∂s =1
2r(r−1)1
2(2s−1)
∂N1
∂r =1
2(2r+ 1)1
2s(s−1) ∂N1
∂s =1
2r(r+ 1)1
2(2s−1)
∂N2
∂r =1
2(2r+ 1)1
2s(s+ 1) ∂N2
∂s =1
2r(r+ 1)1
2(2s+ 1)
∂N3
∂r =1
2(2r−1)1
2s(s+ 1) ∂N3
∂s =1
2r(r−1)1
2(2s+ 1)
∂N4
∂r = (−2r)1
2s(s−1) ∂N4
∂s = (1 −r2)1
2(2s−1)
∂N5
∂r =1
2(2r+ 1)(1 −s2)∂N5
∂s =1
2r(r+ 1)(−2s)
∂N6
∂r = (−2r)1
2s(s+ 1) ∂N6
∂s = (1 −r2)1
2(2s+ 1)
∂N7
∂r =1
2(2r−1)(1 −s2)∂N7
∂s =1
2r(r−1)(−2s)
∂N8
∂r = (−2r)(1 −s2)∂N8
∂s = (1 −r2)(−2s)
4.5.3 Eight node serendipity basis functions in 2D (Q(8)
2)
Inside an element the local numbering of the nodes is as follows:
3=====6=====2
| | | (r_0,s_0)=(-1,-1) (r_4,s_4)=( 0,-1)
| | | (r_1,s_1)=(+1,-1) (r_5,s_5)=(+1, 0)
7=====+=====5 (r_2,s_2)=(+1,+1) (r_6,s_6)=( 0,+1)
| | | (r_3,s_3)=(-1,+1) (r_7,s_7)=(-1, 0)
|||
0=====4=====1
32
The main difference with the Q2element resides in the fact that there is no node in the middle of the
element The basis polynomial is then
f(r, s) = a+br +cs +drs +er2+fs2+gr2s+hrs2
Note that absence of the r2s2term which was previously associated to the center node. We find that
N0(r, s) = 1
4(1 −r)(1 −s)(−r−s−1) (58)
N1(r, s) = 1
4(1 + r)(1 −s)(r−s−1) (59)
N2(r, s) = 1
4(1 + r)(1 + s)(r+s−1) (60)
N3(r, s) = 1
4(1 −r)(1 + s)(−r+s−1) (61)
N4(r, s) = 1
2(1 −r2)(1 −s) (62)
N5(r, s) = 1
2(1 + r)(1 −s2) (63)
N6(r, s) = 1
2(1 −r2)(1 + s) (64)
N7(r, s) = 1
2(1 −r)(1 −s2) (65)
The shape functions at the mid side nodes are products of a second order polynomial parallel to side
and a linear function perpendicular to the side while shape functions for corner nodes are modifications
of the bilinear quadrilateral element:
verify those
4.5.4 Bicubic basis functions in 2D (Q3)
Inside an element the local numbering of the nodes is as follows:
12===13===14===15 (r,s)_{00}=(-1,-1) (r,s)_{08}=(-1,+1/3)
|| || || || (r,s)_{01}=(-1/3,-1) (r,s)_{09}=(-1/3,+1/3)
08===09===10===11 (r,s)_{02}=(+1/3,-1) (r,s)_{10}=(+1/3,+1/3)
|| || || || (r,s)_{03}=(+1,-1) (r,s)_{11}=(+1,+1/3)
04===05===06===07 (r,s)_{04}=(-1,-1/3) (r,s)_{12}=(-1,+1)
|| || || || (r,s)_{05}=(-1/3,-1/3) (r,s)_{13}=(-1/3,+1)
00===01===02===03 (r,s)_{06}=(+1/3,-1/3) (r,s)_{14}=(+1/3,+1)
(r,s)_{07}=(+1,-1/3) (r,s)_{15}=(+1,+1)
The velocity shape functions are given by:
N1(r)=(−1 + r+ 9r2−9r3)/16 N1(t)=(−1 + t+ 9t2−9t3)/16
N2(r) = (+9 −27r−9r2+ 27r3)/16 N2(t) = (+9 −27t−9t2+ 27t3)/16
N3(r) = (+9 + 27r−9r2−27r3)/16 N3(t) = (+9 + 27t−9t2−27t3)/16
N4(r)=(−1−r+ 9r2+ 9r3)/16 N4(t)=(−1−t+ 9t2+ 9t3)/16
33
N01(r, s) = N1(r)N1(s)=(−1 + r+ 9r2−9r3)/16 ∗(−1 + t+ 9s2−9s3)/16
N02(r, s) = N2(r)N1(s) = (+9 −27r−9r2+ 27r3)/16 ∗(−1 + t+ 9s2−9s3)/16
N03(r, s) = N3(r)N1(s) = (+9 + 27r−9r2−27r3)/16 ∗(−1 + t+ 9s2−9s3)/16
N04(r, s) = N4(r)N1(s)=(−1−r+ 9r2+ 9r3)/16 ∗(−1 + t+ 9s2−9s3)/16
N05(r, s) = N1(r)N2(s) = (−1 + r+ 9r2−9r3)/16 ∗(9 −27s−9s2+ 27s3)/16
N06(r, s) = N2(r)N2(s) = (+9 −27r−9r2+ 27r3)/16 ∗(9 −27s−9s2+ 27s3)/16
N07(r, s) = N3(r)N2(s) = (+9 + 27r−9r2−27r3)/16 ∗(9 −27s−9s2+ 27s3)/16
N08(r, s) = N4(r)N2(s)=(−1−r+ 9r2+ 9r3)/16 ∗(9 −27s−9s2+ 27s3)/16
N09(r, s) = N1(r)N3(s) = (66)
N10(r, s) = N2(r)N3(s) = (67)
N11(r, s) = N3(r)N3(s) = (68)
N12(r, s) = N4(r)N3(s) = (69)
N13(r, s) = N1(r)N4(s) = (70)
N14(r, s) = N2(r)N4(s) = (71)
N15(r, s) = N3(r)N4(s) = (72)
N16(r, s) = N4(r)N4(s) = (73)
4.5.5 Linear basis functions for triangles in 2D (P1)
2
|\
| \ (r_0,s_0)=(0,0)
| \ (r_1,s_1)=(1,0)
| \ (r_2,s_2)=(0,2)
0=======1
The basis polynomial is then
f(r, s) = a+br +cs
and the shape functions:
N0(r, s)=1−r−s(74)
N1(r, s) = r(75)
N2(r, s) = s(76)
4.5.6 Quadratic basis functions for triangles in 2D (P2)
2
|\
| \ (r_0,s_0)=(0,0) (r_3,s_3)=(1/2,0)
5 4 (r_1,s_1)=(1,0) (r_4,s_4)=(1/2,1/2)
| \ (r_2,s_2)=(0,1) (r_5,s_5)=(0,1/2)
| \
0===3===1
The basis polynomial is then
f(r, s) = c1+c2r+c3s+c4r2+c5rs +c6s2
34
We have
f1=f(r1, s1) = c1
f2=f(r2, s2) = c1+c2+c4
f3=f(r3, s3) = c1+c3+c6
f4=f(r4, s4) = c1+c2/2 + c4/4
f5=f(r5, s5) = c1+c2/2 + c3/2
+c4/4 + c5/4 + c6/4
f6=f(r6, s6) = c1+c3/2 + c6/4
This can be cast as f=A·cwhere Ais a 6x6 matrix:
A=
100000
110100
101001
1 1/201/4 0 0
1 1/2 1/2 1/4 1/4 1/4
101/2 0 0 1/4
It is rather trivial to compute the inverse of this matrix:
A−1=
1 0 0 0 0 0
−3−1 0 4 0 0
−3 0 −1004
220−4 0 0
400−4 4 −4
2 0 2 0 0 −4
In the end, one obtains:
f(r, s) = f1+ (−3f1−f2+ 4f4)r+ (−3f1−f3+ 4f6)s
+(2f1+ 2f2−4f4)r2+ (4f1−4f4+ 4f5−4f6)rs
+(2f1+ 2f3−4f6)s2
=
6
X
i=1
Ni(r, s)fi(77)
with
N1(r, s)=1−3r−3s+ 2r2+ 4rs + 2s2
N2(r, s) = −r+ 2r2
N3(r, s) = −s+ 2s2
N4(r, s)=4r−4r2−4rs
N5(r, s)=4rs
N6(r, s)=4s−4rs −4s2
4.5.7 Cubic basis functions for triangles (P3)
2
|\ (r_0,s_0)=(0,0) (r_5,s_5)=(2/3,1/3)
| \ (r_1,s_1)=(1,0) (r_6,s_6)=(1/3,2/3)
7 6 (r_2,s_2)=(0,1) (r_7,s_7)=(0,2/3)
| \ (r_3,s_3)=(1/3,0) (r_8,s_8)=(0,1/3)
8 9 5 (r_4,s_4)=(2/3,0) (r_9,s_9)=(1/3,1/3)
| \
0==3==4==1
35
The basis polynomial is then
f(r, s) = c1+c2r+c3s+c4r2+c5rs +c6s2+c7r3+c8r2s+c9rs2+c10s3
N0(r, s) = 9
2(1 −r−s)(1/3−r−s)(2/3−r−s) (78)
N1(r, s) = 9
2r(r−1/3)(r−2/3) (79)
N2(r, s) = 9
2s(s−1/3)(s−2/3) (80)
N3(r, s) = 27
2(1 −r−s)r(2/3−r−s) (81)
N4(r, s) = 27
2(1 −r−s)r(r−1/3) (82)
N5(r, s) = 27
2rs(r−1/3) (83)
N6(r, s) = 27
2rs(r−2/3) (84)
N7(r, s) = 27
2(1 −r−s)s(s−1/3) (85)
N8(r, s) = 27
2(1 −r−s)s(2/3−r−s) (86)
N9(r, s) = 27rs(1 −r−s) (87)
verify those
4.6 Elements and basis functions in 3D
4.6.1 Linear basis functions in tetrahedra (P1)
(r_0,s_0) = (0,0,0)
(r_1,s_1) = (1,0,0)
(r_2,s_2) = (0,2,0)
(r_3,s_3) = (0,0,1)
The basis polynomial is given by
f(r, s, t) = c0+c1r+c2s+c3t
f1=f(r1, s1, t1) = c0(88)
f2=f(r2, s2, t2) = c0+c1(89)
f3=f(r3, s3, t3) = c0+c2(90)
f4=f(r4, s4, t4) = c0+c3(91)
which yields:
c0=f1c1=f2−f1c2=f3−f1c3=f4−f1
f(r, s, t) = c0+c1r+c2s+c3t
=f1+ (f2−f1)r+ (f3−f1)s+ (f4−f1)t
=f1(1 −r−s−t) + f2r+f3s+f4t
=X
i
Ni(r, s, t)fi
Finally,
36
N1(r, s, t)=1−r−s−t
N2(r, s, t) = r
N3(r, s, t) = s
N4(r, s, t) = t
4.6.2 Triquadratic basis functions in 3D (Q2)
N1= 0.5r(r−1) 0.5s(s−1) 0.5t(t−1)
N2= 0.5r(r+ 1) 0.5s(s−1) 0.5t(t−1)
N3= 0.5r(r+ 1) 0.5s(s+ 1) 0.5t(t−1)
N4= 0.5r(r−1) 0.5s(s+ 1) 0.5t(t−1)
N5= 0.5r(r−1) 0.5s(s−1) 0.5t(t+ 1)
N6= 0.5r(r+ 1) 0.5s(s−1) 0.5t(t+ 1)
N7= 0.5r(r+ 1) 0.5s(s+ 1) 0.5t(t+ 1)
N8= 0.5r(r−1) 0.5s(s+ 1) 0.5t(t+ 1)
N9= (1.−r2) 0.5s(s−1) 0.5t(t−1)
N10 = 0.5r(r+ 1) (1 −s2) 0.5t(t−1)
N11 = (1.−r2) 0.5s(s+ 1) 0.5t(t−1)
N12 = 0.5r(r−1) (1 −s2) 0.5t(t−1)
N13 = (1.−r2) 0.5s(s−1) 0.5t(t+ 1)
N14 = 0.5r(r+ 1) (1 −s2) 0.5t(t+ 1)
N15 = (1.−r2) 0.5s(s+ 1) 0.5t(t+ 1)
N16 = 0.5r(r−1) (1 −s2) 0.5t(t+ 1)
N17 = 0.5r(r−1) 0.5s(s−1) (1 −t2)
N18 = 0.5r(r+ 1) 0.5s(s−1) (1 −t2)
N19 = 0.5r(r+ 1) 0.5s(s+ 1) (1 −t2)
N20 = 0.5r(r−1) 0.5s(s+ 1) (1 −t2)
N21 = (1 −r2) (1 −s2) 0.5t(t−1)
N22 = (1 −r2) 0.5s(s−1) (1 −t2)
N23 = 0.5r(r+ 1) (1 −s2) (1 −t2)
N24 = (1 −r2) 0.5s(s+ 1) (1 −t2)
N25 = 0.5r(r−1) (1 −s2) (1 −t2)
N26 = (1 −r2) (1 −s2) 0.5t(t+ 1)
N27 = (1 −r2) (1 −s2) (1 −t2)
37
5 Solving the heat transport equation with linear Finite Ele-
ments
5.1 The diffusion equation in 1D
Let us consider the following one-dimensional grid:
Its spans the domain Ω of length Lx. It is discretised by means of nnx nodes and nelx =nnx −1
elements. Zooming in on element which is bounded by two nodes kand k+ 1, its size (also sometimes
called diameter) is hx=xk+1 −xk, and the temperature field we wish to compute is located on those
nodes so that they are logically called Tkand Tk+1:
We focus here on the 1D diffusion equation (no advection, no heat sources):
ρcp
∂T
∂t =∂
∂x k∂T
∂x (92)
This is the strong form of the ODE to solve. I can multiply this equation by a function3f(x) and
integrate it over Ω: ZΩ
f(x)ρcp
∂T
∂t dx =ZΩ
f(x)∂
∂x k∂T
∂x dx (93)
Looking at the right hand side, it is of the form Ruv0so that I naturally integrate it by parts:
ZΩ
f(x)∂
∂x k∂T
∂x dx =f(x)k∂T
∂x ∂Ω−ZΩ
∂f
∂x k∂T
∂x dx (94)
Assuming there is no heat flux prescribed on the boundary (i.e. qx=−k∂T/∂x = 0 ),
NOT happy with this statement!!
then: ZΩ
f(x)∂
∂x k∂T
∂x dx =−ZΩ
∂f
∂x k∂T
∂x dx (95)
We then obtain the weak form of the diffusion equation in 1D:
ZΩ
f(x)ρcp
∂T
∂t dx +ZΩ
∂f
∂x k∂T
∂x dx = 0 (96)
3This function should be well-behaved with special properties, but we here assume it is a polynomial function.
38
We then use the additive property of the integral RΩ··· =Pelts RΩe. . . so that
X
elts
ZΩe
f(x)ρcp
∂T
∂t dx
| {z }
Λe
f
+ZΩe
∂f
∂x k∂T
∂x dx
| {z }
Υe
f
= 0 (97)
In order to compute these integrals (analytically or by means of a numerical quadrature), we will need
to evaluate Tinside the element. However, inside the element, the temperature is not known: all we
have is the temperature at the nodes. For x∈[xk, xk+1] we need to come up with a way to compute the
temperature at this location. It makes sense to think that T(x) will then be a function of the temperature
at the nodes, i.e. T(x) = αTk+βTk+1 where αand βare coefficients. One over-simplified approach would
be to assign T(x) = (Tk+Tk+1)/2 but this would make the temperature discontinuous from element to
element. The rather logical solution to this problem is a linear temperature field between Tkand Tk+1:
T(x) = xk+1 −x
hx
| {z }
Nθ
k(x)
Tk+x−xk
hx
| {z }
Nθ
k+1(x)
Tk+1
where Nθ
k(x) is the (temperature) shape function associated to node kand Nθ
k+1(x) is the shape function
associated to node k+ 1.
Rather reassuringly, we have:
•x=xkyields T(x) = Tk
•x=xk+1 yields T(x) = Tk+1
•x= (xk+xk+1)/2 yields T(x) = (Tk+Tk+1)/2
In what follows we abbreviate ∂T/∂x by ˙
T. Let us compute Λe
fand Υe
fseparately.
Λe
f=Zxk+1
xk
f(x)ρcp˙
T(x)dx
=Zxk+1
xk
f(x)ρcp[Nθ
k(x)˙
Tk+Nθ
k+1(x)˙
Tk+1]dx
=Zxk+1
xk
f(x)ρcpNθ
k(x)˙
Tkdx +Zxk+1
xk
f(x)ρcpNθ
k+1(x)˙
Tk+1dx
=Zxk+1
xk
f(x)ρcpNθ
k(x)dx˙
Tk+Zxk+1
xk
f(x)ρcpNθ
k+1(x)dx˙
Tk+1
Taking f(x) = Nθ
k(x) and omitting ’(x)’ in the rhs:
Λe
Nθ
k=Zxk+1
xk
ρcpNθ
kNθ
kdx˙
Tk+Zxk+1
xk
ρcpNθ
kNθ
k+1dx˙
Tk+1
Taking f(x) = Nθ
k+1(x) and omitting ’(x)’ in the rhs:
Λe
Nθ
k+1 =Zxk+1
xk
ρcpNθ
k+1Nθ
kdx˙
Tk+Zxk+1
xk
ρcpNθ
k+1Nθ
k+1dx˙
Tk+1
We can rearrange these last two equations as follows:
Λe
Nθ
k
Λe
Nθ
k+1
=
Rxk+1
xkNθ
kρcpNθ
kdx Rxk+1
xkNθ
kρcpNθ
k+1dx
Rxk+1
xkNθ
k+1ρcpNθ
kdx Rxk+1
xkNθ
k+1ρcpNθ
k+1dx
·
˙
Tk
˙
Tk+1
39
and we can take the integrals outside of the matrix:
Λe
Nθ
k
Λe
Nθ
k+1
=
Zxk+1
xk
ρcp
Nθ
kNθ
kNθ
kNθ
k+1
Nθ
k+1Nθ
kNθ
k+1Nθ
k+1
dx
·
˙
Tk
˙
Tk+1
Finally, we can define the vectors
NT=
Nθ
k(x)
Nθ
k+1(x)
and
Te=
Tk
Tk+1
˙
Te=
˙
Tk
˙
Tk+1
so that
Λe
Nθ
k
Λe
Nθ
k+1
=Zxk+1
xk
NTρcp
Ndx·˙
Te
Back to the diffusion term:
Υe
f=Zxk+1
xk
∂f
∂x k∂T
∂x dx
=Zxk+1
xk
∂f
∂x k∂(Nθ
k(x)Tk+Nθ
k+1(x)Tk+1)
∂x dx
= Zxk+1
xk
∂f
∂x k∂N θ
k
∂x dx!Tk+ Zxk+1
xk
∂f
∂x k∂N θ
k+1
∂x dx!Tk+1
Taking f(x) = Nθ
k(x)
Υe
Nθ
k= Zxk+1
xk
k∂Nθ
k
∂x
∂Nθ
k
∂x dx!Tk+ Zxk+1
xk
k∂Nθ
k
∂x
∂Nθ
k+1
∂x dx!Tk+1
Taking f(x) = Nθ
k+1(x)
Υe
Nθ
k+1 = Zxk+1
xk
k∂Nθ
k+1
∂x
∂Nθ
k
∂x dx!Tk+ Zxk+1
xk
k∂Nθ
k+1
∂x
∂Nθ
k+1
∂x dx!Tk+1
Υe
Nθ
k
Υe
Nθ
k+1
=
Rxk+1
xk
∂Nθ
k
∂x k∂Nθ
k
∂x dx Rxk+1
xk
∂Nθ
k
∂x k∂Nθ
k+1
∂x dx
Rxk+1
xk
∂Nθ
k+1
∂x k∂Nθ
k
∂x dx Rxk+1
xk
∂Nθ
k+1
∂x k∂Nθ
k+1
∂x dx
·
Tk
Tk+1
or,
Υe
Nθ
k
Υe
Nθ
k+1
=
Zxk+1
xk
k
∂Nθ
k
∂x
∂Nθ
k
∂x
∂Nθ
k
∂x
∂Nθ
k+1
∂x
∂Nθ
k+1
∂x
∂Nθ
k
∂x
∂Nθ
k+1
∂x
∂Nθ
k+1
∂x
dx
·
Tk
Tk+1
Finally, we can define the vector
BT=
∂Nθ
k
∂x
∂Nθ
k+1
∂x
40
so that
Υe
Nθ
k
Υe
Nθ
k+1
=Zxk+1
xk
BTk
Bdx·
Te
The weak form discretised over 1 element becomes
Zxk+1
xk
NTρcp
Ndx
| {z }
Me
·˙
Te+Zxk+1
xk
BTk
Bdx
| {z }
Ke
d
·
Te= 0
or,
Me·˙
Te+Ke
d·
Te= 0
or,
Me·∂
Te
∂t +Ke
d·
Te= 0
Using a backward first order in time discretisation for the time derivative:
˙
T=∂
T
∂t =
Tnew −
Told
δt
we get
Me·
Tnew −
Told
δt +Ke
d·
Tnew = 0
or,
(Me+Ke
dδt)·
Tnew =Me·
Told
with
Me=Zxk+1
xk
NTρcp
Ndx Ke
d=Zxk+1
xk
BTk
Bdx
Let us compute Mfor an element:
Me=Zxk+1
xk
NTρcp
Ndx
with
NT=
Nk(x)
Nk+1(x)
=
xk+1−x
hx
x−xk
hx
Then
Me=M11 M12
M21 M22 =
Rxk+1
xkρcpNθ
kNθ
kdx Rxk+1
xkρcpNθ
kNθ
k+1dx
Rxk+1
xkρcpNθ
k+1Nθ
kdx Rxk+1
xkρcpNθ
k+1Nθ
k+1dx
I only need to compute 3 integrals since M12 =M21. Let us start with M11:
M11 =Zxk+1
xk
ρcpNθ
k(x)Nθ
k(x)dx =Zxk+1
xk
ρcp
xk+1 −x
hx
xk+1 −x
hx
dx
It is then customary to carry out the change of variable x→rwhere r∈[−1 : 1] as shown hereunder:
41
The relationships between xand rare:
r=2
hx
(x−xk)−1x=hx
2(1 + r) + xk
In what follows we assume for simplicity that ρand cpare constant within each element.
M11 =ρcpZxk+1
xk
xk+1 −x
hx
xk+1 −x
hx
dx =ρcphx
8Z+1
−1
(1 −r)(1 −r)dr =hx
3ρcp
Similarly we arrive at
M12 =ρcpZxk+1
xk
xk+1 −x
hx
x−xk
hx
dx =ρcphx
8Z+1
−1
(1 −r)(1 + r)dr =hx
6ρcp
and
M22 =ρcpZxk+1
xk
x−xk
hx
x−xk
hx
dx =ρcphx
8Z+1
−1
(1 + r)(1 + r)dr =hx
3ρcp
Finally
Me=hx
3ρcp1 1/2
1/2 1
In the new coordinate system, the shape functions
Nθ
k(x) = xk+1 −x
hx
Nθ
k+1(x) = x−xk
hx
become
Nθ
k(r) = 1
2(1 −r)Nθ
k+1(r) = 1
2(1 + r)
Also,
∂Nθ
k
∂x =−1
hx
∂Nθ
k+1
∂x =1
hx
so that
BT=
∂Nθ
k
∂x
∂Nθ
k+1
∂x
=
−1
hx
1
hx
We here also assume that kis constant within the element:
Kd=Zxk+1
xk
BTk
Bdx =kZxk+1
xk
BT
Bdx
simply becomes
Kd=kZxk+1
xk
1
h2
x1−1
−1 1 dx
and then
Kd=k
hx1−1
−1 1
Let us consider this very simple grid consisting of 4 elements/5 nodes:
42
For each element we have
(Me+Ke
dδt)
| {z }
Ae
·
Tnew =Me·
Told
| {z }
~
be
We can write this equation very explictely for each element:
•element 1
A1·T1
T2=
b1
A1
11T1+A1
12T2=b1
x
A1
21T1+A1
22T2=b1
y
•element 2
A2·T2
T3=
b2
A2
11T2+A2
12T3=b2
1
A2
21T2+A2
22T3=b2
2
•element 3
A3·T3
T4=
b3
A3
11T3+A3
12T4=b3
1
A3
21T3+A3
22T4=b3
2
•element 4
A4·T4
T5=
b4
A4
11T4+A4
12T5=b4
1
A4
21T4+A4
22T5=b4
2
All equations can be cast into a single linear system: this is the assembly phase. The process can also
be visualised as shown hereunder. Because nodes 2,3,4 belong to two elements elemental contributions
will be summed in the matrix and the rhs:
43
The assembled matrix and rhs are then:
A1
11 A1
12 0 0 0
A1
21 A1
22 +A2
11 A2
12 0 0
0A2
21 A2
22 +A3
11 A3
12 0
0 0 A3
21 A3
22 +A4
11 A4
12
0 0 0 A4
21 A4
22
T1
T2
T3
T4
T5
=
b1
1
b1
2+b2
1
b2
2+b3
1
b3
2+b4
1
b4
2
Ultimately the assembled matrix system also takes the form
A11 A12 000
A21 A22 A23 0 0
0A32 A33 A34 0
0 0 A43 A44 A45
000A54 A55
T1
T2
T3
T4
T5
=
b1
b2
b3
b4
b5
and we see that it is sparse. Its sparsity structure is easy to derive: each row corresponds to a dof, and
since nodes 1 and 2 ’see’ each other (they belong to the same element) there will be non-zero entries in
the first and second column. Likewise, node 2 ’sees’ node 1 (in other words, there is an edge linking nodes
1 and 2), itself, and node 3, so that there are non-zero entries in the second row at columns 1, 2, and 3.
Before we solve the system, we need to take care of boundary conditions. Let us assume that we wish
to fix the temperature at node 2, or in other words we wish to set
T2=Tbc
This equation can be cast as
01000
T1
T2
T3
T4
T5
=
0
Tbc
0
0
0
This replaces the second line in the previous matrix equation:
A11 A12 000
01000
0A32 A33 A34 0
0 0 A43 A44 A45
000A54 A55
T1
T2
T3
T4
T5
=
b1
Tbc
b3
b4
b5
That’s it, we have a linear system of equations which can be solved!
44
5.2 The advection-diffusion equation in 1D
We start with the 1D advection-diffusion equation
ρcp∂T
∂t +u∂T
∂x =∂
∂x k∂T
∂x +H(98)
This is the strong form of the ODE to solve. As in the previous section, I multiply this equation by a
function f(x) and integrate it over the domain Ω:
ZΩ
f(x)ρcp
∂T
∂t dx +ZΩ
f(x)ρcpu∂T
∂x dx=ZΩ
f(x)∂
∂x k∂T
∂xdx +ZΩ
f(x)Hdx
As in the previous section I integrate the r.h.s. by parts:
ZΩ
f(x)∂
∂x k∂T
∂x dx =f(x)k∂T
∂x ∂Ω−ZΩ
∂f
∂x k∂T
∂x dx
Disregarding the boundary term for now, we then obtain the weak form of the diffusion equation in 1D:
ZΩ
f(x)ρcp
∂T
∂t dx +ZΩ
f(x)ρcpu∂T
∂x dx +ZΩ
∂f
∂x k∂T
∂x dx =ZΩ
f(x)Hdx
We then use the additive property of the integral RΩ··· =Pelts RΩe. . .
X
elts
ZΩe
f(x)ρcp
∂T
∂t dx
| {z }
Λe
f
+ZΩe
f(x)ρcpu∂T
∂x dx
| {z }
Σe
f
+ZΩe
∂f
∂x k∂T
∂x dx
| {z }
Υe
f
−ZΩe
f(x)Hdx
| {z }
Ωe
f
= 0
In the element, we have seen that the temperature can be written:
T(x) = Nθ
k(x)Tk+Nθ
k+1(x)Tk+1
In the previous presentation we have computed Λe
fand Υe
f. Let us now turn to Σe
fand Ωe
f.
Σe
f=Zxk+1
xk
f(x)ρcpu∂T
∂x dx
=Zxk+1
xk
f(x)ρcpu∂[Nθ
k(x)Tk+Nθ
k+1(x)Tk+1]
∂x dx
=Zxk+1
xk
f(x)ρcpu∂Nθ
k
∂x Tkdx +Zxk+1
xk
f(x)ρcpu∂Nθ
k+1
∂x Tk+1dx
=Zxk+1
xk
f(x)ρcpu∂Nθ
k
∂x dxTk+ Zxk+1
xk
f(x)ρcpu∂Nθ
k+1
∂x dx!Tk+1
Taking f(x) = Nθ
k(x) and omitting ’(x)’ in the rhs:
Σe
Nθ
k=Zxk+1
xk
ρcpuNθ
k
∂Nθ
k
∂x dxTk+ Zxk+1
xk
ρcpuNθ
k
∂Nθ
k+1
∂x dx!Tk+1
Taking f(x) = Nθ
k+1(x) and omitting ’(x)’ in the rhs:
Σe
Nθ
k+1 =Zxk+1
xk
ρcpuNθ
k+1
∂Nθ
k
∂x dxTk+ Zxk+1
xk
ρcpuNθ
k+1
∂Nθ
k+1
∂x dx!Tk+1
45
ΣNθ
k
ΣNθ
k+1
=
Rxk+1
xkρcpuNθ
k
∂Nθ
k
∂x dx Rxk+1
xkρcpuNθ
k
∂Nθ
k+1
∂x dx
Rxk+1
xkρcpuNθ
k+1
∂Nθ
k
∂x dx Rxk+1
xkρcpuNθ
k+1
∂Nθ
k+1
∂x dx
·
Tk
Tk+1
or,
ΣNθ
k
ΣNθ
k+1
=
Zxk+1
xk
ρcpu
Nθ
k
∂Nθ
k
∂x Nθ
k
∂Nθ
k+1
∂x
Nθ
k+1
∂Nθ
k
∂x Nθ
k+1
∂Nθ
k+1
∂x
dx
·
Tk
Tk+1
Finally, we have already defined the vectors
NT=
Nθ
k(x)
Nθ
k+1(x)
BT=
∂Nθ
k
∂x
∂Nθ
k+1
∂x
Te=
Tk
Tk+1
so that
ΣNθ
k
ΣNθ
k+1
=Zxk+1
xk
NTρcpu
Bdx·
Te=Ka·
Te
One can easily show that
Ke
a=ρcpu
−1/2 1/2
−1/2 1/2
Note that the matrix Ke
ais not symmetric.
Let us now look at the source term:
Ωe
f=Zxk+1
xk
f(x)H(x)dx
Taking f(x) = Nθ
k(x):
ΩNθ
k=Zxk+1
xk
Nθ
k(x)H(x)dx
Taking f(x) = Nθ
k+1(x):
ΩNθ
k+1 =Zxk+1
xk
Nθ
k+1(x)H(x)dx
We can rearrange both equations as follows:
ΩNθ
k
ΩNθ
k+1
=
Rxk+1
xkNθ
k(x)H(x)dx
Rxk+1
xkNθ
k+1(x)H(x)dx
or,
ΩNθ
k
ΩNθ
k+1
=
Zxk+1
xk
Nθ
k(x)H(x)
Nθ
k+1(x)H(x)
dx
so that
ΩNθ
k
ΩNθ
k+1
= Zxk+1
xk
NTH(x)dx!
46
The weak form discretised over 1 element becomes
Zxk+1
xk
NTρcpNdx
| {z }
Me
·˙
Te+Zxk+1
xk
NTρcpuBdx
| {z }
Ke
a
·
Te+Zxk+1
xk
BTkBdx
| {z }
Ke
d
·
Te=Zxk+1
xk
NTH(x)dx
| {z }
~
Fe
or,
Me·˙
Te+ (Ke
d+Ke
a)·
Te=
Fe
or,
Me·∂
Te
∂t + (Ke
a+Ke
d)·
Te=
Fe
5.3 The advection-diffusion equation in 2D
We start from the ’bare-bones’ heat transport equation (source terms are omitted):
ρcp∂T
∂t +
ν·
∇T=
∇ · k
∇T(99)
In what follows we assume that the velocity vield
νis known so that temperature is the only unknwon.
Let Nθbe the temperature basis functions so that the temperature inside an element is given by4:
Th(r) =
mT
X
i=1
Nθ(r)Ti=
Nθ·
T(100)
where
Tis a vector of length mTThe weak form is then
ZΩ
Nθ
iρcp∂T
∂t +
ν·
∇TdΩ = ZΩ
Nθ
i
∇ · k
∇T dΩ (101)
ZΩ
Nθ
iρcp
∂T
∂t dΩ
| {z }
I
+ZΩ
Nθ
iρcp
ν·
∇T dΩ
| {z }
II
=ZΩ
Nθ
i
∇ · k
∇T dΩ
| {z }
III
i= 1, mT
Looking at the first term:
ZΩ
Nθ
iρcp
∂T
∂t dΩ = ZΩ
Nθ
iρcp
Nθ·˙
T dΩ (102)
(103)
so that when we assemble all contributions for i= 1, mTwe get:
I=ZΩ
Nθρcp
Nθ·˙
T dΩ = ZΩ
ρcp
Nθ
NθdΩ·˙
T=MT·˙
T
where MTis the mass matrix of the system of size (mT×mT) with
MT
ij =ZΩ
ρcpNθ
iNθ
jdΩ
Turning now to the second term:
ZΩ
Nθ
iρcp
ν·
∇T dΩ = ZΩ
Nθ
iρcp(u∂T
∂x +v∂T
∂y )dΩ (104)
=ZΩ
Nθ
iρcp(u∂
Nθ
∂x +v∂
Nθ
∂y )·
T dΩ (105)
(106)
4the θsuperscript has been chosen to denote temperature so as to avoid confusion with the transpose operator
47
so that when we assemble all contributions for i= 1, mTwe get:
II = ZΩ
ρcp
Nθ(u∂
Nθ
∂x +v∂
Nθ
∂y )dΩ!·
T=Ka·
T
where Kais the advection term matrix of size (mT×mT) with
(Ka)ij =ZΩ
ρcpNθ
i u∂Nθ
j
∂x +v∂N θ
j
∂y !dΩ
Now looking at the third term, we carry out an integration by part and neglect the surface term for now,
so that
ZΩ
Nθ
i
∇ · k
∇T dΩ = −ZΩ
k
∇Nθ
i·
∇T dΩ (107)
=−ZΩ
k
∇Nθ
i·
∇(
Nθ·
T)dΩ (108)
(109)
with
∇
Nθ=
∂xNθ
1∂xNθ
2. . . ∂xNθ
mT
∂yNθ
1∂yNθ
2. . . ∂yNθ
mT
so that finally:
III =−ZΩ
k(
∇
Nθ)T·
∇
NθdΩ·
T=−Kd·
T
where Kdis the diffusion term matrix:
Kd=ZΩ
k(
∇
Nθ)T·
∇
NθdΩ
Ultimately terms I, II, III together yield:
Mθ·˙
T+ (Ka+Kd)·
T=
0
What now remains to be done is to address the time derivative on the temperature vector. The most
simple approach would be to use an explicit Euler one, i.e.:
∂
T
∂t =
T(k)−
T(k−1)
δt
where
T(k)is the temperature field at time step kand δt is the time interval between two consecutive
time steps. In this case the discretised heat transport equation is:
Mθ+ (Ka+Kd)δt·
T(k)=Mθ·
T(k−1)
add source term!!
Let us then write this equation at times tand t+δt :
Mθ(t)·˙
T(t) + K(t)·
T(t) =
F(t) (110)
Mθ(t+δt)·˙
T(t+δt) + K(t+δt)·
T(t+δt) =
F(t+δt) (111)
The time derivative of temperature can be written as follows:
T(t+δt)−
T(t)
δt =α˙
T(t+δt) + (1 −α)˙
T(t)
48
If α= 0 then this is a fully implicit scheme, if α= 1 this is a fully explicit scheme. If α= 1/2 this is a
second order accurate, mid-point implicit scheme One can multiply Eq. (110) by 1 −αand Eq. (111) by
αand sum them :
(1 −α)Mθ(t)·˙
T(t) + (1 −α)K(t)·
T(t) = (1 −α)
F(t)
+αM(t+δt)·˙
T(t+δt) + αK(t+δt)·
T(t+δt) +α
F(t+δt)
Assuming Mθ(t)≈Mθ(t+δt), K(t+δt) = K(t) and
F(t)≈
F(t+δt), then
M(t)·
T(t+δt)−
T(t)
δt + (1 −α)K(t)·
T(t) + αK(t)·
T(t+δt) =
F(t)
and finally
Mθ(t) + αK(t)δt·
T(t+δt) = Mθ(t)−(1 −α)K(t)δt·
T(t) +
F(t)δt
or,
A·
T=
b
with
A=Mθ(t) + αK(t)δt
b=Mθ(t)−(1 −α)K(t)δt·
T(t) +
F(t)δt
there’s got to be a prettier way to arrive at this ...
49
6 Solving the flow equations with the FEM
In the case of an incompressible flow, we have seen that the continuity (mass conservation) equation takes
the simple form
∇·v = 0. In other word flow takes place under the constraint that the divergence of its
velocity field is exactly zero eveywhere (solenoidal constraint), i.e. it is divergence free.
We see that the pressure in the momentum equation is then a degree of freedom which is needed to
satisfy the incompressibilty constraint (and it is not related to any constitutive equation) [158]. In other
words the pressure is acting as a Lagrange multiplier of the incompressibility constraint.
Various approaches have been proposed in the literature to deal with the incompressibility constraint
but we will only focus on the penalty method (section 6.3) and the so-called mixed finite element method
6.4.
6.1 Strong and weak forms
The strong form consists of the governing equation and the boundary conditions, i.e. the mass, momentum
and energy conservation equations supplemented with Dirichlet and/or Neumann boundary conditions
on (parts of) the boundary.
To develop the finite element formulation, the partial differential equations must be restated in an
integral form called the weak form. In essence the PDEs are first multiplied by an arbitrary function and
integrated over the domain.
6.2 Which velocity-pressure pair for Stokes?
The success of a mixed finite element formulation crucially depends on a proper choice of the local
interpolations of the velocity and the pressure.
6.2.1 The compatibility condition (or LBB condition)
’LBB stable’ elements assure the existence of a unique solution and assure convergence at the optimal
rate.
6.2.2 Families
The family of Taylor-Hood finite element spaces on triangular/tetrahedral grids is given by Pk×Pk−1
with k≥2, and on quadrilateral/hexahedral grids by Qk×Qk−1with k≥2. This means that the
pressure is then approximated by continuous functions.
These finite elements are very popular, in particular the pairs for k= 2, i.e. Q2×Q1and P2×P1.
The reason why k≥2 comes from the fact that the Q1×Q0(i.e. Q1×P0) and P2×P1are not stable
elements (they are not inf-sup stable).
Remark. Note that a similar element to Q2×Q1has been proposed and used succesfully used [510, 288]:
it is denoted by Q(8)
2×Q1since the center node (’x2y2’) and its associated degrees of freedom have been
removed. It has also been proved to be LBB stable.
The Raviart-Thomas familyon triangles and quadrilaterals. find literaturefind literature
50
6.2.3 The bi/tri-linear velocity - constant pressure element (Q1×P0)
01
2
3
νp
4 vel. nodes, 1 press. nodes
νp
8 vel. nodes, 1 press. nodes
discussed in example 3.71 of [311]
However simple it may look, the element is one of the hardest elements to analyze and many questions
are still open about its properties. The element does not satisfy the inf-sup condition [290]p211. In [266]
it is qualified as follows: slightly unstable but highly usable.
The Q1×P0mixed approximation is the lowest order conforming approximation method defined on
a rectangular grid. It also happens to be the most famous example of an unstable mixed approximation
method. [174, p235].
This element is discussed in [195], [196] and in [427] in the context of multigrid use.
This element is plagued by so-called pressure checkerboard modes which have been thoroughly anal-
ysed [268], [119], [467, 468]. These can be filtered out [119]. Smoothing techniques are also discussed in
[346].
6.2.4 The bi/tri-quadratic velocity - discontinuous linear pressure element (Q2×P−1)
This element is crowned ”probably the most accurate 2D element” in [266].
6.2.5 The bi/tri-quadratic velocity - bi/tri-linear pressure element (Q2×Q1)
01
2
3
4
5
6
7 8
νp
27 vel. nodes, 8 press. nodes
νp
27 vel. nodes, 8 press. nodes
In [266] Gresho & Sani write that in their opinion div(v) = 0 is not strong enough.
This element, implemented in penalised form, is discussed in [50] and the follow-up paper [51]. CHECK
Biquadratic velocities, bilinear pressure. See Hood and Taylor. The element satisfies the inf-sup
condition [290]p215.
51
6.2.6 The stabilised bi/tri-linear velocity - bi/tri-linear pressure element (Q1×Q1-stab)
01
2
3
νp
4 vel. nodes, 4 press. nodes
νp
8 vel. nodes, 8 press. nodes
6.2.7 The MINI triangular element (P+
1×P1)
discussed in section 3.6.1 of [311]
6.2.8 The quadratic velocity - linear pressure triangle (P2×P1)
From [477]. Taylor-Hood elements (Taylor and Hood 1973) are characterized by the fact that the pressure
is continuous in the region Ω. A typical example is the quadratic triangle (P2P1 element). In this element
the velocity is approximated by a quadratic polynomial and the pressure by a linear polynomial. One
can easily verify that both approximations are continuous over the element boundaries. It can be shown,
Segal (1979), that this element is admissible if at least 3 elements are used. The quadrilateral counterpart
of this triangle is the Q2×Q1element.
6.2.9 The Crouzeix-Raviart triangle (P+
2×P−1)
This element was first introduced in [140].
From [145]: seven-node Crouzeix-Raviart triangle with quadratic velocity shape functions enhanced
by a cubic bubble function and discontinuous linear interpolation for the pressure field [e.g., Cuvelier et
al., 1986]. This element is stable and no additional stabilization techniques are required [Elman et al.,
2005].
From [477]. These elements are characterized by a discontinuous pressure; discontinuous on element
boundaries. For output purposes (printing, plotting etc.) these discontinuous pressures are averaged in
vertices for all the adjoining elements.
The most simple Crouzeix-Raviart element is the non-conforming linear triangle with constant pressure
(P1×P0).
p248 of Elman book. satisfies LBB condition.
This element is characterized by a discontinuous pressure; so that for output purposes (printing,
plotting etc.) these discontinuous pressures are averaged in vertices for all the adjoining elements.
52
6.2.10 The Rannacher-Turek element - rotated Q1×P0
p. 722 of [311]
6.2.11 Other elements
•P1P0 example 3.70 in [311]
•P1P1
•Q2P0: Quadratic velocities, constant pressure. The element satisfies the inf-sup condition, but the
constant pressure assumption may require fine discretisation.
•Q2Q2: This element is never used, probably because a) it is unstable, b) it is very costly. There is
one reference to it in [291].
•P2P2
•the MINI quadrilateral element Q+
1×Q1.
6.3 The penalty approach for viscous flow
In order to impose the incompressibility constraint, two widely used procedures are available, namely the
Lagrange multiplier method and the penalty method [34, 290]. The latter is implemented in elefant,
which allows for the elimination of the pressure variable from the momentum equation (resulting in a
reduction of the matrix size).
Mathematical details on the origin and validity of the penalty approach applied to the Stokes problem
can for instance be found in [144], [452] or [271].
The penalty formulation of the mass conservation equation is based on a relaxation of the incompress-
ibility constraint and writes
∇ ·
ν+p
λ= 0 (112)
where λis the penalty parameter, that can be interpreted (and has the same dimension) as a bulk
viscosity. It is equivalent to say that the material is weakly compressible. It can be shown that if one
chooses λto be a sufficiently large number, the continuity equation
∇ ·
ν= 0 will be approximately
satisfied in the finite element solution. The value of λis often recommended to be 6 to 7 orders of
magnitude larger than the shear viscosity [158, 292].
Equation (112) can be used to eliminate the pressure in the momentum equation so that the mass
and momentum conservation equations fuse to become :
∇ · (2η˙ε(
ν)) + λ
∇(
∇ ·
ν) = ρg= 0 (113)
[374] have established the equivalence for incompressible problems between the reduced integration of
the penalty term and a mixed Finite Element approach if the pressure nodes coincide with the integration
points of the reduced rule.
In the end, the elimination of the pressure unknown in the Stokes equations replaces the original
saddle-point Stokes problem [48] by an elliptical problem, which leads to a symmetric positive definite
(SPD) FEM matrix. This is the major benefit of the penalized approach over the full indefinite solver
with the velocity-pressure variables. Indeed, the SPD character of the matrix lends itself to efficient
solving stragegies and is less memory-demanding since it is sufficient to store only the upper half of the
matrix including the diagonal [251] .
list codes which use this approach
Since the penalty formulation is only valid for incompressible flows, then ˙
=˙
dso that the dsuper-
script is ommitted in what follows. Because the stress tensor is symmetric one can also rewrite it the
53
following vector format:
σxx
σyy
σzz
σxy
σxz
σyz
=
−p
−p
−p
0
0
0
+ 2η
˙xx
˙yy
˙zz
˙xy
˙xz
˙yz
=λ
˙xx + ˙yy + ˙zz
˙xx + ˙yy + ˙zz
˙xx + ˙yy + ˙zz
0
0
0
+ 2η
˙xx
˙yy
˙zz
˙xy
˙xz
˙yz
=
λ
111000
111000
111000
000000
000000
000000
| {z }
K
+η
200000
020000
002000
000100
000010
000001
| {z }
C
·
∂u
∂x
∂v
∂y
∂w
∂z
∂u
∂y +∂v
∂x
∂u
∂z +∂w
∂x
∂v
∂z +∂w
∂y
Remember that
∂u
∂x =
4
X
i=1
∂Ni
∂x ui
∂v
∂y =
4
X
i=1
∂Ni
∂y vi
∂w
∂z =
4
X
i=1
∂Ni
∂z wi
and
∂u
∂y +∂v
∂x =
4
X
i=1
∂Ni
∂y ui+
4
X
i=1
∂Ni
∂x vi
∂u
∂z +∂w
∂x =
4
X
i=1
∂Ni
∂z ui+
4
X
i=1
∂Ni
∂x wi
∂v
∂z +∂w
∂y =
4
X
i=1
∂Ni
∂z vi+
4
X
i=1
∂Ni
∂y wi
so that
∂u
∂x
∂v
∂y
∂w
∂z
∂u
∂y +∂v
∂x
∂u
∂z +∂w
∂x
∂v
∂z +∂w
∂y
=
∂N1
∂x 0 0 ∂N2
∂x 0 0 ∂N3
∂x 0 0 . . . ∂N4
∂x 0 0
0∂N1
∂y 0 0 ∂N2
∂y 0 0 ∂N3
∂y 0. . . 0∂N4
∂y 0
0 0 ∂N1
∂z 0 0 ∂N2
∂z 0 0 ∂N3
∂z . . . 0 0 ∂N4
∂z
∂N1
∂y
∂N1
∂x 0∂N2
∂y
∂N2
∂x 0∂N3
∂y
∂N3
∂x 0. . . ∂N4
∂y
∂N4
∂x 0
∂N1
∂z 0∂N1
∂x
∂N2
∂z 0∂N2
∂x
∂N3
∂z 0∂N3
∂x . . . ∂N4
∂z 0∂N4
∂x
0∂N1
∂z
∂N1
∂y 0∂N2
∂z
∂N2
∂y 0∂N3
∂z
∂N3
∂y . . . 0∂N4
∂z
∂N4
∂y
| {z }
B(6×24)
·
u1
v1
w1
u2
v2
w2
u3
v3
w3
. . .
u8
v8
w8
| {z }
~
V(24×1)
54
Finally,
σ =
σxx
σyy
σzz
σxy
σxz
σyz
= (λK+ηC)·B·
V
We will now establish the weak form of the momentum conservation equation. We start again from
∇ · σ+
b=
0
For the Ni’s ’regular enough’, we can write:
ZΩe
Ni
∇ · σdΩ + ZΩe
Ni
b dΩ=0
We can integrate by parts and drop the surface term5:
ZΩe
∇Ni·σdΩ = ZΩe
Ni
b dΩ
or,
ZΩe
∂Ni
∂x 0 0 ∂Ni
∂y
∂Ni
∂z 0
0∂Ni
∂y 0∂Ni
∂x 0∂Ni
∂z
0 0 ∂Ni
∂z 0∂Ni
∂x
∂Ni
∂y
·
σxx
σyy
σzz
σxy
σxz
σyz
dΩ = ZΩe
Ni
b dΩ
Let i= 1,2,3,4, . . . 8 and stack the resulting eight equations on top of one another.
ZΩe
∂Ni
∂x 0 0 ∂Ni
∂y
∂Ni
∂z 0
0∂Ni
∂y 0∂Ni
∂x 0∂Ni
∂z
0 0 ∂Ni
∂z 0∂Ni
∂x
∂Ni
∂y
·
σxx
σyy
σzz
σxy
σxz
σyz
dΩ = ZΩe
N1
bx
by
bz
dΩ
ZΩe
∂Ni
∂x 0 0 ∂Ni
∂y
∂Ni
∂z 0
0∂Ni
∂y 0∂Ni
∂x 0∂Ni
∂z
0 0 ∂Ni
∂z 0∂Ni
∂x
∂Ni
∂y
·
σxx
σyy
σzz
σxy
σxz
σyz
dΩ = ZΩe
N2
bx
by
bz
dΩ
. . .
ZΩe
∂N8
∂x 0 0 ∂N8
∂y
∂N8
∂z 0
0∂N8
∂y 0∂N8
∂x 0∂N8
∂z
0 0 ∂N8
∂z 0∂N8
∂x
∂N8
∂y
·
σxx
σyy
σzz
σxy
σxz
σyz
dΩ = ZΩe
N8
bx
by
bz
dΩ (114)
We easily recognize BTinside the integrals! Let us define
NT
b= (N1bx, N1by, N1bz...N8bx, N8by, N8bz)
5We will come back to this at a later stage
55
then we can write
ZΩe
BT·
σxx
σyy
σzz
σxy
σxz
σyz
dΩ = ZΩe
NbdΩ
and finally: ZΩe
BT·[λK+ηC]·B·
V dΩ = ZΩe
NbdΩ
Since
Vcontains is the vector of unknowns (i.e. the velocities at the corners), it does not depend on the
xor ycoordinates so it can be taking outside of the integral:
ZΩe
BT·[λK+ηC]·BdΩ
| {z }
Ael(24×24)
·
V
|{z}
(24×1)
=ZΩe
NbdΩ
| {z }
~
Bel(24×1)
or,
ZΩe
λBT·K·BdΩ
| {z }
Aλ
el(24×24)
+ZΩe
ηBT·C·BdΩ
| {z }
Aη
el(24×24)
·
V
|{z}
(24×1)
=ZΩe
NbdΩ
| {z }
~
Bel(24×1)
reduced integration
reduced integration [292]
write about 3D to 2D
6.4 The mixed FEM for viscous flow
6.4.1 in three dimensions
In what follows the flow is assumed to be incompressible, isoviscous and isothermal.
The methodology to derive the discretised equations of the mixed system is quite similar to the one
we have used in the case of the penalty formulation. The big difference comes from the fact that we are
now solving for both velocity and pressure at the same time, and that we therefore must solve the mass
and momentum conservation equations together. As before, velocity inside an element is given by
νh(r) =
mv
X
i=1
Nν
i(r)
νi(115)
where Nv
iare the polynomial basis functions for the velocity, and the summation runs over the mvnodes
composing the element. A similar expression is used for pressure:
ph(r) =
mp
X
i=1
Np
i(r)pi(116)
Note that the velocity is a vector of size while pressure (and temperature) is a scalar. There are then ndofv
velocity degrees of freedom per node and ndofppressure degrees of freedom. It is also very important
to remember that the numbers of velocity nodes and pressure nodes for a given element are more often
than not different and that velocity and pressure nodes need not be colocated. Indeed, unless co-called
’stabilised elements’ are used, we have mv> mp, which means that the polynomial order of the velocity
field is higher than the polynomial order of the pressure field (usually by value 1).
insert here link(s) to manual and literature
Other notations are sometimes used for Eqs.(115) and (116):
uh(r) =
Nν·u vh(r) =
Nν·v wh(r) =
Nν·w ph(r) =
Np·p (117)
56
where
ν= (u, v, w) and
Nνis the vector containing all basis functions evaluated at location r:
Nv=Nν
1(r), Nν
2(r), Nν
3(r),...Nν
mv(r)(118)
Np=Np
1(r), Np
2(r), Np
3(r),...Np
mp(r)(119)
and with
u = (u1, u2, u3,...umv) (120)
v = (v1, v2, v3,...vmv) (121)
w = (w1, w2, w3,...wmv) (122)
p =p1, p2, p3,...pmp(123)
We will now establish the weak form of the momentum conservation equation. We start again from
∇ · σ+
b=
0 (124)
∇ ·v = 0 (125)
For the Nν
i’s and Np
i’regular enough’, we can write:
ZΩe
Nν
i
∇ · σdΩ + ZΩe
Nν
i
b dΩ =
0 (126)
ZΩe
Np
i
∇ ·vdΩ = 0 (127)
We can integrate by parts and drop the surface term6:
ZΩe
∇Nν
i·σdΩ = ZΩe
Nν
i
bdΩ (128)
ZΩe
Np
i
∇ ·vdΩ = 0 (129)
or,
ZΩe
∂Nν
i
∂x 0 0 ∂Nν
i
∂y
∂Nν
i
∂z 0
0∂Nν
i
∂y 0∂Nν
i
∂x 0∂Nν
i
∂z
0 0 ∂Nν
i
∂z 0∂Nν
i
∂x
∂Nν
i
∂y
·
σxx
σyy
σzz
σxy
σxz
σyz
dΩ = ZΩe
Nν
i
b dΩ (130)
As before (see section XXX) the above equation can ultimately be written:
ZΩe
BT·
σxx
σyy
σzz
σxy
σxz
σyz
dΩ = ZΩe
NbdΩ (131)
6We will come back to this at a later stage
57
We have previously established that the strain rate vector
˙εis:
˙ε=
∂u
∂x
∂v
∂y
∂w
∂z
∂u
∂y +∂v
∂x
∂u
∂z +∂w
∂x
∂v
∂z +∂w
∂y
=
P
i
∂Nν
i
∂x ui
P
i
∂Nν
i
∂y vi
P
i
∂Nν
i
∂z wi
P
i
(∂Nν
i
∂y ui+∂Nν
i
∂x vi)
P
i
(∂Nν
i
∂z ui+∂Nν
i
∂x wi)
P
i
(∂Nν
i
∂z vi+∂Nν
i
∂y wi)
=
∂Nν
1
∂x 0 0 ··· ∂N ν
mv
∂x 0 0
0∂Nν
1
∂y 0··· 0∂Nν
mv
∂y 0
0 0 ∂Nν
1
∂z ··· 0 0 ∂Nν
mv
∂z
∂Nν
1
∂y
∂Nν
1
∂x 0··· ∂Nν
mv
∂x
∂Nν
mv
∂x 0
∂Nν
1
∂z 0∂Nν
1
∂x ··· ∂Nν
mv
∂z 0∂Nν
mv
∂x
0∂Nν
1
∂z
∂Nν
1
∂y ··· 0∂Nν
mv
∂z
∂Nν
mv
∂y
| {z }
B
·
u1
v1
w1
u2
v2
w2
u3
v3
. . .
umv
vmv
wmv
|{z }
~
V
(132)
or,
˙ε=B·
Vwhere Bis the gradient matrix and
Vis the vector of all vector degrees of freedom for the
element. The matrix Bis then of size 3 ×mv×ndim and the vector
Vis mv∗ndof long. we have
σxx =−p+ 2η˙εd
xx (133)
σyy =−p+ 2η˙εd
yy (134)
σzz =−p+ 2η˙εd
zz (135)
σxy = 2η˙εd
xy (136)
σxz = 2η˙εd
xz (137)
σyz = 2η˙εd
yz (138)
Since we here only consider incompressible flow, we have ˙
εd=˙
εso
σ =−
1
1
1
0
0
0
p+C·
˙ε=−
1
1
1
0
0
0
Np·
P+C·B·
V(139)
with
C=η
200000
020000
002000
000100
000010
000001
˙ε=
˙εxx
˙εyy
˙εzz
2 ˙εxy
2 ˙εxz
2 ˙εyz
(140)
Let us define matrix Npof size 6 ×mp:
Np=
1
1
1
0
0
0
Np=
Np
Np
Np
0
0
0
(141)
so that
σ =−Np·
P+C·B·
V(142)
58
finally ZΩe
BT·[−Np·
P+C·B·
V]dΩ = ZΩe
NbdΩ (143)
or, −ZΩe
BT·NpdΩ
| {z }
G
·
P+ZΩe
BT·C·BdΩ
| {z }
K
·
V=ZΩe
NbdΩ
| {z }
~
f
(144)
where the matrix Kis of size (mv∗ndofv×mv∗ndofv), and matrix Gis of size (mv∗ndofv×mp∗ndofp).
Turning now to the mass conservation equation:
0 = ZΩe
Np
∇ ·v dΩ
=ZΩe
Np
mv
X
i=1 ∂Nν
i
∂x ui+∂N ν
i
∂y vi+∂N ν
i
∂z widΩ
=ZΩe
Np
1mv
P
i=1
∂Nν
i
∂x ui+
mv
P
i=1
∂Nν
i
∂y vi+
mv
P
i=1
∂Nν
i
∂z wi
Np
2mv
P
i=1
∂Nν
i
∂x ui+
mv
P
i=1
∂Nν
i
∂y vi+
mv
P
i=1
∂Nν
i
∂z wi
Np
3mv
P
i=1
∂Nν
i
∂x ui+
mv
P
i=1
∂Nν
i
∂y vi+
mv
P
i=1
∂Nν
i
∂z wi
. . .
Np
mpmv
P
i=1
∂Nν
i
∂x ui+
mv
P
i=1
∂Nν
i
∂y vi+
mv
P
i=1
∂Nν
i
∂z wi
dΩ
=ZΩe
Np
1Np
1Np
1000
Np
2Np
2Np
2000
Np
3Np
3Np
3000
.
.
..
.
..
.
..
.
..
.
..
.
.
Np
mpNp
mpNp
mp000
·
P
i
∂Nν
i
∂x ui
P
i
∂Nν
i
∂y vi
P
i
∂Nν
i
∂z wi
P
i
(∂Nν
i
∂y ui+∂Nν
i
∂x vi)
P
i
(∂Nν
i
∂z ui+∂Nν
i
∂x wi)
P
i
(∂Nν
i
∂z vi+∂Nν
i
∂y wi)
dΩ
=ZΩe
Np
1Np
1Np
1000
Np
2Np
2Np
2000
Np
3Np
3Np
3000
.
.
..
.
..
.
..
.
..
.
..
.
.
Np
mpNp
mpNp
mp000
| {z }
Np
·
˙ε dΩ
=ZNp·BdΩ·
V
=−GT
e·
V(145)
Note that it is common to actually start from −
∇·v = 0 (see Eq.(3) in [2]) so as to arrive at GT
e·
V=
0
Ultimately we obtain the following system for each element:
KeGe
−GT
e0·
V
P=
fe
0
59
Such a matrix is then generated for each element and then must me assembled into the global F.E. matrix.
Note that in this case the elemental Stokes matrix is antisymmetric. One can also define the following
symmetric modified Stokes matrix:
KeGe
GT
e0·
V
P=
fe
0
This matrix is symmetric, but indefinite. It is non-singular if ker(GT) = 0, which is the case if the
compatibility condition holds.
CHECK: Matrix Kis the viscosity matrix. Its size is (ndofv∗Nv)×(ndofv∗Nv) where ndofvis
the number of velocity degrees of freedom per node (typically 1,2 or 3) and Nvis the number of velocity
nodes. The size of matrix Gis (ndofv∗Nv)×(ndofp∗Np) where ndofp(= 1) is the number of velocity
degrees of freedom per node and Npis the number of pressure nodes. Conversely, the size of matrix GT
is (ndofp∗Np)×(ndofv∗Nv). The size of the global FE matrix is N=ndofv∗Nv+ndofp∗NpNote
that matrix Kis analogous to a discrete Laplacian operator, matrix Gto a discrete gradient operator,
and matrix GTto a discrete divergence operator.
On the physical dimensions of the Stokes matrix blocks We start from the Stokes equations:
−
∇p+
∇ · (2η˙
ε) + ρg= 0 (146)
∇ ·
ν= 0 (147)
The dimensions of the terms in the first equation are: ML−2T−2. The blocks Kand Gstem from
the weak form which obtained by multiplying the strong form equations by the (dimensionless) basis
functions and integrating over the domain, so that it follows that
[K·
V]=[G·
P]=[
f] = ML−2T−2L3=MLT −2
We can then easily deduce:
[K] = MT −1[G] = L2
On elemental level mass balance. Note that in what is above no assumption has been made about
whether the pressure basis functions are continuous or discontinuous from one element to another.
Indeed, as mentioned in [266], since the weak formulation of the momentum equation involves inte-
gration by parts of
∇p, the resulting weak form contains no derivatives of pressure. This introduces the
possibility of approximating it by functions (piecewise polynomials, of course) that are not C0-continuous,
and indeed this has been done and is quite popular/useful.
It is then worth noting that only discontinuous pressure elements assure an element-level mass balance
[266]: if for instance Np
iis piecewise-constant on element e(of value 1), the elemental weak form of the
mass conservervation equation is
ZΩe
Np
i
∇ ·
ν=ZΩe
∇ ·
ν=ZΓe
n ·
ν= 0
One potentially unwelcome consequence of using discontinuous pressure elements is that they do not
possess uniquely defined pressure on the element boundaries; they are dual valued there, and often
multi-valued at certain velocity nodes.
60
On the Cmatrix The relationship between deviatoric stress and deviatoric strain rate tensor is
τ= 2η˙
εd(148)
= 2η˙
ε−1
3(
∇ ·v)1(149)
= 2η
˙εxx ˙εxy ˙εxz
˙εyx ˙εyy ˙εyz
˙εzx ˙εzy ˙εzz
−1
3( ˙εxx + ˙εyy + ˙εzz)
100
010
001
(150)
=2
3η
2 ˙εxx −˙εyy −˙εzz 3 ˙εxy 3 ˙εxz
3 ˙εyx −˙εyy + 2 ˙εyy −˙εyy 3 ˙εyz
3 ˙εzx 3 ˙εzy −˙εxx −˙εyy2 ˙εzz
(151)
so that
τ =2
3η
2 ˙εxx −˙εyy −˙εzz
−˙εyy + 2 ˙εyy −˙εyy
−˙εxx −˙εyy + 2 ˙εzz
3 ˙εxy
3 ˙εxz
3 ˙εyz
=η
3
4−2−2000
−2 4 −2000
−2−2 4 0 0 0
0 0 0 3 0 0
0 0 0 0 3 0
0 0 0 0 0 3
| {z }
Cd
·
˙εxx
˙εyy
˙εzz
2 ˙εxy
2 ˙εxz
2 ˙εyz
=Cd·
˙ε(152)
In two dimensions, we have
τ =1
3η
4−2 0
−240
0 0 3
| {z }
Cd
·
In the case where we assume incompressible flow from the beginning, i.e. ˙
ε=˙
εd, then
τ =η
200000
020000
002000
000100
000010
000001
| {z }
C
·
˙εxx
˙εyy
˙εzz
2 ˙εxy
2 ˙εxz
2 ˙εyz
=C·
˙ε(153)
Two slightly different formulations The momentum conservation equation can be written as follows:
∇ · (2η
˙)−
∇p+
b=
0
When the viscosity ηis constant this equation becomes
η∆v −
∇p+
b=
0
In this case the matrix Btakes a different form [158, Eq. 6.24] and this can have consequences for the
Neumann boundary conditions.
On the ’forgotten’ surface terms
6.4.2 Going from 3D to 2D
The world is three-dimensional. However, for many different reasons one may wish to solve problems
which are two-dimensional.
Following ASPECT manual, we will think of two-dimensional models in the following way:
61
•We assume that the domain we want to solve on is a two-dimensional cross section (in the x−y
plane) that extends infinitely far in both negative and positive zdirection.
•We assume that the velocity is zero in the zdirection and that all variables have no variation in
the zdirection.
As a consequence, two-dimensional models are three-dimensional ones in which the zcomponent of the
velocity is zero and so are all zderivatives. This allows to reduce the momentum conservation equations
from 3 equations to 2 equations. However, contrarily to what is often seen, the 3D definition of the
deviatoric strain rate remains, i.e. in other words:
˙
εd=˙
ε−1
3(
∇ ·v)1(154)
and not 1/2. In light of all this, the full strain rate tensor and the deviatoric strain rate tensor in 2D are
given by:
ε=
˙εxx ˙εxy ˙εxz
˙εyx ˙εyy ˙εyz
˙εzx ˙εzy ˙εzz
=
∂u
∂x
1
2∂u
∂y +∂v
∂x 0
1
2∂u
∂y +∂v
∂x ∂v
∂y 0
0 0 0
(155)
˙
εd=1
3
2∂u
∂x −∂v
∂y
1
2∂u
∂y +∂v
∂x 0
1
2∂u
∂y +∂v
∂x −∂u
∂x + 2∂v
∂y 0
0 0 −∂u
∂x −∂v
∂y
(156)
Although the bottom right term may be surprising, it is of no consequence when this expression of the
deviatoric strain rate is used in the Stokes equation:
∇ · 2η˙
εd=
FINISH!
In two dimensions the velocity is then
ν= (u, v) and the FEM building blocks and matrices are
simply:
˙ε=
˙εxx
˙εyy
2 ˙εxy
=
∂u
∂x
∂v
∂y
∂u
∂y +∂v
∂x
=
∂Nν
1
∂x 0∂Nν
2
∂x 0∂Nν
3
∂x 0. . . ∂Nν
mv
∂x 0
0∂Nν
1
∂y 0∂Nν
2
∂y 0∂Nν
3
∂y . . . 0∂N ν
mv
∂x
∂Nν
1
∂y
∂Nν
1
∂x
∂Nν
2
∂y
∂Nν
2
∂x
∂Nν
3
∂y
∂Nν
3
∂x . . . ∂Nν
mv
∂y
∂Nν
mv
∂x
| {z }
B
·
u1
v1
u2
v2
u3
v3
. . .
umv
vmv
| {z }
~
V
(157)
we have
σxx =−p+ 2η˙εxx (158)
σyy =−p+ 2η˙εyy (159)
σxy = +2η˙εxy (160)
so
σ =−
1
1
0
p+C·
˙ε=−
1
1
0
Np·
P+C·B·
V(161)
62
with
C=η
200
020
001
or C=η
3
4−2 0
−240
0 0 3
(162)
check the right C
Finally the matrix Npis of size 3 ×mp:
Np=
1
1
0
Np=
Np
Np
0
(163)
6.5 Solving the elastic equations
6.6 A quick tour of similar literature
•Treatise on Geophysics, Volume 7, Edited by D. Bercovici and G. Schubert: ”Numerical Methods
for Mantle Convection”, by S.J. Zhong, D.A. Yuen, L.N. Moresi and M.G. Knepley. Note that it
is a revision of the previous edition chapter by S.J. Zhong, D.A. Yuen and L.N. Moresi, Volume 7,
pp. 227252, 2007.
6.7 The case against the Q1×P0element
What follows was written by Dave May and sent to me by email in May 2014. It captures so well the
problem at hand that I have decided to reproduce it hereunder.
In the case of the incompressible Stokes equations, we would like to solve
K G
GT0
V
P=
f
0
with an iterative method which is algorithmically scalable and optimal. Scalable here would mean that
the number of iterations doesn’t grow as the mesh is refined. Optimal means the solution time varies
linearly with the total number of unknowns. When using a stable element, If we right precondition the
above system with
P=K G
0−S
then convergence will occur in 2 iterations, however this requires an exact solve on Kand on S=
GT·K−1·G(Sis the pressure schur complement). In practice, people relax the ideal ”two iteration”
scenario by first replacing Svia S∗=Rη−1
NT
N dv (e.g. the pressure mass matrix scaled by the local
inverse of viscosity).
P∗=K G
0−S∗
Using P∗, we obtain iteration counts which are larger than 2, but likely less than 10 - however, the
number of iterations is independent of the mesh size. Replacing the exact Ksolve in P∗again increases
the iterations required to solve Stokes, but it’s still independent of the number of elements. When you
have this behaviour, we say the preconditioner (P∗) is spectrally equivalent to the operator (which here
is Stokes)
The problem with Q1×P0is that there are no approximations for Swhich can be generated that
ensure a spectrally equivalent P∗. Thus, as you refine the mesh using Q1×P0elements, the iteration
count ALWAYS grows. I worked on this problem during my thesis, making some improvements to the
situation - however the problem still remains, it cannot be completely fixed and stems entirely from using
unstable elements.
Citcom solvers works like this:
1. Solve S· P =
f0for pressure
2. Solve K· V =
f−G· P for velocity
63
To obtain a scalable method, we need the number of iterations performed in (1) and (2) to be independent
of the mesh. This means we need a spectrally equivalent preconditioner for Sand K. Thus, we have the
same issue as when you iterate on the full stokes system.
When we don’t have a scalable method, it means increasing the resolution requires more cpu time
in a manner which cannot be predicted. The increase in iteration counts as the mesh is refined can be
dramatic.
If we can bound the number of iterations, AND ensure that the cost per iteration is linearly related
to the number of unknowns, then we have a good method which can run on any mesh resolution with a
predictable cpu time. Obtaining scalable and optimal preconditioners for Kis somewhat easier. Multi-
grid will provide us with this.
The reason citcom doesn’t run with 4003elements is exactly due to this issue. I’ve added petsc
support in citcom (when i was young and naive) - but the root cause of the non-scalable solve is directly
caused by the element choice. Note that many of the high resolution citcom jobs are single time step
calculations— there is a reason for that.
For many lithosphere dynamics problems, we need a reasonable resolution (at least 2003and realisti-
cally 4003to 8003). Given the increase in cost which occurs when using Q1P0, this is not achievable, as
the citcom code has demonstrated. Note that citcom is 20 years old now and for its time, it was great,
but we know much more now and we know how to improve on it. As a result of this realization, I dumped
all my old Q1P0 codes (and Q1Q1 codes, but for other reasons) in the trash and started from scratch.
The only way to make something like 8003tractable is via iterative, scalable and optimal methods and
that mandates stable elements. I can actually run at something like 10003(nodal points) these days
because of such design choices.
64
7 Additional techniques and features
7.1 The SUPG formulation for the energy equation
7.2 Dealing with a free surface
7.3 Convergence criterion for nonlinear iterations
65
7.4 The method of manufactured solutions
The method of manufactured solutions is a relatively simple way of carrying out code verification. In
essence, one postulates a solution for the PDE at hand (as well as the proper boundary conditions),
inserts it in the PDE and computes the corresponding source term. The same source term and boundary
conditions will then be used in a numerical simulation so that the computed solution can be compared
with the (postulated) true analytical solution.
Examples of this approach are to be found in [158, 107, 62].
7.4.1 Analytical benchmark I - ”Donea & Huerta”
Taken from [158]. We consider a two-dimensional problem in the square domain Ω = [0,1] ×[0,1],
which possesses a closed-form analytical solution. The problem consists of determining the velocity field
ν= (u, v) and the pressure psuch that
η∆
ν−
∇p+
b=
0 in Ω (164)
∇ ·v = 0 in Ω (165)
v =
0 on ΓD(166)
where the fluid viscosity is taken as η= 1. The components of the body force
bare prescribed as
bx= (12 −24y)x4+ (−24 + 48y)x3+ (−48y+ 72y2−48y3+ 12)x2
+(−2 + 24y−72y2+ 48y3)x+ 1 −4y+ 12y2−8y3
by= (8 −48y+ 48y2)x3+ (−12 + 72y−72y2)x2
+(4 −24y+ 48y2−48y3+ 24y4)x−12y2+ 24y3−12y4
With this prescribed body force, the exact solution is
u(x, y) = x2(1 −x)2(2y−6y2+ 4y3)
v(x, y) = −y2(1 −y)2(2x−6x2+ 4x3)
p(x, y) = x(1 −x)−1/6
Note that the pressure obeys RΩp dΩ = 0. One can turn to the spatial derivatives of the fields:
∂u
∂x = (2x−6x2+ 4x3)(2y−6y2+ 4y3) (167)
∂v
∂y =−(2x−6x2+ 4x3)(2y−6y2+ 4y3) (168)
with of course
∇ ·
ν= 0 and
∂p
∂x = 1 −2x(169)
∂p
∂y = 0 (170)
The velocity and pressure fields look like:
http://ww2.lacan.upc.edu/huerta/exercises/Incompressible/Incompressible Ex1.htm
66
As shown in [158], If the LBB condition is not satisfied, spurious oscillations spoil the pressure
approximation. Figures below show results obtained with a mesh of 20x20 Q1P0 (left) and P1P1 (right)
elements:
]]
http://ww2.lacan.upc.edu/huerta/exercises/Incompressible/Incompressible Ex1.htm
Taking into account that the proposed problem has got analytical solution, it is easy to analyze
convergence of the different pairs of elements:
http://ww2.lacan.upc.edu/huerta/exercises/Incompressible/Incompressible Ex1.htm
7.4.2 Analytical benchmark II - ”Dohrmann & Bochev 2D”
Taken from [157]. It is for a unit square with ν=µ/ρ = 1 and the smooth exact solution is
u(x, y) = x+x2−2xy +x3−3xy2+x2y(171)
v(x, y) = −y−2xy +y2−3x2y+y3−xy2(172)
p(x, y) = xy +x+y+x3y2−4/3 (173)
Note that the pressure obeys RΩp dΩ=0
bx=−(1 + y−3x2y2) (174)
by=−(1 −3x−2x3y) (175)
67
7.4.3 Analytical benchmark III - ”Dohrmann & Bochev 3D”
This benchmark begins by postulating a polynomial solution to the 3D Stokes equation [157]:
v=
x+x2+xy +x3y
y+xy +y2+x2y2
−2z−3xz −3yz −5x2yz
(176)
and
p=xyz +x3y3z−5/32 (177)
While it is then trivial to verify that this velocity field is divergence-free, the corresponding body force
of the Stokes equation can be computed by inserting this solution into the momentum equation with a
given viscosity µ(constant or position/velocity/strain rate dependent). The domain is a unit cube and
velocity boundary conditions simply use Eq. (340). Note that the pressure fulfills
ZΩ
p(r)dΩ=0.
Constant viscosity In this case, the right hand side writes:
f=−∇p+µ
2+6xy
2+2x2+ 2y2
−10yz
=−
yz + 3x2y3z
xz + 3x3y2z
xy +x3y3
+µ
2+6xy
2+2x2+ 2y2
−10yz
We can compute the components of the strainrate tensor:
˙εxx = 1 + 2x+y+ 3x2y(178)
˙εyy = 1 + x+ 2y+ 2x2y(179)
˙εzz =−2−3x−3y−5x2y(180)
˙εxy =1
2(x+y+ 2xy2+x3) (181)
˙εxz =1
2(−3z−10xyz) (182)
˙εyz =1
2(−3z−5x2z) (183)
Note that we of course have ˙εxx + ˙εyy + ˙εzz = 0.
Variable viscosity In this case, the right hand side is obtained through
f=−∇p+µ
2+6xy
2+2x2+ 2y2
−10yz
+
2 ˙εxx
2 ˙εxy
2 ˙εxz
∂µ
∂x +
2 ˙εxy
2 ˙εyy
2 ˙εyz
∂µ
∂y +
2 ˙εxz
2 ˙εyz
2 ˙εzz
∂µ
∂z (184)
The viscosity can be chosen to be a smooth varying function:
µ=exp(1 −β(x(1 −x) + y(1 −y) + z(1 −z))) (185)
Choosing β= 0 yields a constant velocity µ=e1(and greatly simplifies the right-hand side). One can
easily show that the ratio of viscosities µ?in the system follows µ?= exp(−3β/4) so that choosing β= 10
68
yields µ?'1808 and β= 20 yields µ?'3.269 ×106. In this case
∂µ
∂x =−4β(1 −2x)µ(x, y, z) (186)
∂µ
∂y =−4β(1 −2y)µ(x, y, z) (187)
∂µ
∂z =−4β(1 −2z)µ(x, y, z) (188)
[107] has carried out this benchmark for β= 4, i.e.:
µ(x, y, z) = exp(1 −4(x(1 −x) + y(1 −y) + z(1 −z)))
In a unit cube, this yields a variable viscosity such that 0.1353 < µ < 2.7182, i.e. a ratio of approx. 20
within the domain. We then have:
∂µ
∂x =−4(1 −2x)µ(x, y, z) (189)
∂µ
∂y =−4(1 −2y)µ(x, y, z) (190)
∂µ
∂z =−4(1 −2z)µ(x, y, z) (191)
sort out mess wrt Eq 26 of busa13
7.4.4 Analytical benchmark IV - ”Bercovier & Engelman”
From [50]. The two-dimensional domain is a unit square. The body forces are:
fx= 128[x2(x−1)212(2y−1) + 2(y−1)(2y−1)y(12x2−12x+ 2)]
fy= 128[y2(y−1)212(2x−1) + 2(x−1)(2x−1)y(12y2−12y+ 2)]
(192)
The solution is
u=−256x2(x−1)2y(y−1)(2y−1)
v= 256x2(y−1)2x(x−1)(2x−1)
p= 0 (193)
Another choice:
fx= 128[x2(x−1)212(2y−1) + 2(y−1)(2y−1)y(12x2−12x+ 2)] + y−1/2
fy= 128[y2(y−1)212(2x−1) + 2(x−1)(2x−1)y(12y2−12y+ 2)] + x−1/2
(194)
The solution is
u=−256x2(x−1)2y(y−1)(2y−1)
v= 256x2(y−1)2x(x−1)(2x−1)
p= (x−1/2)(y−1/2) (195)
7.4.5 Analytical benchmark V - ”VJ”
This is taken from Appendix D1 of [311].
The domain Ω is a unit square. We consider the stream function
φ(x, y) = 1000x2(1 −x)4y3(1 −y)2
69
The velocity field is defined by
u(x, y) = ∂yφ= 1000(x2(1 −x)4y2(1 −y)(3 −5y)) (196)
v(x, y) = −∂xφ= 1000(−2x(1 −x)3(1 −3x)y3(1 −y)2) (197)
and it is easy to verify that
∇ ·v = 0.
The pressure is given by:
p(x, y) = π2(xy3cos(2πx2y)−x2ysin(2πxy)) + 1
8
Taken from [311].
7.4.6 Analytical benchmark VI - ”Ilinca & Pelletier”
This is taken from [300].
Let us consider the Poiseuille flow of a Newtonian fluid. The channel has isothermal flat walls located
at y=±h. The velocity distribution is parabolic:
u=u01−y2
h2v= 0
where u0is the maximum velocity. The (steady state) temperature field is the solution of the advection-
diffusion equation:
ρcpv ·
∇T=k∆T+ Φ
where Φ is the dissipation function given by
Φ = η"2∂u
∂x 2
+ 2 ∂v
∂y 2
+∂v
∂x +∂u
∂y 2#=η∂u
∂y 2
= 4ηu2
0y2
h4
We logically assume that T=T(y) so that ∂T/∂x = 0 and v ·
∇T= 0. We then have to solve:
k∂2T
∂y2+ 4ηu2
0y2
h4= 0
We can integrate twice and use the boundary conditions T(y=±h) = T0to arrive at:
T(y) = T0+1
3
ηu2
0
k1−y
h4
with a maximum temperature
TM=T(y= 0) = T0+1
3
ηu2
0
k
70
7.4.7 Analytical benchmark VII - ”grooves”
This benchmark was designed by Dave May. The velocity and pressure fields are given by
u(x, y) = x3y+x2+xy +x
v(x, y) = −3
2x2y2−2xy −1
2y2−y
p(x, y) = x2y2+xy +5+p0(198)
where p0is a constant to be determined based on the type of pressure normalisation. The viscosity is
chosen to be
η(x, y) = −sin(p) + 1 + =−sin(x2y2+xy + 5) + 1 + (199)
where actually controls the viscosity contrast. Note that inserting the polynomial expression of the
pressure inside the viscosity expression makes the problem linear. We have
˙εxx =∂u
∂x = 3x2y+ 2x+y+ 1
˙εyy =∂v
∂y =−3x2y−2x−y−1
˙εxy =1
2∂u
∂y +∂v
∂x =1
2x3+x−3xy2−2y(200)
and we can verify that the velocity field is incompressible since
∇ ·
ν= ˙εxx + ˙εyy = 0. The pressure
gradient is given by
∂p
∂x = 2xy2+y
∂p
∂y = 2x2y+x
The right hand side term of the Stokes equation is such that
−∂p
∂x +∂sxx
∂x +∂syx
∂y +fx= 0
−∂p
∂y +∂sxy
∂x +∂syy
∂y +fy= 0 (201)
with
∂sxx
∂x =∂(2η˙εxx)
∂x = 2η∂˙εxx
∂x + 2 ∂η
∂x ˙εxx
∂szx
∂z =∂(2η˙εzx)
∂z = 2η∂˙εzx
∂z + 2 ∂η
∂z ˙εzx
∂sxz
∂x =∂(2η˙εxz)
∂x = 2η∂˙εxz
∂x + 2 ∂η
∂x ˙εxz
∂szz
∂z =∂(2η˙εzz)
∂z = 2η∂˙εzz
∂z + 2 ∂η
∂z ˙εzz
∂η
∂x =−z(2xz + 1) cos(x2z2+xz + 5)
∂η
∂z =−x(2xz + 1) cos(x2z2+xz + 5)
∂˙εxx
∂x = 6xz + 2
∂˙εzx
∂z =−3xz −1
∂˙εxz
∂x =1
2(3x2+ 1 −3z2)
∂˙εzz
∂z =−3x2−1
71
Velocity boundary conditions are prescribed on all four boundaries so that the pressure is known up
to a constant (the pressure solution has a nullspace), and the p0constant can be determined by requiring
that
ZL
0ZL
0
p(x, y)dxdy =ZL
0ZL
0
(x2y2+xy+5)dxdy+ZL
0ZL
0
p0dxdy =ZL
0ZL
0
(x2y2+xy+5)dxdy+p0L2= 0
where Lis the size of the square domain. Then
p0=−1
L2ZL
0ZL
0
(x2y2+xy + 5)dxdy =−L4
9−L2
4−5
As seen in the following figure, the value of controls the viscosity field amplitude. This is simply
explained by the fact that when the sin term of the viscosity takes value 1, the viscosity is then equal to
.
Domain size 2x2 with = 0.1,0.01,0.001
Another interesting aspect of this benchmark is the fact that increasing the domain size adds complex-
ity to it as it increases the number of low viscosity zones and the spacing between them also decreases:
Three different domain sizes (1x1, 2x2, 3x3) with = 0.001.
72
Finally, because the analytical expression for both components of the velocity is a polynomial, we can
also compute the root mean square velocity exactly. For instance, for a 2x2 domain:
and we end up with (for L= 2)
vrms =r1
L2
861752
1575 =r215438
1575 '11.6955560683
7.4.8 Analytical benchmark VIII - ”Kovasznay”
This flow was published by L.I.G. Kovasznay in 1948 [337]. This paper presents an exact two-dimensional
solution of the Navier-Stokes equations with a periodicity in the vertical direction, gives an analytical
solution to the steady-state Navier-Stokes equations that is similar which is a flow-field behind a periodic
array of cylinders.
u(x, y)=1−exp(λx) cos(2πy)v(x, y) = λ
2πexp(λx) sin(2πy)λ=Re
2−rRe2
4+ 4π2
Following step-55 of deal.II 7we have to ’cheat’ here since we are not solving the non-linear Navier-
Stokes equations, but the linear Stokes system without convective term. Therefore, to recreate the exact
same solution we move the convective term into the right-hand side.
The analytical solution is prescribed left and right, while free/no (??) slip is prescribed at top and
bottom.
Solution as implemented in step-55:
const double pi2 = pi*pi;
u = -exp(x*(-sqrt(25.0 + 4*pi2) + 5.0))*cos(2*y*pi) + 1;
v = (1.0L/2.0L)*(-sqrt(25.0 + 4*pi2) + 5.0)*exp(x*(-sqrt(25.0 + 4*pi2) + 5.0))*sin(2*y*pi)/pi;
p = -1.0L/2.0L*exp(x*(-2*sqrt(25.0 + 4*pi2) + 10.0))
- 2.0*(-6538034.74494422 + 0.0134758939981709*exp(4*sqrt(25.0 + 4*pi2)))/(-80.0*exp(3*sqrt(25.0 + 4*pi2))
+ 16.0*sqrt(25.0 + 4*pi2)*exp(3*sqrt(25.0 + 4*pi2)))
- 1634508.68623606*exp(-3.0*sqrt(25.0 + 4*pi2))/(-10.0 + 2.0*sqrt(25.0 + 4*pi2))
+ (-0.00673794699908547*exp(sqrt(25.0 + 4*pi2))
+ 3269017.37247211*exp(-3*sqrt(25.0 + 4*pi2)))/(-8*sqrt(25.0 + 4*pi2) + 40.0)
+ 0.00336897349954273*exp(1.0*sqrt(25.0 + 4*pi2))/(-10.0 + 2.0*sqrt(25.0 + 4*pi2));
7https://www.dealii.org/current/doxygen/deal.II/step_55.html
73
7.5 Geodynamical benchmarks
Some published numerical experiments have over time become benchmarks for other codes, while some
others showcased comparisons between codes. Here is a short list of ’famous’ benchmarks’ in the compu-
tational geodynamics community.
•the plastic brick [347, 318, 449]
•2D Rayleigh-Benard convection (Blankenbach) [61, 527, 123, 325, 351, 560, 526]
•2D Rayleigh-Taylor convection/instability [432, 526, 489, 503, 68, 35, 449, 465, 351, 560, 546, 1]
•subduction problems [473, 544]
•numerical sandbox [85, 90]
•the Stokes sphere [341]
•2D compressible Stokes flow problem [350]
•3D convection at infinite Prandtl number (Busse) [108, 527]
•Free surface evolution [138]
go through my papers and add relevant ones here
74
7.6 Assigning values to quadrature points
As we have seen in Section 6, the building of the elemental matrix and rhs requires (at least) to assign
a density and viscosity value to each quadrature point inside the element. Depending on the type of
modelling, this task can prove more complex than one might expect and have large consequences on the
solution accuracy.
Here are several options:
•The simplest way (which is often used for benchmarks) consists in computing the ’real’ coordinates
(xq, yq, zq) of a given quadrature point based on its reduced coordinates (rq, sq, tq), and passing these
coordinates to a function which returns density and/or viscosity at this location. For instance, for
the Stokes sphere:
def rho(x,y):
if (x-.5)**2+(y-0.5)**2<0.123**2:
val=2.
else:
val=1.
return val
def mu(x,y):
if (x-.5)**2+(y-0.5)**2<0.123**2:
val=1.e2
else:
val=1.
return val
This is very simple, but it has been shown to potentially be problematic. In essence, it can introduce
very large contrasts inside a single element and perturb the quadrature. Please read section 3.3
of [282] and/or have a look at the section titled ”Averaging material properties” in the ASPECT
manual.
•another similar approach consists in assigning a density and viscosity value to the nodes of the FE
mesh first, and then using these nodal values to assign values to the quadrature points. Very often
,and quite logically, the shape functions are used to this effect. Indeed we have seen before that for
any point (r, s, t) inside an element we have
fh(r, s, t) =
m
X
i
fiNi(r, s, t)
where the fiare the nodal values and the Nithe corresponding basis functions.
In the case of linear elements (Q1basis functions), this is straightforward. In fact, the basis functions
Nican be seen as moving weights: the closer the point is to a node, the higher the weight (basis
function value).
However, this is quite another story for quadratic elements (Q2basis functions). In order to
illustrate the problem, let us consider a 1D problem. The basis functions are
N1(r) = 1
2r(r−1) N2(r)=1−r2N3(r) = 1
2r(r+ 1)
Let us further assign: ρ1=ρ2= 0 and ρ3= 1. Then
ρh(r) =
m
X
i
ρiNi(r) = N3(r)
There lies the core of the problem: the N3(r) basis function is negative for r∈[−1,0]. This means
that the quadrature point in this interval will be assigned a negative density, which is nonsensical
and numerically problematic!
use 2X Q1. write about it !
75
The above methods work fine as long as the domain contains a single material. As soon as there are
multiple fluids in the domain a special technique is needed to track either the fluids themselves or their
interfaces. Let us start with markers. We are then confronted to the infernal trio (a menage a trois?)
which is present for each element, composed of its nodes, its markers and its quadrature points.
Each marker carries the material information (density and viscosity). This information must ul-
timately be projected onto the quadrature points. Two main options are possible: an algorithm is
designed and projects the marker-based fields onto the quadrature points directly or the marker fields
are first projected onto the FE nodes and then onto the quadrature points using the techniques above.
————————–
At a given time, every element econtains nemarkers. During the FE matrix building process, viscosity
and density values are needed at the quadrature points. One therefore needs to project the values carried
by the markers at these locations. Several approaches are currently in use in the community and the
topic has been investigated by [155] and [163] for instance.
elefant adopts a simple approach: viscosity and density are considered to be elemental values, i.e.
all the markers within a given element contribute to assign a unique constant density and viscosity value
to the element by means of an averaging scheme.
While it is common in the literature to treat the so-called arithmetic, geometric and harmonic means
as separate averagings, I hereby wish to introduce the notion of generalised mean, which is a family of
functions for aggregating sets of numbers that include as special cases the arithmetic, geometric and
harmonic means.
If pis a non-zero real number, we can define the generalised mean (or power mean) with exponent p
of the positive real numbers a1, ... anas:
Mp(a1, ...an) = 1
n
n
X
i=1
ap
i!1/p
(202)
and it is trivial to verify that we then have the special cases:
M−∞ = lim
p→−∞ Mp= min(a1, ...an) (minimum) (203)
M−1=n
1
a1+1
a2+··· +1
an
(harm.avrg.) (204)
M0= lim
p→0Mp=n
Y
i=1
ai1/n
(geom.avrg.) (205)
M+1 =1
n
n
X
i=1
ai(arithm.avrg.) (206)
M+2 =v
u
u
t1
n
n
X
i=1
a2
i(root mean square) (207)
M+∞= lim
p→+∞Mp= max(a1, ...an) (maximum) (208)
Note that the proofs of the limit convergence are given in [93].
An interesting property of the generalised mean is as follows: for two real values pand q, if p < q
then Mp≤Mq. This property has for instance been illustrated in Fig. 20 of [473].
One can then for instance look at the generalised mean of a randomly generated set of 1000 viscosity
values within 1018P a.s and 1023P a.s for −5≤p≤5. Results are shown in the figure hereunder and the
arithmetic, geometric and harmonic values are indicated too. The function Mpassumes an arctangent-
like shape: very low values of p will ultimately yield the minimum viscosity in the array while very high
values will yield its maximum. In between, the transition is smooth and occurs essentially for |p| ≤ 5.
76
1e+18
1e+19
1e+20
1e+21
1e+22
1e+23
-4 -2 0 2 4
M(p)
p
geom.
arithm.
harm.
python codes/fieldstone markers avrg
77
7.7 Matrix (Sparse) storage
The FE matrix is the result of the assembly process of all elemental matrices. Its size can become quite
large when the resolution is being increased (from thousands of lines/columns to tens of millions).
One important property of the matrix is its sparsity. Typically less than 1% of the matrix terms is
not zero and this means that the matrix storage can and should be optimised. Clever storage formats
were designed early on since the amount of RAM memory in computers was the limiting factor 3 or 4
decades ago. [463]
There are several standard formats:
•compressed sparse row (CSR) format
•compressed sparse column format (CSC)
•the Coordinate Format (COO)
•Skyline Storage Format
•...
I focus on the CSR format in what follows.
7.7.1 2D domain - One degree of freedom per node
Let us consider again the 3 ×2 element grid which counts 12 nodes.
8=======9======10======11
||||
| (3) | (4) | (5) |
||||
4=======5=======6=======7
||||
| (0) | (1) | (2) |
||||
0=======1=======2=======3
In the case there is only a single degree of freedom per node, the assembled FEM matrix will look
like this:
X X X X
X X X X X X
X X X X X X
X X X X
X X X X X X
X X X X X X X X X
X X X X X X X X X
X X X X X X
X X X X
X X X X X X
X X X X X X
X X X X
where the Xstand for non-zero terms. This matrix structure stems from the fact that
•node 0 sees nodes 0,1,4,5
•node 1 sees nodes 0,1,2,4,5,6
•node 2 sees nodes 1,2,3,5,6,7
•...
78
•node 5 sees nodes 0,1,2,4,5,6,8,9,10
•...
•node 10 sees nodes 5,6,7,9,10,11
•node 11 sees nodes 6,7,10,11
In light thereof, we have
•4 corner nodes which have 4 neighbours (counting themselves)
•2(nnx-2) nodes which have 6 neighbours
•2(nny-2) nodes which have 6 neighbours
•(nnx-2)×(nny-2) nodes which have 9 neighbours
In total, the number of non-zero terms in the matrix is then:
NZ = 4 ×4+4×6+2×6+2×9 = 70
In general, we would then have:
NZ = 4 ×4 + [2(nnx −2) + 2(nny −2)] ×6+(nnx −2)(nny −2) ×9
Let us temporarily assume nnx =nny =n. Then the matrix size (total number of unknowns) is
N=n2and
NZ = 16 + 24(n−2) + 9(n−2)2
A full matrix array would contain N2=n4terms. The ratio of N Z (the actual number of reals to store)
to the full matrix size (the number of reals a full matrix contains) is then
R=16 + 24(n−2) + 9(n−2)2
n4
It is then obvious that when nis large enough R∼1/n2.
CSR stores the nonzeros of the matrix row by row, in a single indexed array A of double precision
numbers. Another array COLIND contains the column index of each corresponding entry in the A array.
A third integer array RWPTR contains pointers to the beginning of each row, which an additional pointer
to the first index following the nonzeros of the matrix A. A and COLIND have length NZ and RWPTR
has length N+1.
In the case of the here-above matrix, the arrays COLIND and RWPTR will look like:
COLIND = (0,1,4,5,0,1,2,4,5,6,1,2,3,5,6,7, ..., 6,7,10,11)
RW P T R = (0,4,10,16, ...)
7.7.2 2D domain - Two degrees of freedom per node
When there are now two degrees of freedom per node, such as in the case of the Stokes equation in
two-dimensions, the size of the Kmatrix is given by
NfemV=nnp∗ndofV
In the case of the small grid above, we have NfemV=24. Elemental matrices are now 8 ×8 in size.
We still have
•4 corner nodes which have 4 neighbours
•2(nnx-2) nodes which have 6 neighbours
•2(nny-2) nodes which have 6 neighbours
79
•(nnx-2)x(nny-2) nodes which have 9 neighbours,
but now each degree of freedom from a node sees the other two degrees of freedom of another node too.
In that case, the number of nonzeros has been multiplied by four and the assembled FEM matrix looks
like:
X X X X X X X X
X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X
X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X X X X X X X X X X X
X X X X X X X X X X X X X X X X X X
X X X X X X X X X X X X X X X X X X
X X X X X X X X X X X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X
X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X X X X X
X X X X X X X X
X X X X X X X X
Note that the degrees of freedom are organised as follows:
(u0, v0, u1, v1, u2, v2, ...u11, v11)
In general, we would then have:
NZ = 4 [4 ×4 + [2(nnx −2) + 2(nny −2)] ×6+(nnx −2)(nny −2) ×9]
and in the case of the small grid, the number of non-zero terms in the matrix is then:
NZ = 4 [4 ×4+4×6+2×6+2×9] = 280
In the case of the here-above matrix, the arrays COLIND and RWPTR will look like:
COLIND = (0,1,2,3,8,9,10,11,0,1,2,3,8,9,10,11, ...)
RW P T R = (0,8,16,28, ...)
7.7.3 in fieldstone
The majority of the codes have the FE matrix being a full array
a mat = np . z e r o s ( ( Nfem , Nfem) , dtype=np . f l o a t 6 4 )
and it is converted to CSR format on the fly in the solve phase:
s o l = s p s . l i n a l g . s p s o l v e ( s ps . c s r m a t r i x ( a mat ) , r hs )
Note that linked list storages can be used (lil matrix). Substantial memory savings but much longer
compute times.
80
7.8 Mesh generation
Before basis functions can be defined and PDEs can be discretised and solved we must first tesselate the
domain with polygons, e.g. triangles and quadrilaterals in 2D, tetrahedra, prisms and hexahedra in 3D.
When the domain is itself simple (e.g. a rectangle, a sphere, ...) the mesh (or grid) can be (more or
less) easily produced and the connectivity array filled with straightforward algorithms [518]. However,
real life applications can involve extremely complex geometries (e.g. a bridge, a human spine, a car
chassis and body, etc ...) and dedicated algorithms/softwares must be used (see [522, 201, 578]).
We usually distinguish between two broad classes of grids: structured grids (with a regular connec-
tivity) and unstructured grids (with an irregular connectivity).
7.8.1 Quadrilateral-based meshes
Let us now focus on the case of a rectangular computational domain of size Lx ×Ly with a regular mesh
composed of nelx×nely=nel quadrilaterals. There are then nnx×nny=nnp grid points. The elements
are of size hx×hy with hx=Lx/nelx.
We have no reason to come up with an irregular/illogical node numbering so we can number nodes
row by row or column by column as shown on the example hereunder of a 3×2 grid:
8=======9======10======11 2=======5=======8======11
||||||||
| (3) | (4) | (5) | | (1) | (3) | (5) |
||||||||
4=======5=======6=======7 1=======4=======7======10
||||||||
| (0) | (1) | (2) | | (0) | (2) | (4) |
||||||||
0=======1=======2=======3 0=======3=======6=======9
"row by row" "column by column"
The numbering of the elements themselves could be done in a somewhat chaotic way but we follow
the numbering of the nodes for simplicity. The row by row option is the adopted one in fieldstone and
the coordinates of the points are computed as follows:
x = np . empty ( nnp , dtype=np . f l o a t 6 4 )
y = np . empty ( nnp , dtype=np . f l o a t 6 4 )
co u nt er = 0
f o r jin range ( 0 , nny ) :
f o r ii n r an g e ( 0 , nnx ) :
x [ c oun te r ]= i ∗hx
y [ c oun te r ]= j ∗hy
co u nt er += 1
The inner loop has iranging from 0to nnx-1 first for j=0, 1, ... up to nny-1 which indeed corresponds
to the row by row numbering.
We now turn to the connectivity. As mentioned before, this is a structured mesh so that the so-called
connectivity array, named icon in our case, can be filled easily. For each element we need to store the
node identities of its vertices. Since there are nel elements and m=4 corners, this is a m×nel array. The
algorithm goes as follows:
81
i c o n =np . z e r o s ( (m, n e l ) , dt yp e=np . i n t 1 6 )
co u nt er = 0
f o r jin range ( 0 , n e l y ) :
f o r ii n r an g e ( 0 , n e l x ) :
i c o n [ 0 , c o u n t e r ] = i + j ∗nnx
i c o n [ 1 , c o u n t e r ] = i + 1 + j ∗nnx
i c o n [ 2 , c o u n t e r ] = i + 1 + ( j + 1 ) ∗nnx
i c o n [ 3 , c o u n t e r ] = i + ( j + 1 ) ∗nnx
co u nt er += 1
In the case of the 3×2 mesh, the icon is filled as follows:
element id→0 1 2 3 4 5
node id↓
0 0 1 2 4 5 6
1 1 2 3 5 6 7
2 56791011
3 4 5 6 8 9 10
It is to be understood as follows: element #4 is composed of nodes 5, 6, 10 and 9. Note that nodes are
always stored in a counter clockwise manner, starting at the bottom left. This is very important since
the corresponding basis functions and their derivatives will be labelled accordingly.
In three dimensions things are very similar. The mesh now counts nelx×nely×nelz=nel elements
which represent a cuboid of size Lx×Ly×Lz. The position of the nodes is obtained as follows:
x = np . empty ( nnp , dtype=np . f l o a t 6 4 )
y = np . empty ( nnp , dtype=np . f l o a t 6 4 )
z = np . empty ( nnp , dtype=np . f l o a t 6 4 )
co u nt er=0
f o r iin range ( 0 , nnx ) :
f o r jin range ( 0 , nny ) :
f o r kin range ( 0 , nnz ) :
x [ c oun te r ]= i ∗hx
y [ c oun te r ]= j ∗hy
z [ c oun te r ]=k∗hz
co u nt er += 1
The connectivity array is now of size m×nel with m=8:
i c o n =np . z e r o s ( (m, n e l ) , dt yp e=np . i n t 1 6 )
co u nt er = 0
f o r iin range ( 0 , n e l x ) :
f o r jin range ( 0 , n e l y ) :
f o r kin range ( 0 , n e l z ) :
i c o n [ 0 , c o u n t e r ]=nny∗nnz ∗( i )+nnz ∗( j )+k
i c o n [ 1 , c o u n t e r ]=nny∗nnz ∗( i +1)+nnz ∗( j )+k
i c o n [ 2 , c o u n t e r ]=nny∗nnz ∗( i +1)+nnz ∗( j +1)+k
i c o n [ 3 , c o u n t e r ]=nny∗nnz ∗( i )+nnz ∗( j +1)+k
i c o n [ 4 , c o u n t e r ]=nny∗nnz ∗( i )+nnz ∗( j )+k+1
i c o n [ 5 , c o u n t e r ]=nny∗nnz ∗( i +1)+nnz ∗( j )+k+1
i c o n [ 6 , c o u n t e r ]=nny∗nnz ∗( i +1)+nnz ∗( j +1)+k+1
i c o n [ 7 , c o u n t e r ]=nny∗nnz ∗( i )+nnz ∗( j +1)+k+1
co u nt er += 1
produce drawing of node numbering
7.8.2 Delaunay triangulation and Voronoi cells
Triangle-based meshes are obviously better suited for simulations of complex geometries:
82
# l0 # l1 # l2 # l3 # l4 # l5 # l6 # l7 # l8
max level= 0 1
max level= 1 0 4
max level= 2 0 3 4
max level= 3 0 2 7 4
max level= 4 0 2 5 10 8
max level= 5 0 1 8 12 11 20
max level= 6 0 1 8 11 13 20 32
max level= 7 0 0 11 14 15 23 37 60
max level= 8 0 0 11 13 17 27 43 72 116
84
0
10
20
30
40
50
60
0 1 2 3 4 5 6 7
number of elements
max ref. level
l 0
l 1
l 2
l 3
l 4
l 5
l 6
l 7
0
20
40
60
80
100
120
140
160
0 1 2 3 4 5 6 7
total number of elements
max ref. level
x3
In the particular case presented here, even though the inclusion in a short two-dimensional line, the
total number of elements grows faster than the third power of the refinement level. While of course the
total number of elements remains much smaller than the constant resolution counterpart, this observation
tells us that authorising a unit increase of the maximum refinement level can have a substantial effect on
the total number of elements.
85
0
50
100
150
200
250
300
0 1 2 3 4 5 6 7
number of elements
max ref. level
l 0
l 1
l 2
l 3
l 4
l 5
l 6
l 7
0
100
200
300
400
500
600
700
0 1 2 3 4 5 6 7
total number of elements
max ref. level
x4
0.01
0.1
1
0 1 2 3 4 5 6 7
tot. nb of elts / nb elts at constant res.
max ref. level
86
7.9 Visco-Plasticity
7.9.1 Tensor invariants
Before we dive into the world of nonlinear rheologies it is necessary to introduce the concept of tensor
invariants since they are needed further on. Unfortunately there are many different notations used in the
literature and these can prove to be confusing. Note that we only consider symmetric tensors in what
follows.
Given a tensor T, one can compute its (moment) invariants as follows:
•first invariant :
TI|2D=T r[T] = Txx +Tyy
TI|3D=T r[T] = Txx +Tyy +Tzz
•second invariant :
TII |2D=1
2T r[T2] = 1
2X
ij
Tij Tji =1
2(T2
xx +T2
yy) + T2
xy
TII |3D=1
2T r[T2] = 1
2X
ij
Tij Tji =1
2(T2
xx +T2
yy +T2
yy) + T2
xy +T2
xz +T2
yz
•third invariant :
TIII =1
3T r[T3] = 1
3X
ijk
Tij TjkTki
The implementation of the plasticity criterions relies essentially on the second invariants of the (de-
viatoric) stress τand the (deviatoric) strainrate tensors ˙
ε:
τII |2D=1
2(τ2
xx +τ2
yy) + τ2
xy
=1
4(σxx −σyy)2+σ2
xy
=1
4(σ1−σ2)2
τII |3D=1
2(τ2
xx +τ2
yy +τ2
zz) + τ2
xy +τ2
xz +τ2
yz
=1
6(σxx −σyy )2+ (σyy −σzz)2+ (σxx −σzz)2+σ2
xy +σ2
xz +σ2
yz
=1
6(σ1−σ2)2+ (σ2−σ3)2+ (σ1−σ3)2
εII |2D=1
2( ˙εd
xx)2+ ( ˙εd
yy)2+ ( ˙εd
xy)2
=1
21
4( ˙εxx −˙εyy)2+1
4( ˙εyy −˙εxx)2+ ˙ε2
xy
=1
4( ˙εxx −˙εyy)2+ ˙ε2
xy
εII |3D=1
2( ˙εd
xx)2+ ( ˙εd
yy)2+ ( ˙εd
zz)2+ ( ˙εd
xy)2+ ( ˙εd
xz)2+ ( ˙εd
yz)2
=1
6(˙xx −˙yy)2+ (˙yy −˙zz)2+ ( ˙xx −˙zz)2+ ˙2
xy + ˙2
xz + ˙2
yz
Note that these (second) invariants are almost always used under a square root so we define:
87
τII =√τII ˙εII =p˙εII
Note that these quantities have the same dimensions as their tensor counterparts, i.e. Pa for stresses and
s−1for strain rates.
7.9.2 Scalar viscoplasticity
This formulation is quite easy to implement. It is widely used, e.g. [572, 520, 493], and relies on the
assumption that a scalar quantity ηp(the ’effective plastic viscosity’) exists such that the deviatoric stress
tensor
τ= 2ηp˙
ε(209)
is bounded by some yield stress value Y. From Eq. (209) it follows that τII = 2ηp˙εII =Ywhich yields
ηp=Y
2˙εII
This approach has also been coined the Viscosity Rescaling Method (VRM) [315].
insert here the rederivation 2.1.1 of spmw16
It is at this stage important to realise that (i) in areas where the strainrate is low, the resulting effective
viscosity will be large, and (ii) in areas where the strainrate is high, the resulting effective viscosity will be
low. This is not without consequences since (effective) viscosity contrasts up to 8-10 orders of magnitude
have been observed/obtained with this formulation and it makes the FE matrix very stiff, leading to
(iterative) solver convergence issues. In order to contain these viscosity contrasts one usually resorts to
viscosity limiters ηmin and ηmax such that
ηmin ≤ηp≤ηmax
Caution must be taken when choosing both values as they may influence the final results.
python codes/fieldstone indentor
7.9.3 About the yield stress value Y
In geodynamics the yield stress value is often given as a simple function. It can be constant (in space
and time) and in this case we are dealing with a von Mises plasticity yield criterion. . We simply assume
YvM =Cwhere Cis a constant cohesion independent of pressure, strainrate, deformation history, etc ...
Another model is often used: the Drucker-Prager plasticity model. A friction angle φis then intro-
duced and the yield value Ytakes the form
YDP =psin φ+Ccos φ
and therefore depends on the pressure p. Because φis with the range [0◦,45◦], Yis found to increase
with depth (since the lithostatic pressure often dominates the overpressure).
Note that a slightly modified verion of this plasticity model has been used: the total pressure pis
then replaced by the lithostatic pressure plith.
88
7.10 Pressure smoothing
It has been widely documented that the use of the Q1×P0element is not without problems. Aside from
the consequences it has on the FE matrix properties, we will here focus on another unavoidable side
effect: the spurious pressure checkerboard modes.
These modes have been thoroughly analysed [268, 119, 467, 468]. They can be filtered out [119] or
simply smoothed [346].
On the following figure (a,b), pressure fields for the lid driven cavity experiment are presented for
both an even and un-even number of elements. We see that the amplitude of the modes can sometimes
be so large that the ’real’ pressure is not visible and that something as simple as the number of elements
in the domain can trigger those or not at all.
a) b)
c)
a) element pressure for a 32x32 grid and for a 33x33 grid;
b) image from [158, p307] for a manufactured solution;
c) elemental pressure and smoothed pressure for the punch experiment [520]
The easiest post-processing step that can be used (especially when a regular grid is used) is explained in
[520]: ”The element-to-node interpolation is performed by averaging the elemental values from elements
common to each node; the node-to-element interpolation is performed by averaging the nodal values
element-by-element. This method is not only very efficient but produces a smoothing of the pressure that
is adapted to the local density of the octree. Note that these two steps can be repeated until a satisfying
level of smoothness (and diffusion) of the pressure field is attained.”
In the codes which rely on the Q1×P0element, the (elemental) pressure is simply defined as
p=np . z e ro s ( ne l , dtype=np . f l o a t 6 4 )
while the nodal pressure is then defined as
q=np . z e r o s ( nnp , dtype=np . f l o a t 6 4 )
The element-to-node algorithm is then simply (in 2D):
cou nt=np . z e r o s ( nnp , d type=np . i n t 1 6 )
f o r i e l in range ( 0 , n e l ) :
q [ i c o n [ 0 , i e l ]]+=p [ i e l ]
q [ i c o n [ 1 , i e l ]]+=p [ i e l ]
q [ i c o n [ 2 , i e l ]]+=p [ i e l ]
q [ i c o n [ 3 , i e l ]]+=p [ i e l ]
co un t [ i c o n [ 0 , i e l ]]+=1
co un t [ i c o n [ 1 , i e l ]]+=1
co un t [ i c o n [ 2 , i e l ]]+=1
co un t [ i c o n [ 3 , i e l ]]+=1
q=q/ count
89
7.11 Pressure scaling
As perfectly explained in the step 32 of deal.ii8, we often need to scale the Gterm since it is many orders
of magnitude smaller than K, which introduces large inaccuracies in the solving process to the point that
the solution is nonsensical. This scaling coefficient is η/L where ηand Lare representative viscosities
and lengths. We start from
K G
GT−C·
V
P=
f
h!
and introduce the scaling coefficient as follows (which in fact does not alter the solution at all):
Kη
LG
η
LGT−η2
L2C·
V
L
η
P!=
f
η
L
h!
We then end up with the modified Stokes system:
K G
GTC·
V
P=
f
h!
where
G=η
LG
P=L
η
PC=η2
L2C
h=η
L
h
After the solve phase, we recover the real pressure with
P=η
L
P.
8https://www.dealii.org/9.0.0/doxygen/deal.II/step 32.html
91
7.12 Pressure normalisation
7.12.1 Basic idea and naive implementation
When Dirichlet boundary conditions are imposed everywhere on the boundary, pressure is only present
by its gradient in the equations. It is thus determined up to an arbitrary constant (one speaks then of
a nullspace of size 1). In such a case, one commonly impose the average of the pressure over the whole
domain or on a subset of the boundary to have a zero average, i.e.
ZΩ
pdV = 0 (210)
Another possibility is to impose the pressure value at a single node.
Let us assume for example that we are using Q1×P0elements. Then the pressure is constant inside
each element. The integral above becomes:
ZΩ
pdV =X
eZΩe
pdV =X
e
peZΩe
dV =X
e
peAe= 0 (211)
where the sum runs over all elements eof area Ae. This can be rewritten
LT·
P= 0
and it is a constraint on the pressure solution which couples all pressure dofs. As we have seen before
??, we can associate to it a Lagrange multiplier λso that we must solve the modified Stokes system:
K G 0
GT0L
0LT0
·
V
P
λ
=
f
h
0
When higher order spaces are used for pressure (continuous or discontinuous) one must then carry out
the above integration numerically by means of (usually) a Gauss-Legendre quadrature.
Although valid, this approach has one main disadvantage: it makes the Stokes matrix larger (although
marginally so – only one row and column are added), but more importantly it prevents the use of some
of the solving strategies of Section 7.13.
7.12.2 Implementation – the real deal
The idea is actually quite simple and requires two steps:
1. remove the null space by prescribing the pressure at one location and solve the system;
2. post-process the pressure so as to arrive at a pressure field which fulfills the required normalisation
(surface, volume, ...)
The reason why it works is as follows: a constant pressure value lies in the null space, so that one can
add or delete any value to the pressure field without consequence. As such I can choose said constant
such that the pressure at a given node/element is zero. All other computed pressures are then relative to
that one. The post-processing step will redistribute a constant value to all pressures (it will shift them
up or down) so that the normalising condition is respected.
92
7.13 Solving the Stokes system
Let us start again from the (full) Stokes system:
K G
GT−C·
V
P=
f
h!(212)
We need to solve this system in order to obtain the solution, i.e. the
Vand
Pvectors. But how?
Unfortunately, this question is not simple to answer and the appropriate method depends on many
parameters, but mainly on how big the matrix blocks are and what the condition number of the matrix
Kis.
In what follow I cover:
•solving when the penalty approach is used
•the Schur complement approach
•the FGMRES approach
•the Augmented Lagrangian approach
7.13.1 when using the penalty formulation
In this case we are only solving for velocity since pressure is recovered in a post-processing step:
(Kη+Kλ)·
V=
f
We also know that the penalty factor is many orders of magnitude higher than the viscosity and in
combination with the use of the Q1×P0element the resulting matrix condition number is very high
so that the use of iterative solvers is precluded. Indeed codes such as SOPALE [207], DOUAR [75], or
FANTOM [516] relying on the penalty formulation all use direct solvers. The most popular are BLKFCT,
MUMPS, WSMP, UMFPACK, SuperLU, PARDISO, CholMod.
Braun et al [75] list the following features of such solvers:
•Robust
•Black-box operation
•Difficult to parallelize
•Memory consumption
•Limited scalability
The main advantage of direct solvers is used in this case: They can solve ill-conditioned matrices.
However memory requirements for the storage of number of nonzeros in the Cholesky matrix grow very fast
as the number of equations/grid size increases, especially in 3D, to the point that even modern computers
with tens of Gb of RAM cannot deal with a 1003element mesh. This explains why direct solvers are often
used for 2D problems and rarely in 3D with noticeable exceptions [520, 582, 76, 367, 13, 14, 15, 570, 407].
7.13.2 Conjugate gradient and the Schur complement approach
Let us write the above system as two equations:
K·
V+G·
P=
f(213)
GT·
V=
h(214)
The first line can be re-written
V=K−1·(
f−G·
P) and can be inserted in the second:
GT·
V=GT·[K−1·(
f−G·
P)] =
h(215)
or,
93
(GT·K−1·G)·
P=GT·K−1·
f−
h(216)
The matrix S=GT·K−1·Gis called the Schur complement. It is Symmetric (since Kis symmetric)
and Positive-Definite9(SPD) if Ker(G) = 0. look in donea-huerta book for details Having solved this
equation (we have obtained
P), the velocity can be recovered by solving K·
V=
f−G·
P.
For now, let us assume that we have built the Smatrix and the right hand side
f=GT·K−1·
f−
h.
We must solve S·
P=
f.
One can resort to so-called Richardson iterations, defined as follows (e.g., see [554], p141): in solving
the matrix equation A·
X=
b, the Richardson iterative method is defined by:
Xk+1 =
Xk+αk(−A·
Xk+
b)m≥0 (217)
where the αk’s are real scalars. It is easy to see that when the method converges then
Xk+1 '
Xkand
then A·
X=
bis satisfied. In our case, it writes:
Pk+1 =
Pk+αk(−S·
Pk+
f)
=
Pk+αk(−GT·K−1·G·
Pk+GT·K−1·
f−
h)
=
Pk+αkhGT·K−1·(−G·
Pk+
f)−
hi
=
Pk+αkhGT·K−1·(K·
Vk)−
hi
=
Pk+αkGT·
Vk−
h(218)
The above iterations are then carried out and for each new pressure field the associated velocity field is
computed. The method of using Richardson iterations applied to the Schur complement is commonly
called the Uzawa algorithm [72, p221].
Uzawa algorithm (1):
solve K·
Vk=
f−G·
Pk−1(219)
Pk=Pk−1+α(GT·
Vk−
h)k= 1,2, ... (220)
This method is rather simple to implement, although what makes an appropriate set of αkvalues
is not straightforward, which is why the conjugate gradient is often preferred, as detailed in the next
subsection.
It is known that such iterations will converge for 0 < α < ρ(S) = λmax(S) where ρ(S) is the spectral
radius of the matrix Swhich is essentially the largest, in absolute value, eigenvalue of S(neither of which
can be computed easily). It can also be proven that the rate of convergence depends on the condition
number of the matrix.
Richardson iterations are part of the family of stationary iterative methods, since it can be rewritten
Xk+1 = (I−αkA)·
Xk+αk
b(221)
which is the definition of a stationary method.
Since the αparameter is the key to a succesful Uzawa algorithm, this issue has of course been looked
into. What follows is presented in [72, p221]. For the analysis of the Uzawa algorithm, we define the
residue
Rk=
h−GT·
Vk
In addition, suppose the solution of the saddle point problem is denoted by (V?,P?). Now substituting
the iteration formula for Vk, we get
Rk=GT·
V?−GT·K−1(
f−G· Pk−1) (222)
=GT·
V?−GT·K−1(K·
V?+G·
P?−G· Pk−1) (223)
=GT·K−1·G·(
Pk−1−
P?) (224)
9Mpositive definite ⇐⇒ xTM x > 0∀x∈Rn\0
94
From Eq. 220 it follows that:
Pk− Pk−1=α(GT·
Vk−
h) (225)
=−α
Rk(226)
=−αGT·K−1·G·(
Pk−1−
P?) (227)
=αGT·K−1·G·(
P?−
Pk−1) (228)
Thus the Uzawa algorithm is equivalent to applying the gradient method to the reduced equation using
a fixed step size. In particular, the iteration converges for α < 2||GT·K−1·G||−1and one can show that
the good step size αkis given by
αk=Rk· Rk
(Gqk)·(K−1Gqk)(229)
However, if we were to use this rule formally, we would need an additional multiplication by K−1in every
step of the iteration. This can be avoided by storing an auxiliary vector.
Note that in [249] it is stated: the convergence of this algorithm is proved for α∈(0,2µ/d) (where d
is the number of dimensions).
check this, and report page number
Note that this algorithm is presented in [610] in the context of viscosplastic flow.
As mentioned above, there is a way to rework the original Uzawa algorithm to include Eq. (229). It
is yields a modified Uzawa algorithm [72, p221]:
Uzawa algorithm (2): Solve K·
V1=
f−G·
P0. For k= 1,2, ..., compute
qk=
h−GT·
Vk(230)
pk=G·qk(231)
Hk=K−1·pk(232)
αk=qk·qk
pk·
Hk
(233)
Pk=
Pk−1−αkqk(234)
Vk+1 =
Vk+αk
Hk(235)
7.13.3 Conjugate gradient and the Schur complement approach
Since Sis SPD, the Conjugate Gradient (CG) method is very appropriate to solve this system. Indeed,
looking at the definition of Wikipedia: ”In mathematics, the conjugate gradient method is an algorithm for
the numerical solution of particular systems of linear equations, namely those whose matrix is symmetric
and positive-definite. The conjugate gradient method is often implemented as an iterative algorithm,
applicable to sparse systems that are too large to be handled by a direct implementation or other direct
methods such as the Cholesky decomposition. Large sparse systems often arise when numerically solving
partial differential equations or optimization problems.”
A simple Google search tells us that the Conjugate Gradient algorithm is as follows:
95
Algorithm as obtained from Wikipedia 10
This algorithm is of course explained in detail in many textbooks such as [463]
add biblio
.
Let us look at this algorithm up close. The parts which may prove to be somewhat tricky are those
involving the matrix inverse (in our case the Schur complement). We start the iterations with a guess
pressure
P0( and an initial guess velocity which could be obtained by solving K·
V0=
f−G·
P0).
r0=
f−S·
P0(236)
=GT·K−1·
f−
h−(GT·K−1·G)·
P0(237)
=GT·K−1·(
f−G·
P0)−
h(238)
=GT·K−1·K·
V0−
h(239)
=GT·
V0−
h(240)
(241)
We now turn to the αkcoefficient:
αk=rT
k·rk
pk·S·pk
=rT
k·rk
pk·GT·K−1·G·pk
=rT
k·rk
(G·pk)T·K−1·(G·pk)
We then define ˜
pk=G·pk, so that αkcan be computed as follows:
1. compute ˜
pk=G·pk
2. solve K·
dk=˜
pk
3. compute αk= (rT
k·rk)/(˜
pT
k·
dk)
Then we need to look at the term S·pk:
S·pk=GT·K−1·G·pk=GT·K−1·˜
pk=GT·
dk
We can then rewrite the CG algorithm as follows [603]:
•r0=GT·
V0−
h
•if r0is sufficiently small, then return (
V0,
P0) as the result
•p0=r0
10https://en.wikipedia.org/wiki/Conjugate_gradient_method
96
•k= 0
•repeat
–compute ˜
pk=G·pk
–solve K·
dk=˜
pk
–compute αk= (rT
k·rk)/(˜
pT
k·
dk)
–
Pk+1 =
Pk+αkpk
–rk+1 =rk−αkGT·
dk
–if rk+1 is sufficiently small, then exit loop
–βk= (rT
k+1 ·rk+1)/(rT
k·rk)
–pk+1 =rk+1 +βkpk
–k=k+ 1
•return
Pk+1 as result
We see that we have managed to solve the Schur complement equation with the Conjugate Gradient
method without ever building the matrix S. Having obtained the pressure solution, we can easily recover
the corresponding velocity with K·
Vk+1 =
f−G·
Pk+1. However, this is rather unfortunate because it
requires yet another solve with the Kmatrix. As it turns out, we can slightly alter the above algorithm
to have it update the velocity as well so that this last solve is unnecessary.
We have
Vk+1 =K−1·(f−G·
Pp+1) (242)
=K−1·(f−G·(
Pk+αkpk)) (243)
=K−1·(f−G·
Pk)−αkK−1·G·pk(244)
=
Vk−αkK−1·˜
pk(245)
=
Vk−αk
dk(246)
and we can insert this minor extra calculation inside the algorithm and get the velocity solution nearly
for free. The final CG algorithm is then
solver cg:
•compute
V0=K−1·(
f−G·
P0)
•r0=GT·
V0−
h
•if r0is sufficiently small, then return (
V0,
P0) as the result
•p0=r0
•k= 0
•repeat
–compute ˜
pk=G·pk
–solve K·
dk= ˜pk
–compute αk= (rT
k·rk)/(˜
pT
k·
dk)
–
Pk+1 =
Pk+αkpk
–
Vk+1 =
Vk−αk
dk
–rk+1 =rk−αkGT·
dk
–if rk+1 is sufficiently small (||rk+1||2/||r0||2< tol), then exit loop
–βk= (rT
k+1rk+1)/(rT
krk)
97
–pk+1 =rk+1 +βkpk
–k=k+ 1
•return
Pk+1 as result
This iterative algorithm will converge to the solution with a rate which depends on the condition
number of the Smatrix, which is not easy to compute since Sis never built. However, it has been
established that large viscosity contrasts in the domain will have a negative impact on the convergence.
Remark. This algorithm requires one solve with matrix Kper iteration but says nothing about the method
employed to do so (direct solver, iterative solver, ...)
One thing we know improves the convergence of any iterative solver is the use of a preconditioner
matrix and therefore now focus on the Preconditioned Conjugate Gradient (PCG) method. Once again
a quick Google search yields:
Algorithm obtained from Wikipedia11.
Note that in the algorithm above the preconditioner matrix Mhas to be symmetric positive-definite
and fixed, i.e., cannot change from iteration to iteration. We see that this algorithm introduces an
additional vector z and a solve with the matrix Mat each iteration, which means that Mmust be such
that solving M·x =
fwhere
fis a given rhs vector must be cheap. Ultimately, the PCG algorithm
applied to the Schur complement equation takes the form:
solver pcg:
•compute V0=K−1(f−GP0)
•r0=GTV0−h
•if r0is sufficiently small, then return (
V0,
P0) as the result
•z0=M−1·r0
•p0=z0
•k= 0
•repeat
–compute ˜
pk=G·pk
11https://en.wikipedia.org/wiki/Conjugate_gradient_method
98
–solve K·
dk=˜
pk
–compute αk= (rT
k·zk)/(˜
pT
k·
dk)
–
Pk+1 =Pk+αkpk
–
Vk+1 =Vk−αk
dk
–rk+1 =rk−αkGT·
dk
–if rk+1 is sufficiently small (||rk+1||2/||r0||2< tol), then exit loop
–zk+1 =M−1·rk+1
–βk= (zT
k+1 ·rk+1)/(zT
k·rk)
–pk+1 =zk+1 +βkpk
–k=k+ 1
•return
Pk+1 as result
Following [603] one can define the following matrix as preconditioner:
M=diag GT(diag[K])−1G
which is the preconditioner used for the Citcom codes (see appendix B). It can be constructed while the
FEM matrix is being built/assembled and it is trivial to invert.
how to compute Mfor the Schur complement ?
7.13.4 The Augmented Lagrangian approach
see LaCoDe paper.
We start from the saddle point Stokes system:
K G
GT0·
V
P=
f
h!(247)
The AL method consists of subtracting λ−1Mp·
Pfrom the left and right-side of the mass conservation
equation (where Mpis the pressure mass matrix) and introducing the following iterative scheme:
K G
GT−λ−1Mp·
Vk+1
Pk+1 =
f
h−λ−1Mp·
Pk!(248)
where kis the iteration counter and λis an artificial compressibility term which has the dimensions of
dynamic viscosity. The choice of λcan be difficult as too low or too high a value yields either erroneous
results and/or terribly ill-conditioned matrices. LaCoDe paper (!!) use such a method and report that
λ= maxΩ(η) works well. Note that at convergence we have ||
Pk+1 −
Pk|| < and then Eq.(248) converges
to Eq.(247) and the velocity and pressure fields are solution of the unmodified system Eq.(247).
The introduction of this term serves one purpose: allowing us to solve the system in a segregated
manner (i.e. computing successive iterates of the velocity and pressure fields until convergence is reached).
The second line of Eq. (248) is
GT·
Vk+1 −λ−1Mp·
Pk+1 =
h−λ−1Mp·
Pk
and can therefore be rewritten
Pk+1 =
Pk+λM−1
p·(GT·
Vk+1 −
h)
99
We can then substitute this expression of
Pk+1 in the first equation. This yields:
K·
Vk+1 =
f−G· Pk+1) (249)
K·
Vk+1 =
f−G·(
Pk+λM−1
p·(GT·
Vk+1 −
h)) (250)
K·
Vk+1 +λG·M−1
p·GT·
Vk+1 =
f−G·(
Pk−λM−1
p
h)) (251)
K+λG·M−1
p·GT
| {z }
˜
K
·
Vk+1 =
f−G·(
Pk−λM−1
p
h))
| {z }
~
fk+1
(252)
(253)
The iterative algorithm goes as follows:
1. if it is the first timestep, set
P0= 0 , otherwise set it to the pressure of the previous timestep.
2. calculate ˜
K
3. calculate
fk+1
4. solve ˜
K·
Vk+1 =
fk+1
5. update pressure with
Pk+1 =
Pk+λM−1
p·(GT·
Vk+1 −
h)
Remark. If discontinuous pressures are used, the pressure mass matrix can be inverted element by
element which is cheaper than inverting Mpas a whole.
Remark. This method has obvious ties with the penalty method.
Remark. If λ >> maxΩηthen the matrix ˜
Kis ill-conditioned and an iterative solver must be used.
7.13.5 The GMRES approach
The Generalized Minimal Residual method [464] is an extension of MINRES (which is only applicable to
symmetric systems) to unsymmetric systems. Like MINRES, it generates a sequence of orthogonal vectors
and combines these through a least-squares solve and update. However, in the absence of symmetry this
can no longer be done with short recurrences. As a consequence, all previously computed vectors in the
orthogonal sequence have to be retained and for this reason ”restarted” versions of the method are used.
It must be said that the (preconditioned) GMRES method is actually much more difficult to implement
than the (preconditioned) Conjugate Gradient method. However, since it can deal with unsymmetric
matrices, it means that it can be applied directly to the Stokes system matrix (as opposed to the CG
method which is used on the Schur complement equation).
Resources: [169, p208] [463] [33]
finish GMRES algo description. not sure what to do, hard to explain, not easy to code.
100
7.14 The consistent boundary flux (CBF)
The Consistent Boundary Flux technique was devised to alleviate the problem of the accuracy of primary
variables derivatives (mainly velocity and temperature) on boundaries, where basis function (nodal)
derivatives do not exist. These derivatives are important since they are needed to compute the heat flux
(and therefore the NUsselt number) or dynamic topography and geoid.
The idea was first introduced in [392] and later used in geodynamics [597]. It was finally implemented
in the CitcomS code [599] and more recently in the ASPECT code (dynamic topography postprocessor).
Note that the CBF should be seen as a post-processor step as it does not alter the primary variables
values.
The CBF method is implemented and used in ??.
7.14.1 applied to the Stokes equation
We start from the strong form:
∇·σ=b
and then write the weak form: ZΩ
N∇·σdV =ZΩ
NbdV
where Nis any test function. We then use the two equations:
∇·(Nσ) = N∇·σ+∇N·σ(chain rule)
ZΩ
(∇·f)dV =ZΓ
f·ndS (divergence theorem)
Integrating the first equation over Ω and using the second, we can write:
ZΓ
Nσ·ndS −ZΩ∇N·σdV =ZΩ
NbdV
On Γ, the traction vector is given by t=σ·n:
ZΓ
NtdS =ZΩ∇N·σdV +ZΩ
NbdV
Considering the traction vector as an unknown living on the nodes on the boundary, we can expand (for
Q1elements)
tx=
2
X
i=1
tx|iNity=
2
X
i=1
ty|iNi
on the boundary so that the left hand term yields a mass matrix M0. Finally, using our previous experience
of discretising the weak form, we can write:
M0· T =−KV − GP+f
where Tis the vector of assembled tractions which we want to compute and Vand Tare the solutions
of the Stokes problem. Note that the assembly only takes place on the elements along the boundary.
Note that the assembled mass matrix is tri-diagonal can be easily solved with a Conjugate Gradient
method. With a trapezoidal integration rule (i.e. Gauss-Lobatto) the matrix can even be diagonalised
and the resulting matrix is simply diagonal, which results in a very cheap solve [597].
7.14.2 applied to the heat equation
We start from the strong form of the heat transfer equation (without the source terms for simplicity):
ρcp∂T
∂t +v·∇T=∇·k∇T
101
The weak form then writes:
ZΩ
Nρcp
∂T
∂t dV +ρcpZΩ
Nv·∇T dV =ZΩ
N∇·k∇T dV
Using once again integration by parts and divergence theorem:
ZΩ
Nρcp
∂T
∂t dV +ρcpZΩ
Nv·∇T dV =ZΓ
Nk∇T·ndΓ−ZΩ
∇N·k∇T dV
On the boundary we are interested in the heat flux q=−k∇T
ZΩ
Nρcp
∂T
∂t dV +ρcpZΩ
Nv·∇T dV =−ZΓ
Nq·ndΓ−ZΩ
∇N·k∇T dV
or, ZΓ
Nq·ndΓ = −ZΩ
Nρcp
∂T
∂t dV −ρcpZΩ
Nv·∇T dV −ZΩ
∇N·k∇T dV
Considering the normal heat flux qn=q·nas an unknown living on the nodes on the boundary,
qn=
2
X
i=1
qn|iNi
so that the left hand term becomes a mass matrix for the shape functions living on the boundary. We
have already covered the right hand side terms when building the FE system to solve the heat transport
equation, so that in the end
M0· Qn=−M·∂T
∂t −Ka·T−Kd·T
where Qnis the assembled vector of normal heat flux components. Note that in all terms the assembly
only takes place over the elements along the boundary.
Note that the resulting matrix is symmetric.
7.14.3 implementation - Stokes equation
Let us start with a small example, a 3x2 element FE grid:
012
345
0 1 2 3
4 5 6 7
8 9 10 11
01234567
891011 1213 1415
16 17 18 19 20 21 22 23
Red color corresponds to the dofs in the x direction, blue color indicates a dof in the y direction.
We have nnp=12, nel=6, NfemV=24. Let us assume that free slip boundary conditions are applied.
The boundary conditions fix bc array is then:
bc fix=[ TTTTTTTTTTTTTTTTTTTTTTTT]
Note that since corners belong to two edges, we effectively prescribed no-slip boundary conditions on
those.
why does array contain only T??
We wish to compute the tractions on the boundaries, and more precisely for the dofs for which a
Dirichlet velocity boundary condition has been prescribed. The number of (traction) unknowns NfemTr
is then the number of Tin the bc fix array. In our specific case, we wave NfemTr= . This means that we finishfinish
need for each targeted dof to be able to find its identity/number between 0 and NfemTr-1. We therefore
create the array bc nb which is filled as follows:
102
bc nb=[TTTTTTTTTTTTTTTTTTTTTTTT]
This translates as follows in the code:
NfemTr=np . sum ( b c f i x )
bc nb=np . z e r o s ( NfemV , dtype=np . i n t 3 2 )
co u nt er=0
f o r iin range ( 0 , NfemV ) :
i f ( b c f i x [ i ] ) :
bc nb [ i ]= c ou nt er
co u nt er+=1
The algorithm is then as follows
A Prepare two arrays to store the matrix Mcbf and its right hand side rhscbf
B Loop over all elements
C For each element touching a boundary, compute the residual vector Rel =−fel +KelVel +GelPel
D Loop over the four edges of the element using the connectivity array
E For each edge loop over the number of degrees of freedom (2 in 2D)
F For each edge assess whether the dofs on both ends are target dofs.
G If so, compute the mass matrix Medge for this edge
H extract the 2 values off the element residual vector and assemble these in rhscbf
I Assemble Medge into NfemTrxNfemTr matrix using bc nb
M cbf = np . z e r os ( ( NfemTr , NfemTr ) , np . f l o a t 6 4 ) # A
r h s c b f = np . z e r os ( NfemTr , np . f l o a t 6 4 )
f o r i e l in range ( 0 , n e l ) : # B
. . . compute e l e m e n t a l r e s i d u a l . . . # C
#boundary 0−1 # D
f o r ii n r an g e ( 0 , ndofV ) : # E
i d o f 0 =2∗i c o n [ 0 , i e l ]+ i
i d o f 1 =2∗i c o n [ 1 , i e l ]+ i
i f ( b c f i x [ i d o f 0 ] and b c f i x [ i d o f 1 ] ) : # F
i d o f T r 0=bc n b [ i d o f 0 ]
i d o f T r 1=bc n b [ i d o f 1 ]
r h s c b f [ i d o f T r 0 ]+= r e s e l [0+ i ] # H
r h s c b f [ i d o f T r 1 ]+= r e s e l [2+ i ]
M cbf [ i d of T r 0 , i d o f T r 0 ]+=M edge [ 0 , 0 ] #
M cbf [ i d of T r 0 , i d o f T r 1 ]+=M edge [ 0 , 1 ] # I
M cbf [ i d of T r 1 , i d o f T r 0 ]+=M edge [ 1 , 0 ] #
M cbf [ i d of T r 1 , i d o f T r 1 ]+=M edge [ 1 , 1 ] #
#boundary 1−2 #[D]
...
#boundary 2−3 #[D]
...
#boundary 3−0 #[D]
...
103
7.15 The value of the timestep
The chosen time step dt used for time integration is chosen to comply with the Courant-Friedrichs-Lewy
condition [16].
δt =Cmin h
max |v|,h2
κ(254)
where his a measure of the element size, κ=k/ρcpis the thermal diffusivity and C is the so-called CFL
number chosen in [0,1[.
In essence the CFL condition arises when solving hyperbolic PDEs . It limits the time step in many
explicit time-marching computer simulations so that the simulation does not produce incorrect results.
This condition is not needed when solving the Stokes equation but it is mandatory when solving
the heat transport equation or any kind of advection-diffusion equation. Note that any increase of grid
resolution (i.e. hbecomes smaller) yields an automatic decrease of the time step value.
104
7.16 Mappings
The name isoparametric derives from the fact that the same (’iso’) functions are used as basis functions
and for the mapping to the reference element.
7.16.1 On a triangle
2
|\ s
| \ |_r
| \
3===1
Let us assume that the coordinates of the vertices are (x1, y1), (x2, y2), and (x3, y3). The coordinates
inside the reference element are (r, s). We then simply have the following relationship, i.e. any point of
the reference element can be mapped to the physical triangle as follows:
x=rx1+sx2+ (1 −r−s)x3(255)
y=ry1+sy2+ (1 −r−s)y3(256)
There is also an inverse map, which is easily computed:
r=(y2−y3)(x−x3)−(x2−x3)(y−y3)
(x1−x3)(y2−y3)−(y1−y3)(x2−x3)(257)
s=−(y1−y3)(x−x3)+(x1−x3)(y−y3)
(x1−x3)(y2−y3)−(y1−y3)(x2−x3)(258)
Remark. The denominator will not vanish, because it is a multiple of the area of the triangle.
105
7.17 Exporting data to vtk format
This format seems to be the universally accepted format for 2D and 3D visualisation in Computational
Geodynamics. Such files can be opened with free softwares such as Paraview 12, MayaVi 13 or Visit 14.
Unfortunately it is my experience that no simple tutorial exists about how to build such files. There
is an official document which describes the vtk format15 but it delivers the information in a convoluted
way. I therefore describe hereafter how fieldstone builds the vtk files.
I hereunder show vtk file corresponding to the 3x2 grid presented earlier 7.8. In this particular example
there are:
•12 nodes and 6 elements
•1 elemental field: the pressure p)
•2 nodal fields: 1 scalar (the smoothed pressure q), 1 vector (the velocity field u,v,0)
Note that vtk files are inherently 3D so that even in the case of a 2D simulation the z-coordinate of the
points and for instance their z-velocity component must be provided. The file, usually called solution.vtu
starts with a header:
<VTKFile typ e= ’ U ns tr uc t ur e dG r id ’ v e r s i o n= ’ 0 . 1 ’ b y t e o r d e r= ’ Big Endian ’>
<UnstructuredGrid>
<P i e c e N umberOfPoi nts= ’ 1 2 ’ N umbe rOf Cell s= ’ 6 ’>
We then proceed to write the node coordinates as follows:
<Poi nts >
<DataArray t ype= ’ F lo a t3 2 ’ NumberOfComponents= ’ 3 ’ Format= ’ a s c i i ’>
0. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
3.333333e−01 0. 00 0 00 0 e+00 0 . 00 00 00 e+00
6.666667e−01 0. 00 0 00 0 e+00 0 . 00 00 00 e+00
1. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
0. 000 000 e+00 5 .00 00 00 e−01 0 . 00 00 00 e+00
3.333333e−01 5. 00 000 0 e−01 0. 00 0 00 0 e+00
6.666667e−01 5. 00 000 0 e−01 0. 00 0 00 0 e+00
1. 000 000 e+00 5 .00 00 00 e−01 0 . 00 00 00 e+00
0. 0 00 00 0 e+00 1. 00 00 00 e+00 0 . 00 00 00 e+00
3.333333e−01 1. 00 0 00 0 e+00 0 . 00 00 00 e+00
6.666667e−01 1. 00 0 00 0 e+00 0 . 00 00 00 e+00
1. 0 00 00 0 e+00 1. 00 00 00 e+00 0 . 00 00 00 e+00
</DataArray>
</Po ints >
These are followed by the elemental field(s):
<Ce ll Dat a S c a l a r s= ’ s c a l a r s ’>
<DataArray t ype= ’ Fl oa t3 2 ’ Name= ’ p ’ Format= ’ a s c i i ’>
−1.333333 e+00
−3. 104414 e −10
1. 3 33 33 3 e+00
−1.333333 e+00
8.278417e−17
1. 3 33 33 3 e+00
</DataArray>
</CellData>
Nodal quantities are written next:
<Poi ntData S c a l a r s= ’ s c a l a r s ’>
<DataArray t ype= ’ F lo a t3 2 ’ NumberOfComponents= ’ 3 ’ Name= ’ v e l o c i t y ’ Format= ’ a s c i i ’>
0. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
0. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
0. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
0. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
12https://www.paraview.org/
13https://docs.enthought.com/mayavi/mayavi/
14https://wci.llnl.gov/simulation/computer-codes/visit/
15https://www.vtk.org/wp-content/uploads/2015/04/file-formats.pdf
106
0. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
8.888885e−08 −8.278 405 e −24 0. 0 00 00 0 e+00
8.888885e−08 1. 65 568 2 e−23 0. 00 0 00 0 e+00
0. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
1. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
1. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
1. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
1. 0 00 00 0 e+00 0. 00 00 00 e+00 0 . 00 00 00 e+00
</DataArray>
<DataArray t ype= ’ F lo a t3 2 ’ NumberOfComponents= ’ 1 ’ Name= ’ q ’ Format= ’ a s c i i ’>
−1.333333 e+00
−6. 666664 e −01
6.666664e−01
1. 3 33 33 3 e+00
−1.333333 e+00
−6. 666664 e −01
6.666664e−01
1. 3 33 33 3 e+00
−1.333333 e+00
−6. 666664 e −01
6.666664e−01
1. 3 33 33 3 e+00
</DataArray>
</PointData>
To these informations we must append 3 more datasets. The first one is the connectivity, the second
one is the offsets and the third one is the type. The first one is trivial since said connectivity is needed
for the Finite Elements. The second must be understood as follows: when reading the connectivity
information in a linear manner the offset values indicate the beginning of each element (omitting the zero
value). The third simply is the type of element as given in the vtk format document (9 corresponds to a
generic quadrilateral with an internal numbering consistent with ours).
<Cells>
<DataArray t ype= ’ In t3 2 ’ Name= ’ c o n n e c t i v i t y ’ Format= ’ a s c i i ’>
0 1 5 4
1 2 6 5
2 3 7 6
4 5 9 8
5 6 10 9
6 7 11 10
</DataArray>
<DataArray t ype= ’ In t 32 ’ Name= ’ o f f s e t s ’ Format=’ a s c i i ’>
4
8
12
16
20
24
</DataArray>
<DataArray t ype= ’ In t 32 ’ Name= ’ t yp es ’ Format= ’ a s c i i ’>
9
9
9
9
9
9
</DataArray>
</C e l l s >
The file is then closed with
</Pi ece >
</UnstructuredGrid>
</VTKFile>
The solution.vtu file can then be opened with ParaView, MayaVi or Visit and the reader is advised
to find tutorials online on how to install and use these softwares.
107
7.18 Runge-Kutta methods
These methods were developed around 1900 by the German mathematicians Carl Runge and Martin
Kutta. The RK methods are methods for the numerical integration of ODEs16. These methods are well
documented in any numerical analysis textbook and the reader is referred to [230, 301]. Any Runge-Kutta
method is uniquely identified by its Butcher tableau (REF?) which contains all necessary coefficients to
build the algorithm.
The simplest RungeKutta method is the (forward) Euler method. Its tableau is:
0
1
The standard second-order RK method method (also called midpoint method) is:
0
1/2 1/2
0 1
Another second-order RK method, called Heun’s method17 is follows:
0
1 1
1/2 1/2
A third-order RK method is as follows:
0
1/2 1/2
1 -1 2
1/6 4/6 1/6
The RK4 method falls in this framework. Its tableau is:
0
1/2 1/2
1/2 0 1/2
1 0 0 1
1/6 1/6 1/3 1/6
A slight variation of the standard RK4 method is also due to Kutta in 1901 and is called the 3/8-rule.
Almost all of the error coefficients are smaller than in the standard method but it requires slightly more
FLOPs per time step. Its Butcher tableau is
0
1/3 1/3
2/3 -1/3 1
1 1 -1 1
1/8 3/8 3/8 1/8
The following method is called the Runge-Kutta-Fehlberg method and is commonly abbreviated
RKF4518 . Its Butcher tableau is as follows:
0
1/4 1/4
3/8 3/32 9/32
12/13 1932/2197 -7200/2197 7296/2197
1 439/216 -8 3680/513 -845/4104
1/2 -8/27 2 -3544/2565 1859/4104 -11/40
16/135 0 6656/12825 28561/56430 -9/50 2/55
25/216 0 1408/2565 2197/4104 -1/5 0
The first row of coefficients at the bottom of the table gives the fifth-order accurate method, and the
second row gives the fourth-order accurate method.
7.18.1 Using RK methods to advect particles/markers
In the context of geodynamical modelling, one is usually confronted to the following problem: now that
I have a velocity field on my FE mesh, how can I use it to advect the Lagrangian markers?
16https://en.wikipedia.org/wiki/Runge-Kutta_methods
17https://en.wikipedia.org/wiki/Heun’s_method
18https://en.wikipedia.org/wiki/Runge-Kutta-Fehlberg_method
108
Runge-Kutta methods are used to this effect but only their spatial component is used: the velocity
solution is not recomputed at the intermediate fractional timesteps, i.e. only the coefficients of the right
hand side of the tableaus is used.
The RK1 method is simple. Carry out a loop over markers and
1. interpolate velocity
νmonto each marker m
2. compute new position as follows: rm(t+δt) = rm(t) +
νmδt
The RK2 method is also simple but requires a bit more work. Carry out a loop over markers and
1. interpolate velocity
νmonto each marker mat position rm
2. compute new intermediate position as follows: r(1)
m(t+δt) = rm(t) +
νmδt/2
3. compute velocity
ν(1)
mat position r(1)
m
4. compute new position: rm(t+δt) = rm(t) +
ν(1)
mδt
Note that the intermediate positions could be in a different element of the mesh so extra care must be
taken when computing intermediate velocities.
The RK3 method introduces two intermediate steps. Carry out a loop over markers and
1. interpolate velocity
νmonto each marker mat position rm
2. compute new intermediate position as follows: r(1)
m(t+δt) = rm(t) +
νmδt/2
3. compute velocity
ν(1)
mat position r(1)
m
4. compute new intermediate position as follows: r(2)
m(t+δt) = rm(t) + (2
ν(1)
m−
νm)δt/2
5. compute velocity
ν(2)
mat position r(2)
m
6. compute new position: rm(t+δt) = rm(t)+(
νm+ 4
ν(1)
m+
ν(2)
m)δt/6
109
7.19 Am I in or not? - finding reduced coordinates
It is quite common that at some point one must answer the question: ”Given a mesh and its connectivity
on the one hand, and the coordinates of a point on the other, how do I accurately and quickly determine
in which element the point resides?”
One typical occurence of such a problem is linked to the use of the Particle-In-Cell technique: particles
are advected and move through the mesh, and need to be localised at every time step. This question could
arise in the context of a benchmark where certain quantities need to be measured at specific locations
inside the domain.
7.19.1 Two-dimensional space
We shall first focus on quadrilaterals. There are many kinds of quadrilaterals as shown hereunder:
I wish to arrive at a single algorithm which is applicable to all quadrilaterals and therefore choose an
irregular quadrilateral. For simplicity, let us consider a Q1element, with a single node at each corner.
01
23
M
Several rather simple options exist:
•we could subdivide the quadrilateral into two triangles and check whether point Mis inside any of
them (as it turns out, this problem is rather straightforward for triangles. Simply google it.)
•We could check that point Mis always on the left side of segments 0 →1, 1 →2, 2 →3, 3 →0.
•...
Any of these approaches will work although some might be faster than others. In three-dimensions
all will however become cumbersome to implement and might not even work at all. Fortunately, there is
an elegant way to answer the question, as detailed in the following subsection.
7.19.2 Three-dimensional space
If point Mis inside the quadrilateral, there exist a set of reduced coordinates r, s, t ∈[−1 : 1]3such that
4
X
i=1
Ni(rM, s, t)xi=xM
4
X
i=1
Ni(rM, s, t)yi=yM
4
X
i=1
Ni(rM, s, t)zi=zM
110
This can be cast as a system of three equations and three unknowns. Unfortunately, each shape function
Nicontains a term rst (as well as rs,rt, and st) so that it is not a linear system and standard techniques
are not applicable. We must then use an iterative technique: the algorithm starts with a guess for values
r, s, t and improves on their value iteration after iteration.
The classical way of solving nonlinear systems of equations is Newton’s method. We can rewrite the
equations above as F(r, s, t) = 0:
8
X
i=1
Ni(r, s, t)xi−xM= 0
8
X
i=1
Ni(r, s, t)yi−yM= 0
8
X
i=1
Ni(r, s, t)zi−zM= 0 (259)
or,
Fr(r, s, t)=0
Fs(r, s, t)=0
Ft(r, s, t)=0
so that we now have to find the zeroes of continuously differentiable functions F:R→R. The
recursion is simply:
rk+1
sk+1
tk+1
=
rk
sk
tk
−JF(rk, sk, tk)−1
Fr(rk, sk, tk)
Fs(rk, sk, tk)
Ft(rk, sk, tk)
where Jthe Jacobian matrix:
JF(rk, sk, tk) =
∂Fr
∂r (rk, sk, tk)∂Fr
∂s (rk, sk, tk)∂Fr
∂t (rk, sk, tk)
∂Fs
∂r (rk, sk, tk)∂Fs
∂s (rk, sk, tk)∂Fs
∂t (rk, sk, tk)
∂Ft
∂r (rk, sk, tk)∂Ft
∂s (rk, sk, tk)∂Ft
∂t (rk, sk, tk)
=
8
P
i=1
∂Ni
∂r (rk, sk, tk)xi
8
P
i=1
∂Ni
∂s (rk, sk, tk)xi
8
P
i=1
∂Ni
∂t (rk, sk, tk)xi
8
P
i=1
∂Ni
∂r (rk, sk, tk)yi
8
P
i=1
∂Ni
∂s (rk, sk, tk)yi
8
P
i=1
∂Ni
∂t (rk, sk, tk)yi
8
P
i=1
∂Ni
∂r (rk, sk, tk)zi
8
P
i=1
∂Ni
∂s (rk, sk, tk)zi
8
P
i=1
∂Ni
∂t (rk, sk, tk)zi
In practice, we solve the following system:
JF(rk, sk, tk)
rk+1
sk+1
tk+1
−
rk
sk
tk
=−
Fr(rk, sk, tk)
Fs(rk, sk, tk)
Ft(rk, sk, tk)
Finally, the algorithm goes as follows:
•set guess values for r, s, t (typically 0)
•loop over k=0,...
•Compute rhs= −F(rk, sk, tk)
•Compute matrix JF(rk, sk, tk)
111
•solve system for (drk, dsk, dtk)
•update rk+1 =rk+drk,sk+1 =sk+dsk,tk+1 =tk+dtk
•stop iterations when (drk, dsk, dtk) is small
•if rk, sk, tk∈[−1,1]3then Mis inside.
This method converges quickly but involves iterations, and multiple solves of 3 ×3 systems which, when
carried out for each marker and at each time step can prove to be expensive. A simple modification can
be added to the above algorithm: iterations should be carried out only when the point Mis inside of a
cuboid of size [min
ixi: max
ixi]×[min
iyi: max
iyi]×[min
izi: max
izi] where the sums run over the vertices
of the element. In 2D this translates as follows: only carry out Newton iterations when Mis inside the
red rectangle!
01
23
M
Note that the algorithm above extends to high degree elements such as Q2and higher, even with
curved sides.
write about case when element is rectangle/cuboid
112
7.20 Error measurements and convergence rates
What follows is written in the case of a two-dimensional model. Generalisation to 3D is trivial. What
follows is mostly borrowed from [515].
When measuring the order of accuracy of the primitive variables v and p, it is standard to report
errors in both the L1and the L2norm. For a scalar quantity Ψ, the L1and L2norms are computed as
kΨk1=ZV|Ψ|dV kΨk2=sZV
Ψ2dV (260)
For a vector quantity
k= (kx, ky) in a two-dimensional space, the L1and L2norms are defined as:
k
1=ZV
(|kx|+|ky|)dV
k
2=sZV
(k2
x+k2
y)dV (261)
To compute the respective norms the integrals in the above norms can be approximated by splitting
them into their element-wise contributions. The element volume integral can then be easily computed by
numerical integration using Gauss-Legendre quadrature.
The respective L1and L2norms for the pressure error can be evaluated via
eh
p|1=
ne
X
i=1
nq
X
q=1 |eh
p(rq)|wq|Jq|eh
p|2=v
u
u
t
ne
X
i=1
nq
X
q=1 |eh
p(rq)|2wq|Jq|(262)
where eh
p(rq) = ph(rq)−p(rq) is the pressure error evaluated at the q-th quadrature associated with the
ith element. neand nqrefer to the number of elements and the number of quadrature points per element.
wqand Jqare the quadrature weight and the Jacobian associated with point q.
The velocity error eh
~v is evaluated using the following two norms
eh
~v |1=
ne
X
i=1
nq
X
q=1
[|eh
u(rq)|+|eh
v(rq)|]wq|Jq|eh
~v |2=v
u
u
t
ne
X
i=1
nq
X
q=1
[|eh
u(rq)|2+eh
v(rq)|2]wq|Jq|(263)
where eh
u(rq) = uh(rq)−u(rq) and eh
v(rq) = vh(rq)−v(rq).
Another norm is very rarely used in the geodynamics literature but is preferred in the Finite Element
literature: the H1norm. The mathematical basis for this norm and the nature of the H1(Ω) Hilbert
space is to be found in many FE books [158, 311, 290]. This norm is expressed as follows for a function
fsuch that f, |∇f| ∈ L2(Ω) 19
kfkH1=ZΩ
(|f|2+|∇f|2)dΩ1/2
(264)
We then have
eh
~v |H1=
vh−v
H1=v
u
u
t
d
X
i=1 ZΩh(vh
i−vi)2+
∇(vh
i−vi)·
∇(vh
i−vi)idΩ (265)
where dis the number of dimensions. Note that sometimes the following semi-norm is used [157, 62]:
eh
~v |H1=
vh−v
H1=v
u
u
t
d
X
i=1 ZΩh
∇(vh
i−vi)·
∇(vh
i−vi)idΩ (266)
When computing the different error norms for epand e~v for a set of numerical experiments with
varying resolution hwe expect the error norms to follow the following relationships:
eh
~v |1=ChrvL1eh
~v |2=ChrvL2eh
~v |H1=ChrvH1(267)
19https://en.wikipedia.org/wiki/Sobolev_space
113
eh
p|1=ChrpL1eh
p|2=ChrpL2(268)
where Cis a resolution-independent constant and rpXX and rvXX are the convergence rates for pressure
and velocity in various norms, respectively. Using linear regression on the logarithm of the respective
error norm and the resolution h, one can compute the convergence rates of the numerical solutions.
As mentioned in [157], when finite element solutions converge at the same rates as the interpolants
we say that the method is optimal, i.e.:
eh
~v |L2=O(h3)eh
~v |H1=O(h2)eh
p|L2=O(h2) (269)
We note that when using discontinuous pressure space (e.g., P0,P−1), these bounds remain valid even
when the viscosity is discontinuous provided that the element boundaries conform to the discontinuity.
7.20.1 About extrapolation
Section contributed by W. Bangerth and part of Thieulot & Bangerth [in prep.]
In a number of numerical benchmarks we want to estimate the error Xh−X∗between a quantity Xh
computed from the numerical solution uh, phand the corresponding value Xcomputed from the exact
solution u, p. Examples of such quantities Xare the root mean square velocity vrms, but it could also be
a mass flux across a boundary, an average horizontal velocity at the top boundary, or any other scalar
quantity.
If the exact solution is known, then one can of course compute Xfrom it. On the other hand, we would
of course like to assess convergence also in cases where the exact solution is not known. In that case, one
can compute an estimate X∗for Xby way of extrapolation. To this end, we make the assumption that
asymptotically, Xhconverges to Xat a fixed (but unknown) rate r, so that
eh=|Xh−X| ≈ Chr.(270)
Here, X,Cand rare all unknown constants to be determined, although we are not really interested in
C. We can evaluate Xhfrom the numerical solution on successively refined meshes with mesh sizes h,
h/2, and h/4. Then, in addition to (270) we also have
eh/2=|Xh/2−X| ≈ Ch
2r
,(271)
eh/4=|Xh/4−X| ≈ Ch
4r
.(272)
Taking ratios of equations (270)–(272), and replacing the unknown Xby an estimate X∗, we then arrive
at the following equation:
|Xh−X?|
|Xh/2−X?|=|Xh/2−X?|
|Xh/4−X?|= 2r.
If one assumes that Xhconverges to Xuniformly either from above or below (rather than oscillate around
X), then this equation allows us to solve for X∗and r:
X?=XhXh/2−X2
h/2
Xh−2Xh/2+Xh/4
, r = log2
Xh/2−X?
Xh/4−X?.
In the determination of r, we could also have used Xhand Xh/2, but using Xh/2and Xh/4is generally
more reliable because the higher order terms we have omitted in (270) are less visible on finer meshes.
114
7.21 The initial temperature field
7.21.1 Single layer with imposed temperature b.c.
Let us take a single layer of material characterised by a heat capacity cp, a heat conductivity kand a
heat production term H.
The Heat transport equation writes
ρcp(∂T
∂t +v ·
∇T) =
∇ · (k
∇T) + ρH
At steady state and in the absence of a velocity field, assuming that the material properties to be
independent of time and space, and assuming that there is no heat production (H= 0), this equation
simplifies to
∆T= 0
Assuming the layer to be parallel to the x-axis, the temperature is
T(x, y) = T(y) = αT +β
In order to specify the constants αand β, we need two constraints.
At the bottom of the layer y=yba temperature Tbis prescribed while a temperature Ttis prescribed
at the top with y=yt. This ultimately yields a temperature field in the layer given by
T(y) = Tt−Tb
yt−yb
(y−yb) + Tb
If now the heat production coefficient is not zero, the differential equation reads
k∆T+H= 0
The temperature field is then expected to be of the form
T(y) = −H
2ky2+αy +β
Supplied again with the same boundary conditions, this leads to
β=Tb+H
2ky2
b−αyb
ie,
T(y) = −H
2k(y2−y2
b) + α(y−yb) + Tb
and finally
α=Tt−Tb
yt−yb
+H
2k(yb+yt)
or,
T(y) = −H
2k(y2−y2
b) + Tt−Tb
yt−yb
+H
2k(yb+yt)(y−yb) + Tb
Taking H= 0 in this equation obviously yields the temperature field obtained previously. Taking
k= 2.25, Tt= 0C,Tb= 550C,yt= 660km,yb= 630km yields the following temperature profiles and
heat fluxes when the heat production Hvaries:
115
0
100
200
300
400
500
600
625000 630000 635000 640000 645000 650000 655000 660000
Temperature (C)
y
H=0.0e-6
H=0.8e-6
H=1.6e-6
0
0.01
0.02
0.03
0.04
0.05
0.06
0.07
625000 630000 635000 640000 645000 650000 655000 660000
heat flux (W/m2)
y
H=0.0e-6
H=0.4e-6
H=0.8e-6
H=1.0e-6
H=1.2e-6
H=1.6e-6
Looking at the values at the top, which are somewhat estimated to be about 55 −65mW/m2[310, table
8.6], one sees that value H= 0.8e−6 yields a very acceptable heat flux. Looking at the bottom, the heat
flux is then about 0.03W/m2which is somewhat problematic since the heat flux at the Moho is reported
to be somewhere between 10 and 20 mW/m2in [310, table 7.1].
7.21.2 Single layer with imposed heat flux b.c.
Let us now assume that heat fluxes are imposed at the top and bottom of the layer:
We start again from the ODE
k∆T+H= 0
but only integrate it once:
kdT
dy +Hy +α= 0
At the bottom q=k(dT/dy)|y=yb=qband at the top q=k(dT/dy)|y=yt=qtso that
to finish
7.21.3 Single layer with imposed heat flux and temperature b.c.
to finish
7.21.4 Half cooling space
7.21.5 Plate model
7.21.6 McKenzie slab
When doing thermo-mechanical modelling, the initial temperature field in the domain is of prime impor-
tance. This is especially true for the temperature in the slab for subduction modelling as its rheological
behaviour is strongly temperature-dependent. One could easily design a simple geometrical initial field
but it is unlikely to be close to the field of a slowly subducting slab at an angle in a hot mantle.
McKenzie [389] derived such approximate initial field from the steady-state energy equation in two
dimensions:
ρcpv ·
∇T=k
∇2T
116
We denote by Tlthe temperature at the base of the lithosphere and lits thickness (i.e. the thickness of
the slab).
Assuming v = (vx,0) yields
ρcpvx
∂T
∂x =k∂2T
∂x2
and substitution of T0=T/Tl,x0=x/l and z0=z/l ∈[0,1] in this equation leads to
ρcpvx
Tl
l
∂T 0
∂x0=kTl
l2∂2T0
∂x02+∂2T0
∂z02
or ρcpvxl
k
∂T 0
∂x0=∂2T0
∂x02+∂2T0
∂z02
and finally (see Eq. 2.3 of [389]):
∂2T0
∂x02−2R∂T 0
∂x0+∂2T0
∂z02= 0
where Ris the thermal Reynolds number
R=ρcpvxl
2k
The general solution to this PDE with T0= 1 on the top, left and right boundary is
T0(x0, z0) = 1 + X
n
Cnexp hR−(R2+n2π2)1/2x0isin(nπz0)
We now must make an assumption about the temperature on the left boundary (x0= 0), which is the
temperature of the lithosphere. For simplicity McKenzie assumes that T0(x0= 0, z0)=1−z0so that
Cn= 2(−1)n/nπ and finally
T0(x0, z0) = 1 + 2 X
n
(−1)n
nπ exp hR−(R2+n2π2)1/2x0isin(nπz0)(273)
Let us build a simple temperature model for a 250km ×50km slab, with ρ= 3000, cp= 1250, k= 3.
The python code is available in images/mckenzie/mckenzie1.py.
Left to right: Dimensionless temperature T0in a 250km ×50km slab for vx= 0.5,1,2cm/year
We logically recover the fact that the slower the slab penetrates the mantle the more temperature
diffusion dominates over temperature advection. For v= 0.5cm/year we see that that the slab assumes
a constant temperature T0= 1 at all depthes 0 ≤z0≤1 for x0≥125km.
Note that this field is a steady-state field, valid for a constant density, heat conductivity and heat
capacity, zero heat production, that it implies that the velocity is constant and that the lithosphere
temperature is linear.
One can also embed the slab in a more realistic context, a subduction zone, involving a subducting
lithosphere, an over-riding plate and a mantle. The domain is 1000km ×250km. The mantle temperature
is set to 1300◦. The slab dip can be varied and so can the velocity. The python code is available in
images/mckenzie/mckenzie2.py.
117
Left to right: temperature Tfor vx= 0.5,1,2cm/year and φ= 30◦.
Left to right: temperature Tfor vx= 1cm/year and φ= 15,30,45◦.
118
7.22 Kinematic boundary conditions
Boundary conditions come in two basic flavors: essential and natural.
•Essential bcs directly affect DOFs, and are imposed on the FEM matrix.
•Natural bcs do not directly affect DOFs and are imposed on the right-hand side vector.
7.22.1 In-out flux boundary conditions for lithospheric models
The velocity on the side is given by
u(y) = vext y < L1
u(y) = vin −vext
y2−y1
(y−y1) + vext y1< y < y2
u(y) = vin y > y2
The requirement for volume conservation is:
Φ = ZLy
0
u(y)dy = 0
Having chosen vin (the velocity of the plate), one can then compute vext as a function of y1and y2.
Φ = Zy1
0
u(y)dy +Zy2
y1
u(y)dy +ZLy
y2
u(y)dy
=vexty1+1
2(vin +vext)(y2−y1)+(Ly−y2)vin
=vext[y1+1
2(y2−y1)] + vin[1
2(y2−y1)+(Ly−y2)]
=vext
1
2(y1+y2) + vin[Ly−1
2(y1+y1)]
and finally
vext =−vin
Ly−1
2(y1+y1)
1
2(y1+y2)
119
7.23 Computing gradients - the recovery process
write about recovering accurate strain rate components and heat flux components on the nodes.
Let g(r) be the desired nodal field which we want to be the continuous Q1representation of the
field
∇fh. Since the derivative of the shape function does not exist on the nodes we need to design an
algorithm do do so. This problem is well known and has been investigated [?]
refs!
. The main standard techniques are listed hereafter.
7.23.1 Global recovery
The global recovery approach is rather simple: we wish to find ghsuch that it satisfies
ZΩ
φghdΩ = ZΩ
φ
∇fhdΩ∀φ
We will then successively replace φby all the shape functions Niand since we have gh=PjNigiwe
then obtain X
jZNiNjdΩgi=ZNi
∇fhdΩ
or,
M·
G=
f
7.23.2 Local recovery - centroid average over patch
7.23.3 Local recovery - nodal average over patch
Let jbe the node at which we want to compute g. Then
gj=g(rj) = P
eadj. to j|Ωe|(
∇f)e(rj)
P|Ωe|
where |Ωe|is the volume of the element and (
∇fh)e(rj) is the gradient of fas obtained with the shape
functions inside element eand computed at location rj.
7.23.4 Local recovery - least squares over patch
7.23.5 Link to pressure smoothing
When the penalty method is used to solve the Stokes equation, the pressure is then given by p=−λ
∇·v.
As explained in section 6.3, the velocity is first obtained and the pressure is recovered by using this
equation as a postprocessing step. Since the divergence cannot be computed easily at the nodes, the
pressure is traditionally computed in the middle of the elements, yielding an elemental pressure field
(remember, we are talking about Q1P0elements here – bi/tri-linear velocity, discontinuous constant
pressure)
tie to fieldstone 12
120
7.24 Tracking materials and/or interfaces
Unless fully Lagrangian, one needs an additional numerical method to represent/track the various mate-
rials present in an undeformable (Eulerian) mesh.
make a distinction between particle-in-cell and marker-and-cell
7.24.1 The Particle-in-cell technique
[213]
The Particle-in-cell method is widely used in the geodynamic literature [?, e.g.]]popo92
[Poliakov and Podladchikov, 1992; Moresi et al., 2003; Gerya and Yuen, 2003; McNamara and Zhong,
2004; Popov and Sobolev, 2008; Thielmann et al., 2014]
It is the SOPALE, FANTOM, ELEFANT, I2/3(EL)VIS, ...
7.24.2 The level set function technique
7.24.3 The field/composition technique
This is the approach taken by the ASPECT developers [339, 282]
7.24.4 Hybrid methods
Particle level sets [75], [465]
121
7.25 Static condensation
The idea behind is quite simple: in some cases, there are dofs belonging to an element which only belong
to that element. For instance, the so-called MINI element (P+
1×P1) showcases a bubble function in the
middle (see section ??). In the following,
V?corresponds to the list of such dofs inside an element. The
discretised Stokes equations on any element looks like:
KLG
LTK?H
GTHT0
e
V
V?
P
e
=
f
f?
h
e
(274)
This is only a re-writing of the elemental Stokes matrix where the matrix Khas been split in four parts.
Note that the matrix K?is diagonal. checkcheck
This can also be re-written in non-matrix form:
K·
V+L·
V?+G·
P=
f(275)
LTV+K?·
V?+H·
P=
f?(276)
GT·
V+HT
V?=
h(277)
The V?in the second equation can be isolated:
V?=K−?·(
f?−LT·
V − H·
P)
and inserted in the first and third equations:
K·
V+LhK−?(
f?−LT·
V − H·
P)i+G·
P=
f(278)
GT·
V+HThK−?(
f?−LT·
V − H·
P)i=
h(279)
or,
(K−L·K−?·LT)·
V+ (G−L·K−?·H)·
P=
f−L·K−?·
f?(280)
(GT−HT·K−?·LT)·
V − (HT·K−?·H)·
P=
h−HT·K−?·
f?(281)
i.e.
K·
V+G·
P=
f(282)
GT·
V − C·
P=
h(283)
with
K=K−L·K−?·LT(284)
G=G−L·K−?·H(285)
C=HT·K−?·H(286)
f=
f−L·K−?·
f?(287)
h=
h−HT·K−?·
f?(288)
Note that Kis symmetric, and so is the Stokes matrix.
For instance, in the case of the MINI element, the dofs corresponding to the bubble could be eliminated
at the elemental level, which would make the Stokes matrix smaller. However, it is then important to
note that static condensation introduces a pressure-pressure term which was not there in the original
formulation.
122
7.26 Measuring incompressibility
The velocity divergence error integrated over the whole element is given by
ediv =ZΩ
(
∇ ·vh−
∇ ·v
|{z}
=0
)dΩ = ZΩ
(
∇ ·vh)dΩ (289)
where Γeis the boundary of element eand n is the unit outward normal of Γe.
Furthermore, one can show that [157]:
ediv =ZΓe
vh·n dΓ
The reason is as follows and is called the divergence theorem20: suppose a volume Vsubset of Rdwhich
is compact and has a piecewise smooth boundary S, and if
Fis a continuously differentiable vector field
then ZV
(
∇ ·
F)dV =ZS
(
F·n)dS
The left side is a volume integral while the right side is a surface integral. Note that sometimes the
notation d
S=n dS is used so that
F·n dS =
F·d
S.
The average velocity divergence over an element can be defined as
<
∇ ·v >e=1
VeZΩe
(
∇ ·v)dΩ = 1
VeZΓe
v ·n dΓ
Note that for elements using discontinuous pressures we shall recover a zero divergence element per ele-
ment (local mass conservation) while for continuous pressure elements the mass conservation is guaranteed
only globally (i.e. over the whole domain), see section 3.13.2 of [266].
Note that one could instead compute <|
∇·v|>e. Either volume or surface integral can be computed
by means of an appropriate Gauss-Legendre quadrature algorithm.
implement and report
20https://en.wikipedia.org/wiki/Divergence_theorem
123
7.27 Periodic boundary conditions
This type of boundary conditions can be handy in some specific cases such as infinite domains. The idea
is simple: when material leaves the domain through a boundary it comes back in through the opposite
boundary (which of course presupposes a certain topology of the domain).
For instance, if one wants to model a gas at the molecular level and wishes to avoid interactions of the
molecules with the walls of the container, such boundary conditions can be used, mimicking an infinite
domain in all directions.
Let us consider the small mesh depicted hereunder:
missing picture
We wish to implement horizontal boundary conditions so that
u5=u1u10 =u6u15 =u11 u20 =u16
One could of course rewrite these conditions as constraints and extend the Stokes matrix but this approach
turns out to be not practical at all.
Instead, the method is rather simple: replace in the connectivity array the dofs on the right side
(nodes 5, 10, 15, 20) by the dofs on the left side. In essence, we wrap the system upon itself in the
horizontal direction so that elements 4, 8 and 12 ’see’ and are ’made of’ the nodes 1, 6, 11 and 16. In
fact, this is only necessary during the assembly. Everywhere in the loops nodes 5, 10, 15 and 20 appear
one must replace them by their left pendants 1, 6, 11 and 16. This autmatically generates a matrix with
lines and columns corresponding to the u5,u10,u15 and u20 being exactly zero. The Stokes matrix is the
same size, the blocks are the same size and the symmetric character of the matrix is respected. However,
there remains a problem. There are zeros on the diagonal of the above mentioned lines and columns.
One must then place there 1 or a more appropriate value.
Another way of seeing this is as follows: let us assume we have built and assembled the Stokes matrix,
and we want to impose periodic b.c. so that dof jand iare the same. The algorithm is composed of four
steps:
1. add col jto col i
2. add row jto row i(including rhs)
3. zero out row j, col j
4. put average diagonal value on diagonal (j, j)
Remark. Unfortunately the non-zero pattern of the matrix with periodic b.c. is not the same as the
matrix without periodic b.c.
124
7.28 Removing rotational nullspace
June 16, 2019 - C.T.
When free slip boundary conditions are prescribed in an annulus or hollow sphere geometry there
exists a rotational nullspace, or in other words there exists a tangential velocity field (’pure rotation’)
which, if added or subtracted to the solution, genrates a solution which is still the solution of the PDEs.
As in the pressure normalisation case (see section 7.12), the solution is simple:
1. fix the tangential velocity at one node on a boundary, and solve the sytem (the nullspace has been
removed)
2. post-process the solution to have the velocity field fulfill the required conditions, i.e. either a zero
net angular momentum or a zero net angular velocity of the domain.
Remark. In Aspect this is available under the option ”Remove nullspace = angular momentum” and
”Remove nullspace = net rotation”. The ”angular momentum” option removes a rotation such that the
net angular momentum is zero. The ”net rotation” option removes the net rotation of the domain.
Angular momentum approach In order to remove the angular momentum, we search for a rotation
vector ω such that ZΩ
ρ[r ×(v −ω ×r)] dV =
0 (290)
The angular momentum of a rigid body can be obtained from the sum of the angular momentums of
the particles forming the body21:
H=X
i
Li(291)
=X
i
ri×mivi(292)
=X
i
ri×mi(ωi×ri) (293)
=X
i
mi
Pimi(y2
i+z2
i)−Pimixiyi−Pimixizi
−PimixiyiPimi(x2
i+z2
i)−Pimiyizi
−Pimixizi−PimiyiziPimi(x2
i+y2
i)
·
ωx
ωy
ωz
(294)
In the continuum limit, we have:
H=ZΩ
ρ(r)r ×v dV (295)
and the 3 ×3 moment of inertia tensor I(also called inertia tensor) is given by22
I=ZΩ
ρ(r)[r ·r 1−r ×r]dV (296)
so that the above equation writes:
H=I·ω and then ω =I−1·
H.
Ultimately, at each velocity node a rotation about the rotation vector ω is then subtracted from the
velocity solution [599, eq. 26]:
vnew =vold −ω ×r (297)
Angular velocity approach The angular velocity23 vector is given by ω =~r×~v
r2so that the volume-
averaged angular velocity of the cylindrical shell is:
ω =1
|Ω|ZΩ
r ×v
r2dV (298)
21http://www.kwon3d.com/theory/moi/iten.html
22https://en.wikipedia.org/wiki/Moment_of_inertia
23https://en.wikipedia.org/wiki/Angular_velocity
125
7.28.1 Three dimensions
The angular momentum vector is given by:
H=ZΩ
ρ(r)
yw −zv
zu −xw
xv −yu
dr =
RΩρ(r)(yw −zv)dr
RΩρ(r)(zu −xw)dr
RΩρ(r)(xv −yu)dr
=
Hx
Hy
Hz
(299)
while the inertia tensor for a continuous body is given by
I=ZΩ
ρ(r)[r ·r 1−r ×r]dr (300)
=ZΩ
ρ(r)
x2+y2+z20 0
0x2+y2+z20
0 0 x2+y2+z2
−
xx xy xz
yx yy yz
zx zy zz
dr (301)
=ZΩ
ρ(r)
y2+z2−xy −xz
−yx x2+z2−yz
−zx −zy x2+y2
dr (302)
=
RΩρ(r)(y2+z2)dr −RΩρ(r)xydr −RΩρ(r)xzdr
−RΩρ(r)yxdr RΩρ(r)(x2+z2)dr −RΩρ(r)yzdr
−RΩρ(r)zxdr −RΩρ(r)zydr RΩρ(r)(x2+y2)dr
(303)
=
Ixx Ixy Ixz
Iyx Iyy Iyz
Izx Izy Izz
(304)
7.28.2 Two dimensions
In two dimensions, flow is taking place in the (x, y) plane. This means that r = (x, y, 0) and v = (u, v, 0)
are coplanar, and therefore that ω is perpendicular to the plane. We have then
H=ZΩ
ρ(r)
0
0
xv −yu
dr =
0
0
RΩρ(r)(xv −yu)dr
(305)
and
I=
Ixx Ixy Ixz
Iyx Iyy Iyz
Izx Izy Izz
=
Ixx Ixy 0
Iyx Iyy 0
0 0 Izz
(306)
since Ixz =Iyz = 0 as z= 0, and with Ixx =RΩρ(r)y2dr and Iyy =RΩρ(r)x2dr. The solution to
I·ω =
Hcan be easily obtained (see Appendix G.2):
ωx=1
det(I)
0Ixy 0
0Iyy 0
H30Izz
= 0 (307)
ωy=1
det(I)
Ixx 0 0
Iyx 0 0
0HzIzz
= 0 (308)
ωz=1
det(I)
Ixx Ixy 0
Iyx Iyy 0
0 0 Hz
(309)
=1
det(I)(IxxIyyHz−IyxIxyHz) (310)
=1
det(I)(IxxIyy −IyxIxy )Hz(311)
126
with det(I) = IxxIyyIzz −IyxIxyIzz. Concretely, this means that in 2D one does not need to solve the
system I·ω =
Hsince only ωzis not zero.
Likewise, the volume-averaged angular velocity is then simply:
ωz=1
|Ω|ZΩ
xv −yu
r2dr (312)
127
7.29 Picard and Newton
explain why our eqs are nonlinear
7.29.1 Picard iterations
Let us consider the following system of nonlinear algebraic equations:
A(
X)·
X=
b(
X)
Both matrix and right hand side depend on the solution vector
X.
For many mildly nonlinear problems, a simple successive substitution iteration scheme (also called
Picard method) will converge to the solution and it is given by the simple relationship:
A(
Xn)·
Xn+1 =
b(
Xn)
where nis the iteration number. It is easy to implement:
1. guess
X0or use the solution from previous time step
2. compute Aand
bwith current solution vector
Xold
3. solve system, obtain Tnew
4. check for convergence (are
Xold and
Xnew close enough?)
5.
Xold ←
Xnew
6. go back to 2.
There are various ways to test whether iterations have converged. The simplest one is to look at
Xold −
Xnew
(in the L1,L2or maximum norm) and assess whether this term is smaller than a given
tolerance . However this approach poses a problem: in geodynamics, if two consecutively obtained
temperatures do not change by more than a thousandth of a Kelvin (say = 10−3K ) we could consider
that iterations have converged but looking now at velocities which are of the order of a cm/year (i.e.
∼3·10−11m/s) we would need a tolerance probably less than 10−13m/s. We see that using absolute values
for a convergence criterion is a potentially dangerous affair, which is why one uses a relative formulation
(thereby making a dimensionless parameter):
Xold −
Xnew
Xnew
<
Another convergence criterion is proposed by Reddy (section 3.7.2) [453]:
(
Xold −
Xnew)·(
Xold −
Xnew)
Xnew ·Xnew !1/2
<
Yet another convergence criterion is used in [516]: the means <
Xold >,<
Xnew >as well as the
variances σold and σnew are computed, followed by the correlation factor R:
R=<(
Xold−<
Xold >)·(
Xnew−<
Xnew >)>
√σoldσnew
Since the correlation is normalised, it takes values between 0 (very dissimilar velocity fields) and 1 (very
similar fields). The following convergence criterion is then used: 1 −R < .
write about nonlinear residual
Note that in some instances and improvement in convergence rate can be obtained by use of a relax-
ation formula where one first solves
A(
Xn)·
X?=
b(
Xn)
and then updates
Xnas follows:
Xn=γ
Xn+ (1 −γ)
X?0< γ ≤1
When γ= 1 we recover the standard Picard iterations formula above.
128
7.30 Defect correction formulation
Work in progress.
We start from the system to solve:
A(
X)·
X=
b(
X)
with the associated residual vector
F
F(
X) = A(
X)·
X−
b(
X)
The Newton-Raphson algorithm consists of two steps:
1. solve Jk·δ
Xk=−
F(
Xk), or in the case of the incompressible Stokes equation FEM system:
JVV
kJVP
k
JPV
k0·δ
Vk
δ
Pk=−
FV
k
−
FP
k
2. update
Xk+1 =
Xk+αkδ
Xk
The defect correction Picard approach consists of neglecting the derivative terms present in the Jterms
(Eqs. 16,17,18 of [199]) so that
JVV
k'KkJVP
k'GJPV
k'GT
and step 1 of the above iterations become:
KkG
GT0·δ
Vk
δ
Pk=−
FV
k
−
FP
k
129
8fieldstone 01: simple analytical solution
This fieldstone was developed in collaboration with Job Mos.
This benchmark is taken from [158] and is described fully in section 7.4. In order to illustrate the
behavior of selected mixed finite elements in the solution of stationary Stokes flow, we consider a two-
dimensional problem in the square domain Ω = [0,1] ×[0,1], which possesses a closed-form analytical
solution. The problem consists of determining the velocity field v= (u, v) and the pressure psuch that
η∆v −
∇p+
b=
0 in Ω
∇ ·v = 0 in Ω
v=
0 on ΓD
where the fluid viscosity is taken as η= 1.
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions (no-slip)
•direct solver
•isothermal
•isoviscous
•analytical solution
130
0.000001
0.000010
0.000100
0.001000
0.010000
0.100000
0.01 0.1
error
h
velocity
pressure
x2
x1
Quadratic convergence for velocity error, linear convergence for pressure error, as expected.
131
9fieldstone 02: Stokes sphere
Viscosity and density directly computed at the quadrature points.
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions (free-slip)
•isothermal
•non-isoviscous
•buoyancy-driven flow
•Stokes sphere
132
10 fieldstone 03: Convection in a 2D box
This benchmark deals with the 2-D thermal convection of a fluid of infinite Prandtl number in a rect-
angular closed cell. In what follows, I carry out the case 1a, 1b, and 1c experiments as shown in [61]:
steady convection with constant viscosity in a square box.
The temperature is fixed to zero on top and to ∆Tat the bottom, with reflecting symmetry at the
sidewalls (i.e. ∂xT= 0) and there are no internal heat sources. Free-slip conditions are implemented on
all boundaries.
The Rayleigh number is given by
Ra =αgy∆T h3
κν =αgy∆T h3ρ2cp
kµ (313)
In what follows, I use the following parameter values: Lx=Ly= 1,ρ0=cP=k=µ= 1, T0= 0,
α= 10−2,g= 102Ra and I run the model with Ra = 104,105and 106.
The initial temperature field is given by
T(x, y) = (1 −y)−0.01 cos(πx) sin(πy) (314)
The perturbation in the initial temperature fields leads to a perturbation of the density field and sets the
fluid in motion.
Depending on the initial Rayleigh number, the system ultimately reaches a steady state after some
time.
The Nusselt number (i.e. the mean surface temperature gradient over mean bottom temperature) is
computed as follows [61]:
Nu =LyR∂T
∂y (y=Ly)dx
RT(y= 0)dx (315)
Note that in our case the denominator is equal to 1 since Lx= 1 and the temperature at the bottom is
prescribed to be 1.
Finally, the steady state root mean square velocity and Nusselt number measurements are indicated in
Table ?? alongside those of [61] and [502]. (Note that this benchmark was also carried out and published
in other publications [527, 7, 230, 151, 351] but since they did not provide a complete set of measurement
values, they are not included in the table.)
Blankenbach et al Tackley [502]
Ra = 104Vrms 42.864947 ±0.000020 42.775
Nu 4.884409 ±0.000010 4.878
Ra = 105Vrms 193.21454 ±0.00010 193.11
Nu 10.534095 ±0.000010 10.531
Ra = 106Vrms 833.98977 ±0.00020 833.55
Nu 21.972465 ±0.000020 21.998
Steady state Nusselt number N u and Vrms measurements as reported in the literature.
133
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions (free-slip)
•Boussinesq approximation
•direct solver
•non-isothermal
•buoyancy-driven flow
•isoviscous
•CFL-condition
134
ToDo:
implement steady state criterion
reach steady state
do Ra=1e4, 1e5, 1e6
plot against blankenbach paper and aspect
look at critical Ra number
135
11 fieldstone 04: The lid driven cavity
The lid driven cavity is a famous Computational Fluid Dynamics test case [321, 245, 419, 65, 83, 267, 483]
and has been studied in countless publications with a wealth of numerical techniques (see [179] for a
succinct review) and also in the laboratory [336].
It models a plane flow of an isothermal isoviscous fluid in a rectangular (usually square) lid-driven
cavity. The boundary conditions are indicated in the Fig. ??a. The gravity is set to zero.
11.1 the lid driven cavity problem (ldc=0)
In the standard case, the upper side of the cavity moves in its own plane at unit speed, while the other
sides are fixed. This thereby introduces a discontinuity in the boundary conditions at the two upper
corners of the cavity and yields an uncertainty as to which boundary (side or top) the corner points
belong to. In this version of the code the top corner nodes are considered to be part of the lid. If these
are excluded the recovered pressure showcases an extremely large checkboard pattern.
This benchmark is usually dicussed in the context of low to very high Reynolds number with the full
Navier-Stokes equations being solved (with the noticeable exception of [467, 468, 119, 168] which focus
on the Stokes equation). In the case of the incompressible Stokes flow, the absence of inertia renders this
problem instantaneous so that only one time step is needed.
11.2 the lid driven cavity problem - regularisation I (ldc=1)
We avoid the top corner nodes issue altogether by prescribing the horizontal velocity of the lid as follows:
u(x) = x2(1 −x)2.(316)
In this case the velocity and its first derivative is continuous at the corners. This is the so-called regularised
lid-driven cavity problem [425].
11.3 the lid driven cavity problem - regularisation II (ldc=2)
Another regularisation was presented in [154]. Also in Appendix D.4 of [311]. Here, a regularized lid
driven cavity is studied which is consistent in the sense that ∇·v= 0 holds also at the corners of the
domain. There are no-slip conditions at the boundaries x= 0, x= 1, and y= 0.
The velocity at y= 1 is given by
u(x)=1−1
41−cos(x1−x
x1
π)2
x∈[0, x1]
u(x)=1 x∈[x1,1−x1]
u(x)=1−1
41−cos(x−(1 −x1)
x1
π)2
x∈[1 −x1,1] (317)
Results are obtained with x1= 0.1.
features
•Q1×P0element
•incompressible flow
•penalty formulation
•isothermal
•isoviscous
136
A 100x100 element grid is used. No-slip boundary conditions are prescribed on sides and bottom. A
zero vertical velocity is prescribed at the top and the exact form of the prescribed horizontal velocity is
controlled by the ldc parameter.
-200
-150
-100
-50
0
50
100
150
200
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
pressure
x
ldc0
ldc1
ldc2
137
12 fieldstone 05: SolCx benchmark
The SolCx benchmark is intended to test the accuracy of the solution to a problem that has a large jump
in the viscosity along a line through the domain. Such situations are common in geophysics: for example,
the viscosity in a cold, subducting slab is much larger than in the surrounding, relatively hot mantle
material.
The SolCx benchmark computes the Stokes flow field of a fluid driven by spatial density variations,
subject to a spatially variable viscosity. Specifically, the domain is Ω = [0,1]2, gravity is g= (0,−1)T
and the density is given by
ρ(x, y) = sin(πy) cos(πx) (318)
Boundary conditions are free slip on all of the sides of the domain and the temperature plays no role in
this benchmark. The viscosity is prescribed as follows:
µ(x, y) = 1for x < 0.5
106for x > 0.5(319)
Note the strongly discontinuous viscosity field yields a stagnant flow in the right half of the domain and
thereby yields a pressure discontinuity along the interface.
The SolCx benchmark was previously used in [163] (references to earlier uses of the benchmark are
available there) and its analytic solution is given in [602]. It has been carried out in [339] and [234].
Note that the source code which evaluates the velocity and pressure fields for both SolCx and SolKz is
distributed as part of the open source package Underworld ([397], http://underworldproject.org).
In this particular example, the viscosity is computed analytically at the quadrature points (i.e. tracers
are not used to attribute a viscosity to the element). If the number of elements is even in any direction,
all elements (and their associated quadrature points) have a constant viscosity(1 or 106). If it is odd, then
the elements situated at the viscosity jump have half their integration points with µ= 1 and half with
µ= 106(which is a pathological case since the used quadrature rule inside elements cannot represent
accurately such a jump).
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions (free-slip)
•direct solver
•isothermal
•non-isoviscous
•analytical solution
138
What we learn from this
139
13 fieldstone 06: SolKz benchmark
The SolKz benchmark [454] is similar to the SolCx benchmark. but the viscosity is now a function of the
space coordinates:
µ(y) = exp(By) with B= 13.8155 (320)
It is however not a discontinuous function but grows exponentially with the vertical coordinate so that
its overall variation is again 106. The forcing is again chosen by imposing a spatially variable density
variation as follows:
ρ(x, y) = sin(2y) cos(3πx) (321)
Free slip boundary conditions are imposed on all sides of the domain. This benchmark is presented in
[602] as well and is studied in [163] and [234].
0.00000001
0.00000010
0.00000100
0.00001000
0.00010000
0.00100000
0.01000000
0.10000000
0.01 0.1
error
h
velocity
pressure
x2
x1
140
14 fieldstone 07: SolVi benchmark
Following SolCx and SolKz, the SolVi inclusion benchmark solves a problem with a discontinuous viscosity
field, but in this case the viscosity field is chosen in such a way that the discontinuity is along a circle.
Given the regular nature of the grid used by a majority of codes and the present one, this ensures that the
discontinuity in the viscosity never aligns to cell boundaries. This in turns leads to almost discontinuous
pressures along the interface which are difficult to represent accurately. [474] derived a simple analytic
solution for the pressure and velocity fields for a circular inclusion under simple shear and it was used in
[155], [500], [163], [339] and [234].
Because of the symmetry of the problem, we only have to solve over the top right quarter of the
domain (see Fig. ??a).
The analytical solution requires a strain rate boundary condition (e.g., pure shear) to be applied far
away from the inclusion. In order to avoid using very large domains and/or dealing with this type of
boundary condition altogether, the analytical solution is evaluated and imposed on the boundaries of
the domain. By doing so, the truncation error introduced while discretizing the strain rate boundary
condition is removed.
A characteristic of the analytic solution is that the pressure is zero inside the inclusion, while outside
it follows the relation
pm= 4˙µm(µi−µm)
µi+µm
r2
i
r2cos(2θ) (322)
where µi= 103is the viscosity of the inclusion and µm= 1 is the viscosity of the background media,
θ= tan−1(y/x), and ˙= 1 is the applied strain rate.
[155] thoroughly investigated this problem with various numerical methods (FEM, FDM), with and
without tracers, and conclusively showed how various averagings lead to different results. [163] obtained
a first order convergence for both pressure and velocity, while [339] and [234] showed that the use of
adaptive mesh refinement in respectively the FEM and FDM yields convergence rates which depend on
refinement strategies.
141
0.00000001
0.00000010
0.00000100
0.00001000
0.00010000
0.00100000
0.01000000
0.10000000
1.00000000
10.00000000
0.01 0.1
error
h
velocity
pressure
x2
x1
142
15 fieldstone 08: the indentor benchmark
The punch benchmark is one of the few boundary value problems involving plastic solids for which there
exists an exact solution. Such solutions are usually either for highly simplified geometries (spherical or
axial symmetry, for instance) or simplified material models (such as rigid plastic solids) [315].
In this experiment, a rigid punch indents a rigid plastic half space; the slip line field theory gives exact
solutions as shown in Fig. ??a. The plane strain formulation of the equations and the detailed solution
to the problem were derived in the Appendix of [520] and are also presented in [224].
The two dimensional punch problem has been extensively studied numerically for the past 40 years
[609, 608, 127, 126, 293, 590, 84, 451] and has been used to draw a parallel with the tectonics of eastern
China in the context of the India-Eurasia collision [508, 393]. It is also worth noting that it has been
carried out in one form or another in series of analogue modelling articles concerning the same region,
with a rigid indenter colliding with a rheologically stratified lithosphere [420, 152, 312].
Numerically, the one-time step punch experiment is performed on a two-dimensional domain of purely
plastic von Mises material. Given that the von Mises rheology yield criterion does not depend on pressure,
the density of the material and/or the gravity vector is set to zero. Sides are set to free slip boundary
conditions, the bottom to no slip, while a vertical velocity (0,−vp) is prescribed at the top boundary for
nodes whose xcoordinate is within [Lx/2−δ/2, Lx/2 + δ/2].
The following parameters are used: Lx= 1, Ly= 0.5, µmin = 10−3,µmax = 103,vp= 1, δ=
0.123456789 and the yield value of the material is set to k= 1.
The analytical solution predicts that the angle of the shear bands stemming from the sides of the
punch is π/4, that the pressure right under the punch is 1 + π, and that the velocity of the rigid blocks
on each side of the punch is vp/√2 (this is simply explained by invoking conservation of mass).
143
ToDo: smooth punch
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions (no-slip)
•isothermal
•non-isoviscous
•nonlinear rheology
144
16 fieldstone 09: the annulus benchmark
This fieldstone was developed in collaboration with Prof. E.G.P. Puckett.
This benchmark is based on Thieulot & Puckett [Subm.] in which an analytical solution to the
isoviscous incompressible Stokes equations is derived in an annulus geometry. The velocity and pressure
fields are as follows:
vr(r, θ) = g(r)ksin(kθ),(323)
vθ(r, θ) = f(r) cos(kθ),(324)
p(r, θ) = kh(r) sin(kθ),(325)
ρ(r, θ) = ℵ(r)ksin(kθ),(326)
with
f(r) = Ar +B/r, (327)
g(r) = A
2r+B
rln r+C
r,(328)
h(r) = 2g(r)−f(r)
r,(329)
ℵ(r) = g00 −g0
r−g
r2(k2−1) + f
r2+f0
r,(330)
A=−C2(ln R1−ln R2)
R2
2ln R1−R2
1ln R2
,(331)
B=−CR2
2−R2
1
R2
2ln R1−R2
1ln R2
.(332)
The parameters Aand Bare chosen so that vr(R1) = vr(R2) = 0, i.e. the velocity is tangential to
both inner and outer surfaces. The gravity vector is radial and of unit length. In the present case, we
set R1= 1, R2= 2 and C=−1.
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions
•direct solver
•isothermal
•isoviscous
•analytical solution
•annulus geometry
•elemental boundary conditions
145
0.0001
0.001
0.01
0.1
1
10
0.01
error
h
velocity
pressure
x2
x1
146
17 fieldstone 10: Stokes sphere (3D) - penalty
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions (free-slip)
•direct solver
•isothermal
•non-isoviscous
•3D
•elemental b.c.
•buoyancy driven
resolution is 24x24x24
147
19 fieldstone 12: consistent pressure recovery
What follows is presented in [607]. The second part of their paper wishes to establish a simple and
effective numerical method to calculate variables eliminated by the penalisation process. The method
involves an additional finite element solution for the nodal pressures using the same finite element basis
and numerical quadrature as used for the velocity.
Let us start with:
p=−λ∇·v
which lead to
(q, p) = −λ(q, ∇·v)
and then ZN N dΩ·P=−λZN∇NdΩ·V
or,
M·P=−D·V
and finally
P=−M−1·D·V
with Mof size (np ×np), Dof size (np ∗ndof ×np ∗ndof) and Vof size (np ∗ndof). The vector P
contains the np nodal pressure values directly, with no need for a smoothing scheme. The mass matrix
Mis to be evaluated at the full integration points, while the constraint part (the right hand side of the
equation) is to be evaluated at the reduced integration point.
As noted by [607], it is interesting to note that when linear elements are used and the lumped matrices
are used for the Mthe resulting algebraic equation is identical to the smoothing scheme based on the
averaging method only if the uniform square finite element mesh is used. In this respect this method is
expected to yield different results when elements are not square or even rectangular.
——-
q1is smoothed pressure obtained with the center-to-node approach.
q2is recovered pressure obtained with [607].
All three fulfill the zero average condition: RpdΩ = 0.
149
0.000001
0.000010
0.000100
0.001000
0.010000
0.100000
0.01 0.1
error
h
velocity
pressure (el)
pressure (q1)
pressure (q2)
x2
x1.5
x1
In terms of pressure error, q2is better than q1which is better than elemental.
QUESTION: why are the averages exactly zero ?!
TODO:
•add randomness to internal node positions.
•look at elefant algorithms
150
20 fieldstone 13: the Particle in Cell technique (1) - the effect
of averaging
This fieldstone is being developed in collaboration with BSc student Eric Hoogen.
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions (no-slip)
•isothermal
•non-isoviscous
•particle-in-cell
After the initial setup of the grid, markers can then be generated and placed in the domain. One
could simply randomly generate the marker positions in the whole domain but unless a very large number
of markers is used, the chance that an element does not contain any marker exists and this will prove
problematic. In order to get a better control over the markers spatial distribution, one usually generates
the marker per element, so that the total number of markers in the domain is the product of the number
of elements times the user-chosen initial number of markers per element.
Our next concern is how to actually place the markers inside an element. Two methods come to mind:
on a regular grid, or in a random manner, as shown on the following figure:
In both cases we make use of the basis shape functions: we generate the positions of the markers
(random or regular) in the reference element first (rim, sim), and then map those out to the real element
as follows:
xim =
m
X
i
Ni(rim, sim)xiyim =
m
X
i
Ni(rim, sim)yi(333)
where xi, yiare the coordinates of the vertices of the element.
A third option consists in the use of the so-called Poisson-disc sampling which produces points that
are tightly-packed, but no closer to each other than a specified minimum distance, resulting in a more
natural pattern 24. Note that the Poisson-disc algorithm fills the whole domain at once, not element after
element.
say smthg about avrg dist
insert here theory and link about Poisson disc
24https://en.wikipedia.org/wiki/Supersampling
151
Left: regular distribution, middle: random, right: Poisson disc.
16384 markers (32x32 grid, 16 markers per element).
When using active markers, one is faced with the problem of transferring the properties they carry to
the mesh on which the PDEs are to be solved. As we have seen, building the FE matrix involves a loop
over all elements, so one simple approach consists of assigning each element a single property computed as
the average of the values carried by the markers in that element. Often in colloquial language ”average”
refers to the arithmetic mean:
hφiam =1
n
n
X
k
φi(334)
where < φ >am is the arithmetic average of the nnumbers φi. However, in mathematics other means
are commonly used, such as the geometric mean:
hφigm = n
Y
i
φi!(335)
and the harmonic mean:
hφihm = 1
n
n
X
i
1
φi!−1
(336)
Furthermore, there is a well known inequality for any set of positive numbers,
hφiam ≥ hφigm ≥ hφihm (337)
which will prove to be important later on.
Let us now turn to a simple concrete example: the 2D Stokes sphere. There are two materials
in the domain, so that markers carry the label ”mat=1” or ”mat=2”. For each element an average
density and viscosity need to be computed. The majority of elements contains markers with a single
material label so that the choice of averaging does not matter (it is trivial to verify that if φi=φ0then
hφiam =hφigm =hφihm =φ0. Remain the elements crossed by the interface between the two materials:
they contain markers of both materials and the average density and viscosity inside those depends on 1)
the total number of markers inside the element, 2) the ratio of markers 1 to markers 2, 3) the type of
averaging.
This averaging problem has been studied and documented in the literature [473, 155, 515, 435]
Nodal projection. Left: all markers inside elements to which the green node belongs to are taken into account.
Right: only the markers closest to the green node count.
152
Let kbe the green node of the figures above. Let (r, s) denote the coordinates of a marker inside its
element. For clarity, we define the follow three nodal averaging schemes:
•nodal type A:
fk=sum of values carried by markers in 4 neighbour elements
number of markers in 4 neighbour elements
•nodal type B:
fk=sum of values carried by markers inside dashed line
number of markers in area delimited by the dashed line
•nodal type C
fk=sum of values carried by markers in 4 neighbour elements ∗Np(r, s)
sum of Np(r, s)
where Npis the Q1basis function corresponding to node pdefined on each element. Since these
functions are 1 on node kand then linearly decrease and become zero on the neighbouring nodes,
this effectively gives more weight to those markers closest to node k.
This strategy is adopted in [2, 388] (although it is used to interpolate onto the nodes of Q2P−1
elements. It is formulated as follows:
”We assume that an arbitrary material point property f, is discretized via f(x)'δ(x−xp)fp. We
then utilize an approximate local L2projection of fponto a continuous Q1finite element space.
The corner vertices of each Q2finite element define the mesh fpis projected onto. The local
reconstruction for a node i is defined by
ˆ
fi=RΩiNi(x)f(x)
RΩiNi(x)'PpNi(xp)fp
PpNi(xp)
where the summation over pincludes all material points contained within the support Ωiof the
trilinear interpolant Ni”.
The setup is identical to the Stokes sphere experiment. The bash script script runall runs the code
for many resolutions, both initial marker distribution and all four averaging types. The viscosity of the
sphere has been set to 103while the viscosity of the surrounding fluid is 1. The average density is always
computed with an arithmetic mean.
Conclusions:
•With increasing resolution (h→0) vrms values seem to converge towards a single value, irrespective
of the number of markers.
•At low resolution, say 32x32 (i.e. h=0.03125), vrms values for the three averagings differ by about
10%. At higher resolution, say 128x128, vrms values are still not converged.
•The number of markers per element plays a role at low resolution, but less and less with increasing
resolution.
•Results for random and regular marker distributions are not identical but follow a similar trend
and seem to converge to the same value.
•elemental values yield better results (espcecially at low resolutions)
•harmonic mean yields overal the best results
153
Root mean square velocity results are shown hereunder:
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
random markers, elemental proj
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
random PD markers, elemental proj
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
regular markers, elemental proj
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
random markers, nodal proj A
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
random PD markers, nodal proj A
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
regular markers, nodal proj A
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
random markers, nodal proj B
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
random markers, nodal proj B
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
regular markers, nodal proj B
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
random markers, nodal proj C
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
random markers, nodal proj C
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
regular markers, nodal proj C
am, 09 m
am, 16 m
am, 25 m
am, 36 m
am, 48 m
am, 64 m
gm, 09 m
gm, 16 m
gm, 25 m
gm, 36 m
gm, 48 m
gm, 64 m
hm, 09 m
hm, 16 m
hm, 25 m
hm, 36 m
hm, 48 m
hm, 64 m
Left column: random markers, middle column: Poisson disc, right column: regular markers. First row: elemental
projection, second row: nodal 1 projection, third row: nodal 2 projection, fourth row: nodal 3 projection.
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
64 markers per element, arithmetic avrg
reg, el
rand, el
pd, el
reg, nodA
rand, nodA
pd, nodA
reg, nodB
rand, nodB
pd, nodB
reg, nodC
rand, nodC
pd, nodC
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
64 markers per element, geometric avrg
reg, el
rand, el
pd, el
reg, nodA
rand, nodA
pd, nodA
reg, nodB
rand, nodB
pd, nodB
reg, nodC
rand, nodC
pd, nodC
0.001
0.002
0.003
0.004
0.005
0.006
0.007
0.008
0.009
0.01
0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
vrms
h
64 markers per element, harmonic avrg
reg, el
rand, el
pd, el
reg, nodA
rand, nodA
pd, nodA
reg, nodB
rand, nodB
pd, nodB
reg, nodC
rand, nodC
pd, nodC
Left to right: arithmetic, geometric, harmonic averaging for viscosity.
154
21 fieldstone f14: solving the full saddle point problem
The details of the numerical setup are presented in Section ??.
The main difference is that we no longer use the penalty formulation and therefore keep both velocity
and pressure as unknowns. Therefore we end up having to solve the following system:
K G
GT0·V
P=f
hor,A·X=rhs
Each block K,Gand vector f,hare built separately in the code and assembled into the matrix A
and vector rhs afterwards. Aand rhs are then passed to the solver. We will see later that there are
alternatives to solve this approach which do not require to build the full Stokes matrix A.
Each element has m= 4 vertices so in total ndofV ×m= 8 velocity dofs and a single pressure
dof, commonly situated in the center of the element. The total number of velocity dofs is therefore
NfemV =nnp ×ndofV while the total number of pressure dofs is NfemP =nel. The total number of
dofs is then Nfem =NfemV +N femP .
As a consequence, matrix Khas size N femV, N femV and matrix Ghas size N femV, NfemP . Vector
fis of size NfemV and vector his of size N femP .
features
•Q1×P0element
•incompressible flow
•mixed formulation
•Dirichlet boundary conditions (no-slip)
•direct solver (?)
•isothermal
•isoviscous
•analytical solution
•pressure smoothing
155
Unlike the results obtained with the penalty formulation (see Section ??), the pressure showcases a
very strong checkerboard pattern, similar to the one in [158].
Left: pressure solution as shown in [158]; Right: pressure solution obtained with fieldstone.
Rather interestingly, the nodal pressure (obtained with a simple center-to-node algorithm) fails to
recover a correct pressure at the four corners.
156
Note that the umfpack solver complains a lot about the matrix condition number, even at (very) low
resolutions. I believe it does not like the zeros on the (2,2) block of the assembled Stokes matrix.
157
22 fieldstone f15: saddle point problem with Schur comple-
ment approach - benchmark
The details of the numerical setup are presented in Section ??. The main difference resides in the Schur
complement approach to solve the Stokes system, as presented in Section ?? (see solver cg). This
iterative solver is very easy to implement once the blocks Kand G, as well as the rhs vectors fand h
have been built.
Rather interestingly the pressure checkerboard modes are not nearly as present as in Section ?? which
uses a full matrix approach.
Looking at the discretisation errors for velocity and pressure, we of course recover the same rates and
values as in the full matrix case.
158
0.000001
0.000010
0.000100
0.001000
0.010000
0.100000
0.01 0.1
error
h
velocity
pressure
x2
x1
Finally, for each experiment the normalised residual (see solver cg) was recorded. We see that all
things equal the resolution has a strong influence on the number of iterations the solver must perform to
reach the required tolerance. This is one of the manifestations of the fact that the Q1×P0element is
not a stable element: the condition number of the matrix increases with resolution. We will see that this
is not the case of stable elements such as Q2×Q1.
0.000000001
0.000000010
0.000000100
0.000001000
0.000010000
0.000100000
0.001000000
0.010000000
0.100000000
1.000000000
0 10 20 30 40 50 60 70 80 90 100
normalised residual
# iteration
8x8
12x12
16x16
24x24
32x32
48x48
64x64
128x128
1e-8
159
features
•Q1×P0element
•incompressible flow
•mixed formulation
•Schur complement approach
•isothermal
•isoviscous
•analytical solution
build S and have python compute its smallest and largest eigenvalues as a function of resolution?
160
23 fieldstone f16: saddle point problem with Schur comple-
ment approach - Stokes sphere
We are revisiting the 2D Stokes sphere problem, but this time we use the Schur complement approach
to solve the Stokes system, Because there are viscosity contrasts in the domain, it is advisable to use the
Preconditioned Conjugate Gradient as presented in Section ?? (see solver pcg).
The normalised residual (see solver pcg) was recorded. We see that all things equal the resolution
has a strong influence on the number of iterations the solver must perform to reach the required tolerance.
However, we see that the use of the preconditioner can substantially reduce the number of iterations inside
the Stokes solver. At resolution 128x128, this number is halved.
161
0.000000001
0.000000010
0.000000100
0.000001000
0.000010000
0.000100000
0.001000000
0.010000000
0.100000000
1.000000000
0 50 100 150 200 250 300 350 400
normalised residual
# iteration
32x32 (prec.)
32x32 (no prec.)
64x64 (prec.)
64x64 (no prec.)
128x128 (prec.)
128x128 (no prec.)
1e-8
features
•Q1×P0element
•incompressible flow
•mixed formulation
•Schur complement approach
•isothermal
•non-isoviscous
•Stokes sphere
162
24 fieldstone 17: solving the full saddle point problem in 3D
When using Q1×P0elements, this benchmark fails because of the Dirichlet b.c. on all 6 sides and all
three components. However, as we will see, it does work well with Q2×Q1elements. .
This benchmark begins by postulating a polynomial solution to the 3D Stokes equation [157]:
v=
x+x2+xy +x3y
y+xy +y2+x2y2
−2z−3xz −3yz −5x2yz
(338)
and
p=xyz +x3y3z−5/32 (339)
While it is then trivial to verify that this velocity field is divergence-free, the corresponding body force
of the Stokes equation can be computed by inserting this solution into the momentum equation with a
given viscosity µ(constant or position/velocity/strain rate dependent). The domain is a unit cube and
velocity boundary conditions simply use Eq. (340). Following [107], the viscosity is given by the smoothly
varying function
µ= exp(1 −β(x(1 −x) + y(1 −y) + z(1 −z))) (340)
One can easily show that the ratio of viscosities µ?in the system follows µ?= exp(−3β/4) so that
choosing β= 10 yields µ?'1808 and β= 20 yields µ?'3.269 ×106.
We start from the momentum conservation equation:
−∇p+∇·(2µ˙
) = f
The x-component of this equation writes
fx=−∂p
∂x +∂
∂x (2µ˙xx) + ∂
∂y (2µ˙xy) + ∂
∂z (2µ˙xz) (341)
=−∂p
∂x + 2µ∂
∂x ˙xx + 2µ∂
∂y ˙xy + 2µ∂
∂z ˙xz + 2∂µ
∂x ˙xx + 2∂µ
∂y ˙xy + 2∂µ
∂z ˙xz (342)
Let us compute all the block separately:
˙xx = 1 + 2x+y+ 3x2y
˙yy = 1 + x+ 2y+ 2x2y
˙zz =−2−3x−3y−5x2y
2˙xy = (x+x3)+(y+ 2xy2) = x+y+ 2xy2+x3
2˙xz = (0) + (−3z−10xyz) = −3z−10xyz
2˙yz = (0) + (−3z−5x2z) = −3z−5x2z
163
In passing, one can verify that ˙xx + ˙yy + ˙zz = 0. We further have
∂
∂x 2 ˙xx = 2(2 + 6xy)
∂
∂y 2 ˙xy = 1 + 4xy
∂
∂z 2 ˙xz =−3−10xy
∂
∂x 2 ˙xy = 1 + 2y2+ 3x2
∂
∂y 2 ˙yy = 2(2 + 2x2)
∂
∂z 2 ˙yz =−3−5x2
∂
∂x 2 ˙xz =−10yz
∂
∂y 2 ˙yz = 0
∂
∂z 2 ˙zz = 2(0)
∂p
∂x =yz + 3x2y3z(343)
∂p
∂y =xz + 3x3y2z(344)
∂p
∂z =xy +x3y3(345)
Pressure normalisation Here again, because Dirichlet boundary conditions are prescribed on all
sides the pressure is known up to an arbitrary constant. This constant can be determined by (arbitrarily)
choosing to normalised the pressure field as follows:
ZΩ
p dΩ = 0 (346)
This is a single constraint associated to a single Lagrange multiplier λand the global Stokes system takes
the form
K G 0
GT0C
0CT0
V
P
λ
In this particular case the constraint matrix Cis a vector and it only acts on the pressure degrees of
freedom because of Eq.(348). Its exact expression is as follows:
ZΩ
p dΩ = X
eZΩe
p dΩ = X
eZΩeX
i
Np
ipidΩ = X
eX
iZΩe
Np
idΩpi=X
eCe·pe
where peis the list of pressure dofs of element e. The elemental constraint vector contains the correspond-
ing pressure basis functions integrated over the element. These elemental constraints are then assembled
into the vector C.
164
24.0.1 Constant viscosity
Choosing β= 0 yields a constant velocity µ(x, y, z) = exp(1) '2.718 (and greatly simplifies the right-
hand side) so that
∂
∂x µ(x, y, z) = 0 (347)
∂
∂y µ(x, y, z) = 0 (348)
∂
∂z µ(x, y, z) = 0 (349)
and
fx=−∂p
∂x + 2µ∂
∂x ˙xx + 2µ∂
∂y ˙xy + 2µ∂
∂z ˙xz
=−(yz + 3x2y3z) + 2(2 + 6xy) + (1 + 4xy)+(−3−10xy)
=−(yz + 3x2y3z) + µ(2 + 6xy)
fy=−∂p
∂y + 2µ∂
∂x ˙xy + 2µ∂
∂y ˙yy + 2µ∂
∂z ˙yz
=−(xz + 3x3y2z) + µ(1 + 2y2+ 3x2) + µ2(2 + 2x2) + µ(−3−5x2)
=−(xz + 3x3y2z) + µ(2 + 2x2+ 2y2)
fz=−∂p
∂z + 2µ∂
∂x ˙xz + 2µ∂
∂y ˙yz + 2µ∂
∂z ˙zz
=−(xy +x3y3) + µ(−10yz)+0+0
=−(xy +x3y3) + µ(−10yz)
Finally
f=−
yz + 3x2y3z
xz + 3x3y2z
xy +x3y3
+µ
2+6xy
2+2x2+ 2y2
−10yz
Note that there seems to be a sign problem with Eq.(26) in [107].
165
0.00001
0.00010
0.00100
0.01000
0.1
error
h
velocity
pressure
x3
x2
24.0.2 Variable viscosity
The spatial derivatives of the viscosity are then given by
∂
∂x µ(x, y, z) = −(1 −2x)βµ(x, y, z)
∂
∂y µ(x, y, z) = −(1 −2y)βµ(x, y, z)
∂
∂z µ(x, y, z) = −(1 −2z)βµ(x, y, z)
166
and thr right-hand side by
f=−
yz + 3x2y3z
xz + 3x3y2z
xy +x3y3
+µ
2+6xy
2+2x2+ 2y2
−10yz
(350)
−(1 −2x)βµ(x, y, z)
2˙xx
2˙xy
2˙xz
−(1 −2y)βµ(x, y, z)
2˙xy
2˙yy
2˙yz
−(1 −2z)βµ(x, y, z)
2˙xz
2˙yz
2˙zz
=−
yz + 3x2y3z
xz + 3x3y2z
xy +x3y3
+µ
2+6xy
2+2x2+ 2y2
−10yz
−(1 −2x)βµ
2+4x+ 2y+ 6x2y
x+y+ 2xy2+x3
−3z−10xyz
−(1 −2y)βµ
x+y+ 2xy2+x3
2+2x+ 4y+ 4x2y
−3z−5x2z
−(1 −2z)βµ
−3z−10xyz
−3z−5x2z
−4−6x−6y−10x2y
Note that at (x, y, z) = (0,0,0), µ= exp(1), and at (x, y, z) = (0.5,0.5,0.5), µ= exp(1 −3β/4) so
that the maximum viscosity ratio is given by
µ?=exp(1 −3β/4)
exp(1) = exp(−3β/4)
By varying βbetween 1 and 22 we can get up to 7 orders of magnitude viscosity difference.
features
•Q1×P0element
•incompressible flow
•saddle point system
•Dirichlet boundary conditions (free-slip)
•direct solver
•isothermal
•non-isoviscous
•3D
•elemental b.c.
•analytical solution
167
25 fieldstone 18: solving the full saddle point problem with
Q2×Q1elements
The details of the numerical setup are presented in Section ??.
Each element has mV= 9 vertices so in total ndofV×mV= 18 velocity dofs and ndofP∗mP= 4
pressure dofs. The total number of velocity dofs is therefore Nf emV =nnp ×ndofV while the total
number of pressure dofs is N femP =nel. The total number of dofs is then Nfem =N f emV +N femP .
As a consequence, matrix Khas size N femV, N femV and matrix Ghas size N femV, NfemP . Vector
fis of size NfemV and vector his of size N femP .
renumber all nodes to start at zero!! Also internal numbering does not work here
features
•Q2×Q1element
•incompressible flow
•mixed formulation
•Dirichlet boundary conditions (no-slip)
•isothermal
•isoviscous
•analytical solution
168
0.0000001
0.0000010
0.0000100
0.0001000
0.0010000
0.0100000
0.1
error
h
velocity
pressure
x3
x2
169
26 fieldstone 19: solving the full saddle point problem with
Q3×Q2elements
The details of the numerical setup are presented in Section ??.
Each element has mV= 16 vertices so in total ndofV×mV= 32 velocity dofs and ndofP∗mP= 9
pressure dofs. The total number of velocity dofs is therefore Nf emV =nnp ×ndofV while the total
number of pressure dofs is N femP =nel. The total number of dofs is then Nfem =N f emV +N femP .
As a consequence, matrix Khas size N femV, N femV and matrix Ghas size N femV, NfemP . Vector
fis of size NfemV and vector his of size N femP .
60===61===62===63===64===65===66===67===68===70
|| || || ||
50 51 52 53 54 55 56 57 58 59
|| || || ||
40 41 42 43 44 45 46 47 48 49
|| || || ||
30===31===32===33===34===35===36===37===38===39
|| || || ||
20 21 22 23 24 25 26 27 28 29
|| || || ||
10 11 12 13 14 15 16 17 18 19
|| || || ||
00===01===02===03===04===05===06===07===08===09
Example of 3x2 mesh. nnx=10, nny=7, nnp=70, nelx=3, nely=2, nel=6
12===13===14===15 06=====07=====08
|| || || || || || ||
08===09===10===11 || || ||
|| || || || 03=====04=====05
04===05===06===07 || || ||
|| || || || || || ||
00===01===02===03 00=====01=====02
Velocity (Q3) Pressure (Q2)
(r,s)_{00}=(-1,-1) (r,s)_{00}=(-1,-1)
(r,s)_{01}=(-1/3,-1) (r,s)_{01}=(0,-1)
(r,s)_{02}=(+1/3,-1) (r,s)_{02}=(+1,-1)
(r,s)_{03}=(+1,-1) (r,s)_{03}=(-1,0)
(r,s)_{04}=(-1,-1/3) (r,s)_{04}=(0,0)
(r,s)_{05}=(-1/3,-1/3) (r,s)_{05}=(+1,0)
(r,s)_{06}=(+1/3,-1/3) (r,s)_{06}=(-1,+1)
(r,s)_{07}=(+1,-1/3) (r,s)_{07}=(0,+1)
(r,s)_{08}=(-1,+1/3) (r,s)_{08}=(+1,+1)
(r,s)_{09}=(-1/3,+1/3)
(r,s)_{10}=(+1/3,+1/3)
(r,s)_{11}=(+1,+1/3)
(r,s)_{12}=(-1,+1)
(r,s)_{13}=(-1/3,+1)
(r,s)_{14}=(+1/3,+1)
(r,s)_{15}=(+1,+1)
Write about 4 point quadrature.
170
features
•Q3×Q2element
•incompressible flow
•mixed formulation
•isothermal
•isoviscous
•analytical solution
1x10-10
1x10-9
1x10-8
1x10-7
1x10-6
1x10-5
0.0001
0.1
error
h
velocity
pressure
x4
x3
velocity error rate is cubic, pressure superconvergent since the pressure field is quadratic and therefore
lies into the Q2 space.
171
27 fieldstone 20: the Busse benchmark
This three-dimensional benchmark was first proposed by [108]. It has been subsequently presented in
[502, 527, 7, 414, 151, 339]. We here focus on Case 1 of [108]: an isoviscous bimodal convection experiment
at Ra = 3 ×105.
The domain is of size a×b×hwith a= 1.0079h,b= 0.6283hwith h= 2700km. It is filled
with a Newtonian fluid characterised by ρ0= 3300kg.m−3,α= 10−5K−1,µ= 8.0198 ×1023Pa.s,
k= 3.564W.m−1.K−1,cp= 1080J.K−1.kg−1. The gravity vector is set to g= (0,0,−10)T. The
temperature is imposed at the bottom (T= 3700◦C) and at the top (T= 0◦C).
The various measurements presented in [108] are listed hereafter:
•The Nusselt number N u computed at the top surface following Eq. (317):
Nu =LzRRz=Lz
∂T
∂y dxdy
RRz=0 T dxdy
•the root mean square velocity vrms and the temperature mean square velocity Trms
•The vertical velocity wand temperature Tat points x1= (0,0, Lz/2), x2= (Lx,0, Lz/2), x3=
(0, Ly, Lz/2) and x4= (Lx, Ly, Lz/2);
•the vertical component of the heat flux Qat the top surface at all four corners.
The values plotted hereunder are adimensionalised by means of a reference temperature (3700K), a
reference lengthscale 2700km, and a reference time L2
z/κ.
0.0001
0.0002
0.0003
0.0004
0.0005
0.0006
0.0007
0.0008
0.0009
0 2x108 4x108 6x108 8x108 1x109 1.2x109
1.4x109
1.6x109
vrms
time/year
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
0 2x108 4x108 6x108 8x108 1x109 1.2x109
1.4x109
1.6x109
<T>
time/year
172
-0.002
-0.0015
-0.001
-0.0005
0
0.0005
0.001
0.0015
0.002
0 2x108 4x108 6x108 8x108 1x109 1.2x109
1.4x109
1.6x109
w at Lz/2
time/year
-3.5
-3
-2.5
-2
-1.5
-1
-0.5
0
1x108 1.5x108 2x108 2.5x108 3x108 3.5x108
heat flux
time/year
features
•Q1×P0element
•incompressible flow
•mixed formulation
•Dirichlet boundary conditions (free-slip)
•direct solver
•isothermal
•non-isoviscous
•3D
•elemental b.c.
•buoyancy driven
ToDo: look at energy conservation. run to steady state and make sure the expected values are
retrieved.
173
28 fieldstone 21: The non-conforming Q1×P0element
features
•Non-conforming Q1×P0element
•incompressible flow
•mixed formulation
•isothermal
•non-isoviscous
•analytical solution
•pressure smoothing
try Q1 mapping instead of isoparametric.
174
29 fieldstone 22: The stabilised Q1×Q1element
The details of the numerical setup are presented in Section 7.4.
We wish to use Q1×Q1element, which, unless stabilised, violates the LBB stability condition and
therefore is unusable. Stabilisation can be of two types: least-squares [158, 513, 323, 272], or by means of
an additional term in the weak form as first introduced in [157, 62], which is appealing since there is no
explicit satabilisation parameter. It is further analysed in [411, 354, 291, 475, 265]. Note that an equal-
order velocity-pressure formulation that does not exhibit spurious pressure modes (without stabilisaion)
has been presented in [455].
This element corresponds to bilinear velocities, bilinear pressure (equal order interpolation for both
velocity and pressure) which is very convenient in terms of data structures since all dofs are colocated.
In geodynamics, it is used in the Rhea code [494, 107] and in Gale [21]. It is also used in [351] in its
stabilised form, in conjunction with AMR. This element is quickly discussed at page 217 of Volker John’s
book [311].
The stabilisation term Centers the Stokes matrix in the (2,2) position:
K G
GT−C·V
P=f
h
The purpose of the Cterm is to stabilise the linear system. It is given by:
C(p, q) = X
eZΩe
1
η(p−Πp)(q−Πq)dΩ
where Π is the L2-projection onto the space of element-wise constant functions:
Πp=1
|Ωe|ZΩe
pdΩ
Because of the stabilisation matrix C, the numerical solution satisfies the incompressibility condition
only approximately. Local mesh refinement helps to control these unwanted effects [106, 107]. Since K
and Care symmetric matrices, the Stokes system is then an indefinite symmetric system. The Schur
complement matrix Sis then given by
S=GT·K−1·G+C
One can further expand the above expression for the Cterm:
C(p, q) = X
eZΩe
1
η(p−Πp)(q−Πq)dΩ
=X
eZΩe
1
η[pq −(Πp)q−(Πq)p+ (Πp)(Πq)]dΩ
=X
e
1
ηeZΩe
pqdΩ−ZΩe
(Πp)qdΩ−ZΩe
(Πq)pdΩ + ZΩe
(Πp)(Πq)dΩ
=X
e
1
ηeZΩe
pqdΩ−(Πp)ZΩe
qdΩ−(Πq)ZΩe
pdΩ + (Πp)(Πq)ZΩe
dΩ
=X
e
1
ηeZΩe
pqdΩ−(Πp)|Ωe|(Πq)−(Πq)|Ωe|(Πp) + (Πp)(Πq)|Ωe|
=X
e
1
ηeZΩe
pqdΩ− |Ωe|(Πp)(Πq)(351)
where we have used the fact that on each element Πphis constant. The left term will obviously yield a
Q1mass matrix (scaled by the elemental viscosities). Note that this approach is not used in practice as
we’ll see hereafter.
175
The pressure inside an element is given by
ph(x) = X
k
Np
k(x)pk
so that
Πph=1
|Ωe|ZΩeX
k
Np
kpkdΩ = X
k
1
|Ωe|ZΩe
Np
kdΩ
| {z }
˜
Np
k
pk(352)
and then
ph−Πph=X
k
Np
k(x)pk−X
k
˜
Np
kpk=X
k
(Np
k(x)−˜
Np
k)pk
The algorithm is straighforward and as follows: In the loop over elements, a) Compute the average of
each shape function Np
k(x) over the element; b) Substract this average to the shape function; c) Build
mass matrix with modified/offset shape functions (taking in account the viscosity).
In the case of rectangular elements of size (hx, hy), ˜
Np
ksimplifies even more:
˜
Np
k=1
|Ωe|ZΩe
Np
k(x)dΩ = 1
hxhy
hxhy
4Z+1
−1Z+1
−1
Np
k(r, s)drds =1
4Z+1
−1Z+1
−1
Np
k(r, s)drds (353)
It is easy to show that the average of the Q1shape functions of over the reference element is 1, so that
˜
Np
k= 1/4. This explains why in the code we have:
Navrg = np . z e r os (m, dtype=np . f l o a t 6 4 )
Navrg [ 0 ] = 0 . 2 5
Navrg [ 1 ] = 0 . 2 5
Navrg [ 2 ] = 0 . 2 5
Navrg [ 3 ] = 0 . 2 5
This also means that Πph= (p1+p2+p3+p4)/4, i.e. the projected pressure is the mean of the vertex
values. It follows, as shown on p.244 of [174] that the elemental Cmatrix is (omitting the viscosity term)
Cel =Mel −qTq|Ωe|q =1
4,1
4,1
4,1
4
The nullspace of Cconsists of constant vectors, i.e.
1∈null(C) which means that the assembled stabili-
sation operator is consistent.
The elemental Cel matrix is then computed like a mass matrix, although with modified shape function
vectors. Inside the loop over quadrature points, we do:
Nvect [ 0 , 0 :m]=N[ 0 :m]−Navrg [ 0 :m]
C e l+=Nvect .T. dot ( Nvect ) ∗j c o b ∗w eigh tq / v i s c o s i t y ( xq , yq , c as e )
It is then assembled inside the big FEM matrix
f o r k1 in range ( 0 ,m) :
f o r k2 in range ( 0 ,m) :
C mat [ i c o n [ k1 , i e l ] , i c o n [ k2 , i e l ]]+= C e l [ k1 , k2 ]
Non-zero pattern of the Gmatrix: Let us take a simple example: a 3x2 element grid.
012
345
0123
4567
8 9 10 11
0,1 2,3 4,5 6,7
8,9 10,11 12,13 14,15
16,17 18,19 20,21 22,23
176
The Kmatrix is of size NfemV ×Nf emV with N femV =ndofV ×nnp = 2 ×12 = 24. The G
matrix is of size NfemV ×NfemP with N f emP =ndofP ×nnp = 1 ×12 = 12. The Cmatrix is of
size NfemP ×Nf emP .
A corner pdof sees 4 vdofs, a side pdof sees 12 vdofs and an inside pdof sees 18 vdofs, so that the
total number of nonzeros in Gcan be computed as follows:
NZG= 4
|{z}
corners
+ 2(nnx −2) ∗12
| {z }
2hor.sides
+ 2(nny −2) ∗12
| {z }
2vert.sides
+ (nnx −2)(nny −2) ∗18
| {z }
insidenodes
Concretely,
•pdof #0 sees vdofs 0,1,2,3,8,9,10,11
•pdof #1 sees vdofs 0,1,2,3,4,5,8,9,10,11,12,13
•pdof #5 sees vdofs 0,1,2,3,4,5,8,9,10,11,12,13,16,17,18,19,20,21
so that the GTmatrix non-zero structure then is as follows:
0
1
2
3
4
5
6
7
8
9
10
11
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
Non-zero pattern of the Cmatrix: Let us take a simple example: a 3x2 element grid.
finish structure of C matrix for q1q1
We impose RpdV = 0 which means that the following constraint is added to the Stokes matrix:
K G 0
GTC L
0LT0
·
V
P
λ
=
f
h
0
29.1 The Donea & Huerta benchmark
As in [158] we solve the benchmark problem presented in section 7.4.1.
177
0.00001
0.00010
0.00100
0.01000
0.10000
0.1
error
h
velocity
pressure
x2
x1.5
29.2 The Dohrmann & Bochev benchmark
As in [157] we solve the benchmark problem presented in section 7.4.2.
0.00001
0.00010
0.00100
0.01000
0.10000
1.00000
0.1
error
h
velocity
pressure
x2
x1
compare my rates with original paper!
29.3 The falling block experiment
The setup is desscribed in [519].
1x1017
1x1018
1x1019
1x1020
1x1021
0.0001 0.01 1 100 10000 1x106
|vz| η1/δρ
η2/η1
178
30 fieldstone 23: compressible flow (1) - analytical benchmark
This work is part of the MSc thesis of T. Weir (2018).
We first start with an isothermal Stokes flow, so that we disregard the heat transport equation and
the equations we wish to solve are simply:
−∇ · 2η˙ε(v)−1
3(∇ · v)1+∇p=ρgin Ω,(354)
∇ · (ρv) = 0 in Ω (355)
The second equation can be rewritten ∇ · (ρv) = ρ∇ · v+v·∇ρ= 0 or,
∇ · v+1
ρv·∇ρ= 0
Note that this presupposes that the density is not zero anywhere in the domain.
We use a mixed formulation and therefore keep both velocity and pressure as unknowns. We end up
having to solve the following system:
K G
GT+Z0·V
P=f
hor,A·X=rhs
Where Kis the stiffness matrix, Gis the discrete gradient operator, GTis the discrete divergence operator,
Vthe velocity vector, Pthe pressure vector. Note that the term ZVderives from term v·∇ρin the
continuity equation.
Each block K,G,Zand vectors fand hare built separately in the code and assembled into the
matrix Aand vector rhs afterwards. Aand rhs are then passed to the solver. We will see later that
there are alternatives to solve this approach which do not require to build the full Stokes matrix A.
Remark: the term ZVis often put in the rhs (i.e. added to h) so that the matrix Aretains the same
structure as in the incompressible case. This is indeed how it is implemented in ASPECT. This however
requires more work since the rhs depends on the solution and some form of iterations is needed.
In the case of a compressible flow the strain rate tensor and the deviatoric strain rate tensor are no
more equal (since ∇·v6= 0). The deviatoric strainrate tensor is given by25
˙
d(v) = ˙
(v)−1
3T r(˙
)1=˙
(v)−1
3(∇·v)1
In that case:
˙d
xx =∂u
∂x −1
3∂u
∂x +∂v
∂y =2
3
∂u
∂x −1
3
∂v
∂y (356)
˙d
yy =∂v
∂y −1
3∂u
∂x +∂v
∂y =−1
3
∂u
∂x +2
3
∂v
∂y (357)
2˙d
xy =∂u
∂y +∂v
∂x (358)
and then
˙
d(v) =
2
3
∂u
∂x −1
3
∂v
∂y
1
2
∂u
∂y +1
2
∂v
∂x
1
2
∂u
∂y +1
2
∂v
∂x −1
3
∂u
∂x +2
3
∂v
∂y
From τ = 2ηdwe arrive at:
τxx
τyy
τxy
= 2η
˙d
xx
˙d
yy
˙d
xy
= 2η
2/3−1/3 0
−1/3 2/3 0
0 0 1/2
·
∂u
∂x
∂v
∂y
∂u
∂y +∂v
∂x
=η
4/3−2/3 0
−2/3 4/3 0
0 0 1
·
∂u
∂x
∂v
∂y
∂u
∂y +∂v
∂x
or,
τ =CηBV
25See the ASPECT manual for a justification of the 3 value in the denominator in 2D and 3D.
179
In order to test our implementation we have created a few manufactured solutions:
•benchmark #1 (ibench=1)): Starting from a density profile of:
ρ(x, y) = xy (359)
We derive a velocity given by:
vx(x, y) = Cx
x, vy(x, y) = Cy
y(360)
With gx(x, y) = 1
xand gy(x, y) = 1
y, this leads us to a pressure profile:
p=−η4Cx
3x2+4Cy
3y2+xy +C0(361)
This gives us a strain rate:
˙xx =−Cx
x2˙yy =−Cy
y2˙xy = 0
In what follows, we choose η= 1 and Cx=Cy= 1 and for a unit square domain [1 : 2] ×[1 : 2] we
compute C0so that the pressure is normalised to zero over the whole domain and obtain C0=−1.
•benchmark #2 (ibench=2): Starting from a density profile of:
ρ= cos(x) cos(y) (362)
We derive a velocity given by:
vx=Cx
cos(x), vy=Cy
cos(y)(363)
With gx=1
cos(y)and gy=1
cos(x), this leads us to a pressure profile:
p=η 4Cxsin(x)
3 cos2(x)+4Cysin(y)
3 cos2(y)!+ (sin(x) + sin(y)) + C0(364)
˙xx =Cx
sin(x)
cos2(x)˙yy =Cy
sin(y)
cos2(y)˙xy = 0
We choose η= 1 and Cx=Cy= 1. The domain is the unit square [0 : 1] ×[0 : 1] and we obtain C0
as before and obtain
C0= 2 −2 cos(1) + 8/3( 1
cos(1) −1) '3.18823730
(thank you WolframAlpha)
•benchmark #3 (ibench=3)
•benchmark #4 (ibench=4)
•benchmark #5 (ibench=5)
features
•Q1×P0element
•incompressible flow
•mixed formulation
•Dirichlet boundary conditions (no-slip)
•isothermal
•isoviscous
•analytical solution
•pressure smoothing
180
ToDo:
•pbs with odd vs even number of elements
•q is ’fine’ everywhere except in the corners - revisit pressure smoothing paper?
•redo A v d Berg benchmark (see Tom Weir thesis)
181
31 fieldstone 24: compressible flow (2) - convection box
This work is part of the MSc thesis of T. Weir (2018).
31.1 The physics
Let us start with some thermodynamics. Every material has an equation of state. The equilibrium
thermodynamic state of any material can be constrained if any two state variables are specified. Examples
of state variables include the pressure pand specific volume ν= 1/ρ, as well as the temperature T.
After linearisation, the density depends on temperature and pressure as follows:
ρ(T, p) = ρ0((1 −α(T−T0) + βTp)
where αis the coefficient of thermal expansion, also called thermal expansivity:
α=−1
ρ∂ρ
∂T p
αis the percentage increase in volume of a material per degree of temperature increase; the subscript p
means that the pressure is held fixed.
βTis the isothermal compressibility of the fluid, which is given by
βT=1
K=1
ρ∂ρ
∂P T
with Kthe bulk modulus. Values of βT= 10−12 −10−11 Pa−1are reasonable for Earth’s mantle, with
values decreasing by about a factor of 5 between the shallow lithosphere and core-mantle boundary. This
is the percentage increase in density per unit change in pressure at constant temperature. Both the
coefficient of thermal expansion and the isothermal compressibility can be obtained from the equation of
state.
The full set of equations we wish to solve is given by
−∇ · 2η˙
d(v)+∇p=ρ0((1 −α(T−T0) + βTp)gin Ω (365)
∇ · v+1
ρv·∇ρ= 0 in Ω (366)
ρCp∂T
∂t +v· ∇T−∇·k∇T=ρH + 2η˙
d:˙
d+αT ∂p
∂t +v· ∇pin Ω,(367)
Note that this presupposes that the density is not zero anywhere in the domain.
31.2 The numerics
We use a mixed formulation and therefore keep both velocity and pressure as unknowns. We end up
having to solve the following system:
K G +W
GT+Z0·V
P=f
hor,A·X=rhs
Where Kis the stiffness matrix, Gis the discrete gradient operator, GTis the discrete divergence operator,
Vthe velocity vector, Pthe pressure vector. Note that the term ZVderives from term v·∇ρin the
continuity equation.
As perfectly explained in the step 32 of deal.ii26, we need to scale the Gterm since it is many orders
of magnitude smaller than K, which introduces large inaccuracies in the solving process to the point that
the solution is nonsensical. This scaling coefficient is η/L. After building the Gblock, it is then scaled
as follows: G0=η
LGso that we now solve
26https://www.dealii.org/9.0.0/doxygen/deal.II/step 32.html
182
K G0+W
G0T+Z0·V
P0=f
h
After the solve phase, we recover the real pressure with P=η
LP0.
adapt notes since I should scale Wand Ztoo.hshould be caled too !!!!!!!!!!!!!!!
Each block K,G,Zand vectors fand hare built separately in the code and assembled into the
matrix Aand vector rhs afterwards. Aand rhs are then passed to the solver. We will see later that
there are alternatives to solve this approach which do not require to build the full Stokes matrix A.
Remark 1: the terms ZVand WPare often put in the rhs (i.e. added to h) so that the matrix
Aretains the same structure as in the incompressible case. This is indeed how it is implemented in
ASPECT, see also appendix A of [350]. This however requires more work since the rhs depends on the
solution and some form of iterations is needed.
Remark 2: Very often the adiabatic heating term αT (v· ∇p) is simplified as follows: If you assume
the vertical component of the gradient of the dynamic pressure to be small compared to the gradient of
the total pressure (in other words, the gradient is dominated by the gradient of the hydrostatic pressure),
then −ρg'∇pand then αT (v· ∇p)' −αρT v·g. We will however not be using this approximation in
what follows.
We have already established that
τ =CηBV
The following measurements are carried out:
•The root mean square velocity (vrms):
vrms =s1
VZV
v2dV
•The average temperature (Tavrg):
< T >=1
VZV
T dV
•The total mass (mass):
M=ZV
ρdV
•The Nusselt number (Nu):
Nu =−1
Lx
1
∆TZLx
0
∂T (x, y =Ly)
∂y dx
•The kinetic energy (EK):
EK=ZV
1
2ρv2dV
•The work done against gravity
< W >=−ZV
ρgyvydV
•The total viscous dissipation (visc diss)
<Φ>=ZΦdV =1
VZ2η˙
ε:˙
εdV
•The gravitational potential energy (EG)
EG=ZV
ρgy(Ly−y)dV
183
•The internal thermal energy (ET)
ET=ZV
ρ(0)CpT dV
Remark 3: Measuring the total mass can be misleading: indeed because ρ=ρ0(1 −αT ), then
measuring the total mass amounts to measuring a constant minus the volume-integrated tempera-
ture, and there is no reason why the latter should be zero, so that there is no reason why the total
mass should be zero...!
31.3 The experimental setup
The setup is as follows: the domain is Lx =Ly = 3000km. Free slip boundary conditions are imposed
on all four sides. The initial temperature is given by:
T(x, y) = Ly−y
Ly −0.01 cos(πx
Lx
) sin( πy
Ly )∆T+Tsurf
with ∆T= 4000K, Tsurf =T0= 273.15K. The temperature is set to ∆T+Tsurf at the bottom and
Tsurf at the top. We also set k= 3, Cp= 1250, |g|= 10, ρ0= 3000 and we keep the Rayleigh number
Ra and dissipation number Di as input parameters:
Ra =αg∆T L3ρ2
0Cp
ηk Di =αgL
Cp
From the second equation we get α=DiCp
gL , which we can insert in the first one:
Ra =DiC2
p∆T L2ρ2
0
ηk or, η =DiC2
p∆T L2ρ2
0
Ra k
For instance, for Ra = 104and Di = 0.75, we obtain α'3·10−5and η'1025 which are quite reasonable
values.
31.4 Scaling
Following [324], we non-dimensionalize the equations using the reference values for density ρr, thermal
expansivity αr, temperature contrast ∆Tr(refTemp), thermal conductivity kr, heat capacity Cp, depth
of the fluid layer Land viscosity ηr. The non-dimensionalization for velocity, ur, pressure prand time,
trbecome
ur=kr
ρrCpL(refvel)
pr=ηrkr
ρrCpL2(refpress)
tr=ρrCpL2
kr
(reftime)
In the case of the setup described hereabove, and when choosing Ra = 104and Di = 0.5, we get:
alphaT 2.083333e-05
eta 8.437500e+24
reftime 1.125000e+19
refvel 2.666667e-13
refPress 7.500000e+05
184
31.5 Conservation of energy 1
31.5.1 under BA and EBA approximations
Following [350], we take the dot product of the momentum equation with the velocity vand integrate
over the whole volume27:ZV
[−∇ · τ+∇p]·vdV =ZV
ρg·vdV
or,
−ZV
(∇ · τ)·vdV +ZV
∇p·vdV =ZV
ρg·vdV
Let us look at each block separately:
−ZV
(∇ · τ)·vdV =−ZS
τ v ·n
|{z}
=0 (b.c.)
dS +ZV
τ:∇vdV =ZV
τ:˙
εdV =ZV
ΦdV
which is the volume integral of the shear heating. Then,
ZV
∇p·vdV =ZS
pv·n
|{z}
=0 (b.c.)
dS −ZV
∇·v
|{z}
=0 (incomp.)
pdV = 0
which is then zero in the case of an incompressible flow. And finally
ZV
ρg·vdV =W
which is the work against gravity.
Conclusion for an incompressible fluid: we should have
ZV
ΦdV =ZV
ρg·vdV (368)
This formula is hugely problematic: indeed, the term ρin the rhs is the full density. We know that to the
value of ρ0corresponds a lithostatic pressure gradient pL=ρ0gy. In this case one can write ρ=ρ0+ρ0
and p=pL+p0so that we also have
ZV
[−∇ · τ+∇p0]·vdV =ZV
ρ0g·vdV
which will ultimately yield
ZV
ΦdV =ZV
ρ0g·vdV =ZV
(ρ−ρ0)g·vdV (369)
Obviously Eqs.(370) and (371) cannot be true at the same time. The problem comes from the nature
of the (E)BA approximation: ρ=ρ0in the mass conservation equation but it is not constant in the
momentum conservation equation, which is of course inconsistent. Since the mass conservation equation
is ∇·v= 0 under this approximation then the term RV∇p·vdV is always zero for any pressure (full
pressure p, or overpressure p−pL), hence the paradox. This paradox will be lifted when a consistent set
of equations will be used (compressible formulation). On a practical note, Eqs.(370) is not verified by
the code, while (371) is.
In the end: ZV
ΦdV
| {z }
visc diss
=ZV
(ρ−ρ0)g·vdV
| {z }
work grav
(370)
27Check: this is akin to looking at the power, force*velocity, says Arie
185
31.5.2 under no approximation at all
ZV
∇p·vdV =ZS
pv·n
|{z}
=0 (b.c.)
dS −ZV
∇·vpdV = 0 (371)
=ZV
1
ρv·∇ρ pdV = 0 (372)
(373)
ToDo:see section 3 of [350] where this is carried out with the Adams-Williamson eos.
31.6 Conservation of energy 2
Also, following the Reynold’s transport theorem [375],p210, we have for a property A(per unit mass)
d
dt ZV
AρdV =ZV
∂
∂t (Aρ)dV +ZS
Aρv·ndS
Let us apply to this to A=CpTand compute the time derivative of the internal energy:
d
dt ZV
ρCpT dV =ZV
∂
∂t (ρCpT)dV +ZS
Aρ v·n
|{z}
=0 (b.c.)
dS =ZV
CpT∂ρ
∂t dV
| {z }
I
+ZV
ρCp
∂T
∂t dV
| {z }
II
(374)
In order to expand I, the mass conservation equation will be used, while the heat transport equation
will be used for II:
I=ZV
CpT∂ρ
∂t dV =−ZV
CpT∇·(ρv)dV =−ZV
CpT ρ v·n
|{z}
=0 (b.c.)
dS +ZV
ρCp∇T·vdV (375)
II =ZV
ρCp
∂T
∂t dV =ZV−ρCpv·∇T+∇·k∇T+ρH +Φ+αT ∂p
∂t +v·∇pdV (376)
=ZV−ρCpv·∇T+ρH +Φ+αT ∂p
∂t +v·∇pdV +ZV
∇·k∇T dV(377)
=ZV−ρCpv·∇T+ρH +Φ+αT ∂p
∂t +v·∇pdV +ZS
k∇T·ndS(378)
=ZV−ρCpv·∇T+ρH +Φ+αT ∂p
∂t +v·∇pdV −ZS
q·ndS (379)
Finally:
I+II =d
dt ZV
ρCpT dV
| {z }
ET
=ZVρH +Φ+αT ∂p
∂t +v·∇pdV −ZS
q·ndS (380)
=ZV
ρHdV +ZV
ΦdV
| {z }
visc diss
+ZV
αT ∂p
∂t dV
| {z }
extra
+ZV
αT v·∇pdV
| {z }
adiab heating
−ZS
q·ndS
| {z }
heatflux boundary
(381)
This was of course needlessly complicated as the term ∂ρ/∂t is always taken to be zero, so that I= 0
automatically. The mass conservation equation is then simply ∇·(ρv) = 0. Then it follows that
0 = ZV
CpT∇·(ρv)dV =−ZV
CpT ρ v·n
|{z}
=0 (b.c.)
dS +ZV
ρCp∇T·vdV (382)
=ZV
ρCp∇T·vdV (383)
so that the same term in Eq.(381) vanishes too, and then Eq.(383) is always valid, although one should
be careful when computing ETin the BA and EBA cases as it should use ρ0and not ρ.
186
31.7 The problem of the onset of convection
[wiki] In geophysics, the Rayleigh number is of fundamental importance: it indicates the presence and
strength of convection within a fluid body such as the Earth’s mantle. The mantle is a solid that behaves
as a fluid over geological time scales.
The Rayleigh number essentially is an indicator of the type of heat transport mechanism. At low
Rayleigh numbers conduction processes dominate over convection ones. At high Rayleigh numbers it is
the other way around. There is a so-called critical value of the number with delineates the transition
from one regime to the other.
This problem has been studied and approached both theoretically and numerically [528, e.g.] and it
was found that the critical Rayleigh number Racis
Rac= (27/4)π4'657.5
in setups similar to ours.
VERY BIG PROBLEM
The temperature setup is built as follows: Tsurf is prescribed at the top, Tsurf + ∆Tis prescribed
at the bottom. The initial temperature profile is linear between these two values. In the case of BA, the
actual value of Tsurf is of no consequence. However, for the EBA the full temperature is present in the
adiabatic heating term on the rhs of the hte, and the value of Tsurf will therefore influence the solution
greatly. This is very problematic as there is no real way to arrive at the surface temperature from the
King paper. On top of this, the density uses a reference temperature T0which too will influence the
solution without being present in the controlling Ra and Di numbers!!
In light thereof, it will be very difficult to recover the values of King et al for EBA!
features
•Q1×P0element
•compressible flow
•mixed formulation
•Dirichlet boundary conditions (no-slip)
•isoviscous
•analytical solution
•pressure smoothing
Relevant literature: [49, 302, 506, 350, 324, 351, 365, 282]
ToDo:
•heat flux is at the moment elemental, so Nusselt and heat flux on boundaries measurements not as
accurate as could be.
187
31.8 results - BA - Ra = 104
These results were obtained with a 64x64 resolution, and CFL number of 1. Steady state was reached
after about 1250 timesteps.
(a)
0
1x10-6
2x10-6
3x10-6
4x10-6
5x10-6
6x10-6
7x10-6
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
EK
time (Myr)
(b)
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
ET
time (Myr)
(c)
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
EG
time (Myr)
(d)
2273.15
2273.15
2273.15
2273.15
2273.15
2273.15
2273.15
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
<T>
time (Myr)
(e)
0
500
1000
1500
2000
2500
3000
3500
4000
4500
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
Temperature
time (Myr)
min(T)
max(T)
(f)
-0.0015
-0.001
-0.0005
0
0.0005
0.001
0.0015
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
velocity
time (Myr)
min(u)
max(u)
min(v)
max(v)
(g)
-80000
-70000
-60000
-50000
-40000
-30000
-20000
-10000
0
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
adiabatic heating
time (Myr)
(h)
0
10000
20000
30000
40000
50000
60000
70000
80000
90000
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
viscous dissipation
time (Myr)
(i)
0
10000
20000
30000
40000
50000
60000
70000
80000
90000
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
work against gravity
time (Myr)
(j)
-5x10-8
-4x10-8
-3x10-8
-2x10-8
-1x10-8
0
1x10-8
2x10-8
3x10-8
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
heat flux
time (Myr)
(k)
0
0.01
0.02
0.03
0.04
0.05
0.06
0.07
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
vrms (cm/yr)
time (Myr)
(l)
0
1
2
3
4
5
6
7
8
0 10000 20000 30000 40000 50000 60000 70000 80000 90000 100000
Nu
time (Myr)
4.88
(l)
-6x10-7
-4x10-7
-2x10-7
0
2x10-7
4x10-7
6x10-7
8x10-7
0 1x1010
2x1010
3x1010
4x1010
5x1010
6x1010
7x1010
8x1010
9x1010
1x1011
time (Myr)
0
HF
dETdt
(m)
0
10000
20000
30000
40000
50000
60000
70000
80000
90000
0 1x1010
2x1010
3x1010
4x1010
5x1010
6x1010
7x1010
8x1010
9x1010
1x1011
time (Myr)
VD
WG
AH: adiabatic heating, VD: viscous dissipation, HF: heat flux, WG: work against gravity
Eq.(383) is verified by (l) and Eq.(372) is verified by (m).
189
(a) (b) (c)
(d) (e) (f)
(g) (h) (i)
190
31.9 results - BA - Ra = 105
These results were obtained with a 64x64 resolution, and CFL number of 1. Steady state was reached
after about 1250 timesteps.
(a)
0
0.0001
0.0002
0.0003
0.0004
0.0005
0.0006
0.0007
0 5000 10000 15000 20000 25000 30000 35000
EK
time (Myr)
(b)
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
7.67188x1022
0 5000 10000 15000 20000 25000 30000 35000
ET
time (Myr)
(c)
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
-7.73687x1023
0 5000 10000 15000 20000 25000 30000 35000
EG
time (Myr)
(d)
2273.149999999
2273.149999999
2273.149999999
2273.150000000
2273.150000000
2273.150000000
2273.150000000
2273.150000000
2273.150000001
2273.150000001
2273.150000001
0 5000 10000 15000 20000 25000 30000 35000
<T>
time (Myr)
(e)
0
500
1000
1500
2000
2500
3000
3500
4000
4500
0 5000 10000 15000 20000 25000 30000 35000
Temperature
time (Myr)
min(T)
max(T)
(f)
-0.015
-0.01
-0.005
0
0.005
0.01
0.015
0 5000 10000 15000 20000 25000 30000 35000
velocity
time (Myr)
min(u)
max(u)
min(v)
max(v)
(g)
-900000
-800000
-700000
-600000
-500000
-400000
-300000
-200000
-100000
0
0 5000 10000 15000 20000 25000 30000 35000
adiabatic heating
time (Myr)
(h)
0
100000
200000
300000
400000
500000
600000
700000
800000
900000
0 5000 10000 15000 20000 25000 30000 35000
viscous dissipation
time (Myr)
(i)
0
100000
200000
300000
400000
500000
600000
700000
800000
900000
0 5000 10000 15000 20000 25000 30000 35000
work against gravity
time (Myr)
(j)
-1x10-6
-5x10-7
0
5x10-7
1x10-6
1.5x10-6
2x10-6
2.5x10-6
0 5000 10000 15000 20000 25000 30000 35000
heat flux
time (Myr)
(k)
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0 5000 10000 15000 20000 25000 30000 35000
vrms (cm/yr)
time (Myr)
193.2150
(l)
0
2
4
6
8
10
12
14
16
18
0 5000 10000 15000 20000 25000 30000 35000
Nu
time (Myr)
10.53
(l)
-8x10-6
-6x10-6
-4x10-6
-2x10-6
0
2x10-6
4x10-6
6x10-6
8x10-6
1x10-5
0 5x109 1x1010
1.5x1010
2x1010
2.5x1010
3x1010
3.5x1010
time (Myr)
0
HF
dETdt
(m)
0
100000
200000
300000
400000
500000
600000
700000
800000
900000
0 5x109 1x1010 1.5x1010 2x1010 2.5x1010 3x1010 3.5x1010
time (Myr)
VD
WG
AH: adiabatic heating, VD: viscous dissipation, HF: heat flux, WG: work against gravity
Eq.(383) is verified by (l) and Eq.(372) is verified by (m).
191
31.10 results - BA - Ra = 106
192
31.11 results - EBA - Ra = 104
These results were obtained with a 64x64 resolution, and CFL number of 1. Steady state was reached
after about 2500 timesteps
(a)
0
1x10-7
2x10-7
3x10-7
4x10-7
5x10-7
6x10-7
7x10-7
8x10-7
0 50000 100000 150000 200000 250000
EK
time (Myr)
(b)
7.2x1022
7.25x1022
7.3x1022
7.35x1022
7.4x1022
7.45x1022
7.5x1022
7.55x1022
7.6x1022
7.65x1022
7.7x1022
0 50000 100000 150000 200000 250000
ET
time (Myr)
(c)
-7.76x1023
-7.755x1023
-7.75x1023
-7.745x1023
-7.74x1023
-7.735x1023
0 50000 100000 150000 200000 250000
EG
time (Myr)
(d)
2140
2160
2180
2200
2220
2240
2260
2280
0 50000 100000 150000 200000 250000
<T>
time (Myr)
(e)
0
500
1000
1500
2000
2500
3000
3500
4000
4500
0 50000 100000 150000 200000 250000
Temperature
time (Myr)
min(T)
max(T)
(f)
-0.0004
-0.0003
-0.0002
-0.0001
0
0.0001
0.0002
0.0003
0.0004
0 50000 100000 150000 200000 250000
velocity
time (Myr)
min(u)
max(u)
min(v)
max(v)
(g)
-10000
-9000
-8000
-7000
-6000
-5000
-4000
-3000
-2000
-1000
0
0 50000 100000 150000 200000 250000
adiabatic heating
time (Myr)
(h)
0
1000
2000
3000
4000
5000
6000
7000
8000
9000
10000
0 50000 100000 150000 200000 250000
viscous dissipation
time (Myr)
(i)
0
1000
2000
3000
4000
5000
6000
7000
8000
9000
10000
0 50000 100000 150000 200000 250000
work against gravity
time (Myr)
(j)
-1000
0
1000
2000
3000
4000
5000
6000
7000
8000
9000
10000
0 50000 100000 150000 200000 250000
heat flux
time (Myr)
(k)
0
0.005
0.01
0.015
0.02
0.025
0 50000 100000 150000 200000 250000
vrms (cm/yr)
time (Myr)
(l)
0.8
1
1.2
1.4
1.6
1.8
2
2.2
2.4
0 50000 100000 150000 200000 250000
Nu
time (Myr)
(l)
-10000
-9000
-8000
-7000
-6000
-5000
-4000
-3000
-2000
-1000
0
1000
0 50000 100000 150000 200000 250000
time (Myr)
0
AH+VD+HF
dETdt
(m)
0
1000
2000
3000
4000
5000
6000
7000
8000
9000
10000
0 50000 100000 150000 200000 250000
time (Myr)
VD
WG
AH: adiabatic heating, VD: viscous dissipation, HF: heat flux, WG: work against gravity
Eq.(383) is verified by (l) and Eq.(372) is verified by (m).
193
a) b) c)
d) e) f)
g) h) i)
j) k) l)
m) n)
194
31.12 results - EBA - Ra = 105
These results were obtained with a 64x64 resolution, and CFL number of 1. Simulation was stopped after
about 4300 timesteps.
(a)
0
1x10-5
2x10-5
3x10-5
4x10-5
5x10-5
6x10-5
7x10-5
8x10-5
9x10-5
0 20000 40000 60000 80000 100000 120000
EK
time (Myr)
(b)
7.4x1022
7.45x1022
7.5x1022
7.55x1022
7.6x1022
7.65x1022
7.7x1022
0 20000 40000 60000 80000 100000 120000
ET
time (Myr)
(c)
-7.75x1023
-7.748x1023
-7.746x1023
-7.744x1023
-7.742x1023
-7.74x1023
-7.738x1023
-7.736x1023
0 20000 40000 60000 80000 100000 120000
EG
time (Myr)
(d)
2200
2210
2220
2230
2240
2250
2260
2270
2280
0 20000 40000 60000 80000 100000 120000
<T>
time (Myr)
(e)
0
500
1000
1500
2000
2500
3000
3500
4000
4500
5000
0 20000 40000 60000 80000 100000 120000
Temperature
time (Myr)
min(T)
max(T)
(f)
-0.005
-0.004
-0.003
-0.002
-0.001
0
0.001
0.002
0.003
0.004
0.005
0 20000 40000 60000 80000 100000 120000
velocity
time (Myr)
min(u)
max(u)
min(v)
max(v)
(g)
-120000
-100000
-80000
-60000
-40000
-20000
0
0 20000 40000 60000 80000 100000 120000
adiabatic heating
time (Myr)
(h)
0
20000
40000
60000
80000
100000
120000
0 20000 40000 60000 80000 100000 120000
viscous dissipation
time (Myr)
(i)
0
20000
40000
60000
80000
100000
120000
0 20000 40000 60000 80000 100000 120000
work against gravity
time (Myr)
(j)
-20000
-10000
0
10000
20000
30000
40000
50000
60000
70000
0 20000 40000 60000 80000 100000 120000
heat flux
time (Myr)
(k)
0
0.05
0.1
0.15
0.2
0.25
0.3
0 20000 40000 60000 80000 100000 120000
vrms (cm/yr)
time (Myr)
(l)
0.5
1
1.5
2
2.5
3
3.5
4
4.5
5
5.5
6
0 20000 40000 60000 80000 100000 120000
Nu
time (Myr)
(l)
-60000
-50000
-40000
-30000
-20000
-10000
0
10000
20000
0 20000 40000 60000 80000 100000 120000
time (Myr)
0
AH+VD+HF
dETdt
(m)
0
20000
40000
60000
80000
100000
120000
0 20000 40000 60000 80000 100000 120000
time (Myr)
VD
WG
AH: adiabatic heating, VD: viscous dissipation, HF: heat flux, WG: work against gravity
195
31.13 Onset of convection
The code can be run for values of Ra between 500 and 1000, at various resolutions for the BA formulation.
The value vrms(t)−vrms(0) is plotted as a function of Ra and for the 10 first timesteps. If the vrms is
found to decrease, then the Rayleigh number is not high enough to allow for convection and the initial
temperature perturbation relaxes by diffusion (and then vrms(t)−vrms(0) <0. If the vrms is found to
increase, then vrms(t)−vrms(0) >0 and the system is going to showcase convection. The zero value of
vrms(t)−vrms(0) gives us the critical Rayleigh number, which is found between 775 and 790.
-4x10-15
-2x10-15
0
2x10-15
4x10-15
6x10-15
8x10-15
1000
vrms trend
Ra
16x16
32x32
48x48
64x64
-3.5x10-16
-3x10-16
-2.5x10-16
-2x10-16
-1.5x10-16
-1x10-16
-5x10-17
0
5x10-17
1x10-16
1.5x10-16
770 775 780 785 790
vrms trend
Ra
16x16
32x32
48x48
64x64
196
Appendix: Looking for the right combination of parameters for the King benchmark.
I run a quadruple do loop over L, ∆T,ρ0and η0between plausible values (see code targets.py) and
write in a file only the combination which yields the required Rayleigh and Dissipation number values
(down to 1% accuracy).
alp ha=3e−5
g=10
hcapa =1250
hcond=3
DTmin=1000 ; DTmax=4000 ; DTnpts=251
Lmin=1e6 ; Lmax=3e6 ; Lnpts=251
rhomin =3000 ; rhomax=3500 ; rh on pt s=41
etam in =19 ; etamax=25 ; e t a n p t s =100
On the following plots the ’winning’ combinations of these four parameters are shown:
0.24
0.245
0.25
0.255
0.26
9600 9800 10000 10200 10400
Di
Ra
1x106
1.005x106
1.01x106
1.015x106
1.02x106
1.025x106
1.03x106
1.035x106
1.04x106
1.045x106
1.05x106
500 1000 1500 2000 2500 3000 3500 4000 4500
L
DT
1x1023
2x1023
3x1023
4x1023
5x1023
6x1023
7x1023
8x1023
9x1023
2800 3000 3200 3400 3600 3800 4000 4200
eta
rho
We see that:
•the parameter L(being to the 3rd power in the Ra number) cannot vary too much. Although it is
varied between 1000 and 3000km there seems to be a ’right’ value at about 1040 km. (why?)
•viscosities are within 1023 and 1024 which are plausible values (although a bit high?).
•densities can be chosen freely between 3000 and 3500
•∆Tseems to be the most problematic value since it can range from 1000 to 4000K ...
197
32 fieldstone 25: Rayleigh-Taylor instability (1) - instantaneous
This numerical experiment was first presented in [546]. It consists of an isothermal Rayleigh-Taylor
instability in a two-dimensional box of size Lx = 0.9142 and Ly= 1. Two Newtonian fluids are present
in the system: the buoyant layer is placed at the bottom of the box and the interface between both fluids
is given by y(x) = 0.2+0.02 cos πx
LxThe bottom fluid is parametrised by its mass density ρ1and its
viscosity µ1, while the layer above is parametrised by ρ2and µ2.
No-slip boundary conditions are applied at the bottom and at the top of the box while free-slip
boundary conditions are applied on the sides.
In the original benchmark the system is run over 2000 units of dimensionless time and the timing
and position of various upwellings/downwellings is monitored. In this present experiment only the root
mean square velocity is measured at t= 0: the code is indeed not yet foreseen of any algorithm capable
of tracking deformation.
Another approach than the ones presented in the extensive literature which showcases results of this
benchmark is taken. The mesh is initially fitted to the fluids interface and the resolution is progressively
increased. This results in the following figure:
0.00001
0.00010
0.00100
0.01000
0.01 0.1
vrms
hx
The green line indicates results obtained with my code ELEFANT with grids up to 2000x2000 with the
exact same methodology.
198
features
•Q1×P0element
•incompressible flow
•mixed formulation
•isothermal
•numerical benchmark
199
33 fieldstone 26: Slab detachment benchmark (1) - instanta-
neous
As in [472], the computational domain is 1000km ×660km. No-slip boundary conditions are imposed
on the sides of the system while free-slip boundary conditions are imposed at the top and bottom. Two
materials are present in the domain: the lithosphere (mat.1) and the mantle (mat.2). The overriding
plate (mat.1) is 80km thick and is placed at the top of the domain. An already subducted slab (mat.1)
of 250km length hangs vertically under this plate. The mantle occupies the rest of the domain.
The mantle has a constant viscosity η0= 1021P a.s and a density ρ= 3150kg/m3. The slab has a
density ρ= 3300kg/m3and is characterised by a power-law flow law so that its effective viscosity depends
on the second invariant of the strainrate I2as follows:
ηeff =1
2A−1/nsI1/ns−1
2=1
2[(2 ×4.75×1011)−ns]−1/nsI1/ns−1
2= 4.75×1011I1/ns−1
2=η0I1/ns−1
2(384)
with ns= 4 and A= (2 ×4.75×1011)−ns, or η0= 4.75 ×1011.
Fields at convergence for 151x99 grid.
1x1020
1x1021
1x1022
1x1023
1x1024
0 100 200 300 400 500 600 700 800 900 1000
viscosity (Pa.s)
x (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
1x1020
1x1021
1x1022
1x1023
1x1024
400 450 500 550 600
viscosity (Pa.s)
x (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
1x1020
1x1021
1x1022
1x1023
1x1024
1x1025
1x1026
0 100 200 300 400 500 600 700
viscosity (Pa.s)
y (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
0.0000001
0.0000010
0.0000100
0.0001000
0.0010000
0.0100000
0.1000000
1.0000000
0 5 10 15 20 25 30 35 40 45
normalised nonlinear residual
y (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
1e-7
-8x10-16
-6x10-16
-4x10-16
-2x10-16
0
2x10-16
4x10-16
0 100 200 300 400 500 600 700 800 900 1000
exx
x (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
-4x10-16
-2x10-16
0
2x10-16
4x10-16
6x10-16
8x10-16
1x10-15
0 100 200 300 400 500 600 700 800 900 1000
eyy
x (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
-1.5x10-15
-1x10-15
-5x10-16
0
5x10-16
1x10-15
1.5x10-15
0 100 200 300 400 500 600 700 800 900 1000
exy
x (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
200
Along the horizontal line
-1x10-15
-8x10-16
-6x10-16
-4x10-16
-2x10-16
0
2x10-16
4x10-16
0 100 200 300 400 500 600 700
exx
y (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
-4x10-16
-2x10-16
0
2x10-16
4x10-16
6x10-16
8x10-16
1x10-15
0 100 200 300 400 500 600 700
eyy
y (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
-6x10-17
-4x10-17
-2x10-17
0
2x10-17
4x10-17
6x10-17
8x10-17
0 100 200 300 400 500 600 700
exy
y (km)
nelx=32
nelx=48
nelx=51
nelx=64
nelx=100
nelx=128
nelx=151
Along the vertical line
features
•Q1×P0element
•incompressible flow
•mixed formulation
•isothermal
•nonlinear rheology
•nonlinear residual
Todo: nonlinear mantle, pressure normalisation
201
34 fieldstone 27: Consistent Boundary Flux
In what follows we will be re-doing the numerical experiments presented in Zhong et al. [597].
The first benchmark showcases a unit square domain with free slip boundary conditions prescribed
on all sides. The resolution is fixed to 64 ×64 Q1×P0elements. The flow is isoviscous and the buoyancy
force fis given by
fx= 0
fy=ρ0αT (x, y)
with the temperature field given by
T(x, y) = cos(kx)δ(y−y0)
where k= 2π/λ and λis a wavelength, and y0represents the location of the buoyancy strip. We set
gy=−1 and prescribe ρ(x, y) = ρ0αcos(kx)δ(y−y0) on the nodes of the mesh.
One can prove ([597] and refs. therein) that there is an analytic solution for the surface stress σzz 28
σyy
ραgh =cos(kx)
sinh2(k)[k(1 −y0) sinh(k) cosh(ky0)−ksinh(k(1 −y0)) + sinh(k) sinh(ky0)]
We choose ρ0α= 64, η= 1 (note that in this case the normalising coefficient of the stress is exactly
1 (since h=Lx/nelx = 1/64) so it is not implemented in the code). λ= 1 is set to 1 and we explore
y0=63
64 ,62
64 ,59
64 and y0= 32/64. Under these assumptions the density field for y0= 59/64 is:
We can recover the stress at the boundary by computing the yy component of the stress tensor in the
top row of elements:
σyy =−p+ 2η˙yy
Note that pressure is by definition elemental, and that strain rate components are then also computed in
the middle of each element.
These elemental quantities can be projected onto the nodes (see section ??) by means of the C→N
algorithm or a least square algorithm (LS).
-0.2
-0.15
-0.1
-0.05
0
0.05
0.1
0.15
0.2
0 0.2 0.4 0.6 0.8 1
σyy
x
y0=32/64
analytical
elemental
C-N
LS
cbf
-0.001
-0.0008
-0.0006
-0.0004
-0.0002
0
0.0002
0.0004
0.0006
0.0008
0.001
0 0.2 0.4 0.6 0.8 1
σyy error
x
y0=32/64
elemental
C-N
LS
cbf
0.
28Note that in the paper the authors use ραg which does not have the dimensions of a stress
202
-1
-0.8
-0.6
-0.4
-0.2
0
0.2
0.4
0.6
0.8
1
0 0.2 0.4 0.6 0.8 1
σyy
x
y0=59/64
analytical
elemental
C-N
LS
cbf
-0.003
-0.002
-0.001
0
0.001
0.002
0.003
0 0.2 0.4 0.6 0.8 1
σyy error
x
y0=59/64
elemental
C-N
LS
cbf
0.
-1.5
-1
-0.5
0
0.5
1
1.5
0 0.2 0.4 0.6 0.8 1
σyy
x
y0=62
analytical
elemental
C-N
LS
cbf
-0.1
-0.08
-0.06
-0.04
-0.02
0
0.02
0.04
0.06
0.08
0.1
0 0.2 0.4 0.6 0.8 1
σyy error
x
y0=62
elemental
C-N
LS
cbf
0.
-1.5
-1
-0.5
0
0.5
1
1.5
0 0.2 0.4 0.6 0.8 1
σyy
x
y0=63/64
analytical
elemental
C-N
LS
cbf
-0.2
-0.15
-0.1
-0.05
0
0.05
0.1
0.15
0.2
0 0.2 0.4 0.6 0.8 1
σyy error
x
y0=63/64
elemental
C-N
LS
cbf
0.
The consistent boundary flux (CBF) method allows us to compute traction vectors t=σ·non the
boundary of the domain. On the top boundary, n= (0,1) so that t= (σxy, σyy)Tand tyis the quantity
we need to consider and compare to other results.
In the following table are shown the results presented in [597] alongside the results obtained with
Fieldstone:
Method y0= 63/64 y0= 62/64 y0= 59/64 29 y0= 32/64
Analytic solution 0.995476 0.983053 0.912506 0.178136
Pressure smoothing [597] 1.15974 1.06498 0.911109 n.a.
CBF [597] 0.994236 0.982116 0.912157 n.a.
fieldstone: elemental 0.824554 (-17.17 %) 0.978744 (-0.44%) 0.909574 (-0.32 %) 0.177771 (-0.20 %)
fieldstone: nodal (C→N) 0.824554 (-17.17 %) 0.978744 (-0.44%) 0.909574 (-0.32 %) 0.177771 (-0.20 %)
fieldstone: LS 1.165321 ( 17.06 %) 1.070105 ( 8.86%) 0.915496 ( 0.33 %) 0.178182 ( 0.03 %)
fieldstone: CBF 0.994236 ( -0.13 %) 0.982116 (-0.10%) 0.912157 (-0.04 %) 0.177998 (-0.08 %)
We see that we recover the published results with the same exact accuracy, thereby validating our
implmentation.
On the following figures are shown the velocity, pressure and traction fields for two cases y0= 32/64
and y0= 63/64.
203
Here lies the superiority of our approach over the one presented in the original article: our code
computes all traction vectors on all boundaries at once.
explain how Medge is arrived at!
compare with ASPECT ??!
gauss-lobatto integration?
pressure average on surface instead of volume ?
204
features
•Q1×P0element
•incompressible flow
•mixed formulation
•isothermal
•isoviscous
•analytical solution
•pressure smoothing
•consistent boundary flux
205
35 fieldstone 28: convection 2D box - Tosi et al, 2015
This fieldstone was developed in collaboration with Rens Elbertsen.
The viscosity field µis calculated as the harmonic average between a linear part µlin that depends
on temperature only or on temperature and depth d, and a non-linear, plastic part µplast dependent on
the strain rate:
µ(T, z, ˙
)=21
µlin(T, z)+1
µplast(˙
)−1
.(385)
The linear part is given by the linearized Arrhenius law (the so-called Frank-Kamenetskii approxima-
tion [?]):
µlin(T, z) = exp(−γTT+γzz),(386)
where γT= ln(∆µT) and γz= ln(∆µz) are parameters controlling the total viscosity contrast due to
temperature (∆µT) and pressure (∆µz). The non-linear part is given by [?]:
µplast(˙
) = µ∗+σY
√˙
:˙
,(387)
where µ∗is a constant representing the effective viscosity at high stresses [?] and σYis the yield
stress, also assumed to be constant. In 2-D, the denominator in the second term of equation (389) is
given explicitly by
√˙
:˙
=p˙ij ˙ij =s∂ux
∂x 2
+1
2∂ux
∂y +∂uy
∂x 2
+∂uy
∂y 2
.(388)
The viscoplastic flow law (equation 387) leads to linear viscous deformation at low stresses (equation
(388)) and to plastic deformation for stresses that exceed σY(equation (389)), with the decrease in
viscosity limited by the choice of µ∗[?].
In all cases that we present, the domain is a two-dimensional square box. The mechanical boundary
conditions are for all boundaries free-slip with no flux across, i.e. τxy =τyx = 0 and u·n= 0, where
ndenotes the outward normal to the boundary. Concerning the energy equation, the bottom and top
boundaries are isothermal, with the temperature Tset to 1 and 0, respectively, while side-walls are
assumed to be insulating, i.e. ∂T/∂x = 0. The initial distribution of the temperature field is prescribed
as follows:
T(x, y) = (1 −y) + Acos(πx) sin(πy),(389)
where A= 0.01 is the amplitude of the initial perturbation.
In the following Table ??, we list the benchmark cases according to the parameters used.
Case Ra ∆µT∆µyµ∗σYConvective regime
1 1021051 – – Stagnant lid
2 1021051 10−31 Mobile lid
3 10210510 – – Stagnant lid
4 10210510 10−31 Mobile lid
5a 10210510 10−34 Periodic
5b 10210510 10−33 – 5 Mobile lid – Periodic – Stagnant lid
Benchmark cases and corresponding parameters.
In Cases 1 and 3 the viscosity is directly calculated from equation (388), while for Cases 2, 4, 5a, and
5b, we used equation (387). For a given mesh resolution, Case 5b requires running simulations with yield
stress varying between 3 and 5
In all tests, the reference Rayleigh number is set at the surface (y= 1) to 102, and the viscosity
contrast due to temperature ∆µTis 105, implying therefore a maximum effective Rayleigh number of
107for T= 1. Cases 3, 4, 5a, and 5b employ in addition a depth-dependent rheology with viscosity
contrast ∆µz= 10. Cases 1 and 3 assume a linear viscous rheology that leads to a stagnant lid regime.
206
Cases 2 and 4 assume a viscoplastic rheology that leads instead to a mobile lid regime. Case 5a also
assumes a viscoplastic rheology but a higher yield stress, which ultimately causes the emergence of a
strictly periodic regime. The setup of Case 5b is identical to that of Case 5a but the test consists in
running several simulations using different yield stresses. Specifically, we varied σYbetween 3 and 5 in
increments of 0.1 in order to identify the values of the yield stress corresponding to the transition from
mobile to periodic and from periodic to stagnant lid regime.
35.0.1 Case 0: Newtonian case, a la Blankenbach et al., 1989
0
10
20
30
40
50
60
70
80
90
0 0.05 0.1 0.15 0.2 0.25 0.3 0.35
vrms
time
0
1
2
3
4
5
6
7
0 0.05 0.1 0.15 0.2 0.25 0.3 0.35
Nu
time
0
1
2
3
4
5
6
7
0 10 20 30 40 50 60 70 80 90
Nu
vrms
207
35.0.2 Case 1
In this case µ?= 0 and σY= 0 so that µplast can be discarded. The CFL number is set to 0.5 and the
viscosity is given by µ(T, z, ˙
) = µlin(T, z). And since ∆µz= 1 then γz= 0 so that µlin(T, z) = exp(−γTT)
0
50
100
150
200
250
300
350
0.001 0.01 0.1 1
vrms
time
ELEFANT, 32x32
ELEFANT, 48x48
ELEFANT, 64x64
ELEFANT, 100x100
243.872
0.5
1
1.5
2
2.5
3
3.5
0.001 0.01 0.1 1
Nu
time
3.3987
0.5
1
1.5
2
2.5
3
3.5
0 50 100 150 200 250 300 350
Nu
vrms
0.5
0.55
0.6
0.65
0.7
0.75
0.8
0.001 0.01 0.1 1
<T>
time
0.77368
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
y
T
0
0.2
0.4
0.6
0.8
1
0.00010 0.00100 0.01000 0.10000
y
viscosity
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
0 50 100 150 200 250 300 350 400
y
velocity
208
209
35.0.3 Case 2
0
100
200
300
400
500
600
0.001 0.01 0.1 1
vrms
time
141.518
0
2
4
6
8
10
12
14
0.001 0.01 0.1 1
Nu
time
8.17154
0
2
4
6
8
10
12
14
0 100 200 300 400 500 600
Nu
vrms
0.5
0.52
0.54
0.56
0.58
0.6
0.62
0.001 0.01 0.1 1
<T>
time
0.60521
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
y
T
0
0.2
0.4
0.6
0.8
1
0.00010 0.00100 0.01000 0.10000
y
viscosity
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
0 50 100 150 200 250 300 350 400
y
velocity
210
211
35.0.4 Case 3
0
10
20
30
40
50
60
70
80
90
100
110
0.001 0.01 0.1 1
vrms
time
100.018
0.5
1
1.5
2
2.5
3
3.5
0.001 0.01 0.1 1
Nu
time
3.03472
0.5
1
1.5
2
2.5
3
3.5
0 10 20 30 40 50 60 70 80 90 100 110
Nu
vrms
0.5
0.55
0.6
0.65
0.7
0.75
0.001 0.01 0.1 1
<T>
time
0.7277
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
y
T
0
0.2
0.4
0.6
0.8
1
0.00010 0.00100 0.01000 0.10000
y
viscosity
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
0 50 100 150 200 250 300 350 400
y
velocity
212
213
35.0.5 Case 4
0
50
100
150
200
250
300
350
400
450
500
0.001 0.01 0.1 1
vrms
time
79.4746
0
2
4
6
8
10
12
14
16
0.001 0.01 0.1 1
Nu
time
6.40359
0
2
4
6
8
10
12
14
16
0 50 100 150 200 250 300 350 400 450 500
Nu
vrms
0.495
0.5
0.505
0.51
0.515
0.52
0.525
0.53
0.001 0.01 0.1 1
<T>
time
0.528634
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
y
T
0
0.2
0.4
0.6
0.8
1
0.00010 0.00100 0.01000 0.10000
y
viscosity
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
0 50 100 150 200 250 300 350 400
y
velocity
214
215
35.0.6 Case 5
0
20
40
60
80
100
0 0.5 1 1.5 2 2.5 3 3.5 4 4.5
vrms
time
41.61
98.183
0
1
2
3
4
5
6
7
8
0 0.5 1 1.5 2 2.5 3 3.5 4 4.5
Nu
time
2.6912
7.0763
0
1
2
3
4
5
6
7
8
0 10 20 30 40 50 60 70 80 90 100
Nu
vrms
0.5
0.52
0.54
0.56
0.58
0.6
0.62
0.64
0.66
0.68
0 1 2 3 4 5 6 7
<T>
time
0.66971
0.65206
-200
-150
-100
-50
0
50
100
150
200
0 1 2 3 4 5 6 7
u
time
min(u)
max(u)
-150
-100
-50
0
50
100
150
200
250
300
0 1 2 3 4 5 6 7
v
time
min(v)
max(v)
216
217
36 fieldstone 29: open boundary conditions
In what follows we will investigate the use of the so-called open boundary conditions in the very simple
context of a 2D Stokes sphere experiment.
We start with a domain without the sphere. Essentially, it is what people would call an aquarium.
Free slip boundary conditions are prescribed on the sides and no-slip conditions at the bottom. The top
surface is left free. The fluid has a density ρ0= 1 and a viscosity η0= 1. In the absence of any density
difference in the domain there is no active buoyancy force so that we expect a zero velocity field and a
lithostatic pressure field. This is indeed what we recover:
If we now implement a sphere parametrised by its density ρs=ρ0+ 1, its viscosity ηs= 103and
its radius Rs= 0.123 in the middle of the domain, we see clear velocity field which logically shows the
sphere falling downward and a symmetric return flow of the fluid on each side:
Unfortunately it has been widely documented that the presence of free-slip boundary conditions
affects the evolution of subduction [121], even when these are placed rather far from the subduction zone.
A proposed solution to this problem is the use of ’open boundary conditions’ which are in fact stress
boundary conditions. The main idea is to prescribe a stress on the lateral boundaries (instead of free
slip) so that it balances out exactly the existing lithostatic pressure inside the domain along the side
walls. Only pressure deviations with respect to the lithostatic are responsible for flow and such boundary
conditions allow flow across the boundaries.
We need the lithostatic pressure and compute it before hand (which is trivial in our case but can
prove to be a bit more tedious in real life situations when for instance density varies in the domain as a
function of temperature and/or pressure).
p l i t h = np . z e r os ( nnp , dtype=np . f l o a t 6 4 )
f o r iin range ( 0 , nnp ) :
p l i t h [ i ]=(Ly−y [ i ] ) ∗r ho0 ∗abs ( gy )
Let us start with a somewhat pathological case: even in the absence of the sphere, what happens when
no boundary conditions are prescribed on the sides? The answer is simple: think about an aquarium
without side walls, or a broken dam. The velocity field indeed shows a complete collapse of the fluid left
and right of the bottom.
218
Let us then continue (still with no sphere) but let us now switch on the open boundary conditions.
Since the side boundary conditions match the lithostatic pressure we expect no flow at all in the absence
of any density perturbation in the system. This is indeed what is recovered:
Finally, let us reintroduce the sphere. This time flow is allowed through the left and right side
boundaries:
Finally, although horizontal velocity Dirichlet boundary conditions and open boundary conditions
are not compatible, the same is not true for the vertical component of the velocity: the open b.c.
implementation acts on the horizontal velocity dofs only, so that one can fix the vertical component to
zero, as is shown hereunder:
We indeed see that the in/outflow on the sides is perpendicular to the boundaries.
Turning now to the actual implementation, we see that it is quite trivial, since all element edges are
vertical, and all have the same vertical dimension hx. Since we use a Q0approximation for the pressure
219
we need to prescribe a single pressure value in the middle of the element. Finally because of the sign of
the normal vector projection onto the x-axis, we obtain:
i f open bc left and x [ i c o n [ 0 , i e l ] ] <eps : # l e f t s i d e
pmid =0. 5∗( p l i t h [ i co n [ 0 , i e l ] ]+ p l i t h [ i co n [ 3 , i e l ] ] )
f e l [0 ]+= 0.5∗hy∗pmid
f e l [6 ]+= 0.5∗hy∗pmid
i f open bc right and x [ i c o n [ 1 , i e l ] ] >Lx−eps : # r i g h t s i d e
pmid =0. 5∗( p l i t h [ i co n [ 1 , i e l ] ]+ p l i t h [ i co n [ 2 , i e l ] ] )
f e l [2 ] −= 0. 5∗hy∗pmid
f e l [4 ] −= 0. 5∗hy∗pmid
These few lines of code are added after the elemental matrices and rhs are built, and before the
application of other Dirichlet boundary conditions, and assembly.
features
•Q1×P0element
•incompressible flow
•mixed formulation
•open boundary conditions
•isoviscous
220
37 fieldstone 30: conservative velocity interpolation
In this the Stokes equations are not solved. It is a 2D implementation of the cvi algorithm as introduced
in [561] which deals with the advection of markers. Q1and Q2basis functions are used and in both cases
the cvi algorithm can be toggled on/off. Markers can be distributed regularly or randomly at startup.
Three velocity fields are prescribed on the mesh:
•the so-called Couette flow of [561]
•the SolCx solution
•a flow created by means of a stream line function (see fieldstone 32)
37.1 Couette flow
37.2 SolCx
37.3 Streamline flow
0
1
2
3
4
5
6
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9
nmarker
time
Q1, no cvi, RK1
Q1, cvi, RK1
Q2, no cvi, RK1
Q2, cvi, RK1
Q1, no cvi, RK1, **
0
0.5
1
1.5
2
2.5
0 0.2 0.4 0.6 0.8 1
nmarker
time
Q1, no cvi, RK2
Q1, cvi, RK2
Q1, no cvi, RK4
Q1, no cvi, RK5
Q2, no cvi, RK2
Q2, no cvi, RK4
In this case RK order seems to be more important that cvi.
Explore why ?!
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions (free-slip)
•direct solver
•isothermal
•non-isoviscous
•analytical solution
221
38 fieldstone 31: conservative velocity interpolation 3D
222
39 fieldstone 32: 2D analytical sol. from stream function
39.1 Background theory
The stream function is a function of coordinates and time of an inviscid liquid. It allows to determine
the components of velocity by differentiating the stream function with respect to the space coordinates.
A family of curves Ψ = const represent streamlines, i.e. the stream function remains constant along a
streamline. Although also valid in 3D, this approach is mostly used in 2D because of its relative simplicity
REFERENCES.
In two dimensions the velocity is obtained as follows:
v=∂Ψ
∂y ,−∂Ψ
∂x (390)
Provided the function Ψ is a smooth enough function, this automatically insures that the flow is incom-
pressible:
∇·v=∂u
∂x +∂v
∂y =∂2Ψ
∂xy −∂2Ψ
∂xy = 0 (391)
Assuming constant viscosity, the Stokes equation writes:
−∇p+µ∆v=ρg(392)
Let us introduce the vector Wfor convenience such that in each dimension:
Wx=−∂p
∂x +µ∂2u
∂x2+∂2u
∂xy=ρgx(393)
Wy=−∂p
∂y +µ∂2v
∂x2+∂2v
∂xy=ρgy(394)
Taking the curl of the vector Wand only considering the component perpendicular to the xy-plane:
∂Vy
∂x −∂Vx
∂y =∂ρgy
∂x −∂ρgx
∂y (395)
The advantage of this approach is that the pressure terms cancel out (the curl of a gradient is always
zero), so that:
∂
∂x µ(∂2v
∂x2+∂2v
∂xy−∂
∂y µ∂2u
∂x2+∂2u
∂xy=∂ρgy
∂x −∂ρgx
∂y (396)
and then replacing u, v by the their stream function derivatives yields (for a constant viscosity):
µ∂4Ψ
∂x4+∂4Ψ
∂y4+ 2 ∂4Ψ
∂x2y2=∂ρgy
∂x −∂ρgx
∂y (397)
or,
∇4Ψ = ∂2
∂x2+∂2
∂y2 ∂2
∂x2+∂2
∂y2Ψ = ∂ρgy
∂x −∂ρgx
∂y (398)
These equations are also to be found in the geodynamics literature, eee Eq. 1.43 of Tackley book, p 70-71
of Gerya book.
39.2 A simple application
I wish to arrive at an analytical formulation for a 2D incompressible flow in the square domain [−1 :
1] ×[−1 : 1] The fluid has constant viscosity µ= 1 and is subject to free slip boundary conditions on all
sides. For reasons that will become clear in what follows I postulate the following stream function:
Ψ(x, y) = sin(mπx) sin(nπy) (399)
223
We have the velocity being defined as:
v= (u, v) = ∂Ψ
∂y ,−∂Ψ
∂x = (nπ sin(mπx) cos(nπy),−mπ cos(mπx) sin(nπy)) (400)
The strain rate components are then:
˙εxx =∂u
∂x =mnπ2cos(mπx) cos(nπy) (401)
˙εyy =∂v
∂y =−mnπ2cos(mπx) cos(nπy) (402)
2 ˙εxy =∂u
∂y +∂v
∂x (403)
=∂2Ψ
∂y2−∂2Ψ
∂x2(404)
=−n2π2Ψ + m2π2Ψ (405)
= (m2−n2)π2sin(mπx) sin(nπy) (406)
Note that if m=nthe last term is identically zero, which is not desirable (flow is too ’simple’) so in
what follows we will prefer m6=n.
It is also easy to verify that u= 0 on the sides and v= 0 at the top and bottom and that the term
˙εxy is nul on all four sides, thereby garanteeing free slip.
Our choice of stream function yields:
∇4Ψ = ∂4Ψ
∂x4+∂4Ψ
∂y4+ 2 ∂2Ψ
∂x2y2=π4(m4Ψ + n4Ψ+2m2n2Ψ) = (m4+n4+ 2m2n2)π4Ψ
We assume gx= 0 and gy=−1 so that we simply have
(m4+n4+ 2m2n2)π4Ψ = −∂ρ
∂x (407)
so that (assuming the integration constant to be zero):
ρ(x, y) = m4+n4+ 2m2n2
mπ3cos(mπx) sin(nπy)
The x-component of the momentum equation is
−∂p
∂x +∂2u
∂x2+∂2u
∂y2=−∂p
∂x −m2nπ3sin(mπx) cos(nπy)−n3π3sin(mπx) cos(nπy)=0
so ∂p
∂x =−(m2n+n3)π3sin(mπx) cos(nπy)
and the pressure field is then (once again neglecting the integration constant):
p(x, y) = m2n+n3
mπ2cos(πx) cos(πy)
Note that in this case RpdV = 0 so that volume normalisation of the pressure is turned on (when free
slip boundary conditions are prescribed on all sides the pressure is known up to a constant and this
undeterminacy can be lifted by adding an additional constraint to the pressure field).
224
Top to bottom: Velocity components uand v, pressure p, density ρand strain rate ˙εxy . From left to right:
(m, n) = (1,1), (m, n) = (1,2), (m, n) = (2,1), (m, n) = (2,2)
225
0.001
0.01
0.1
1
10
100
0.01 0.1
error
h
velocity
pressure
x2
x1
Errors for velocity and pressure for (m, n) = (1,1),(1,2),(2,1),(2,2)
Velocity arrows for (m, n) = (2,1)
226
40 fieldstone 33: Convection in an annulus
This fieldstone was developed in collaboration with Rens Elbertsen.
This is based on the community benchmark for viscoplastic thermal convection in a 2D square box
[524] as already carried out in ??.
In this experiment the geometry is an annulus of inner radius R1= 1.22 and outer radius R2= 2.22.
The rheology and buoyancy forces are identical to those of the box experiment. The initial temperature
is now given by:
T(r, θ) = Tc(r) + A s(1 −s) cos(N0θ)s=R2−r
R2−R1∈[0,1]
where sin the normalised depth, Ais the amplitude of the perturbation and N0the number of lobes. In
this equation Tc(r) stands for the steady state purely conductive temperature solution which is obtained
by solving the Laplace’s equation in polar coordinates (all terms in θare dropped because of radial
symmetry) supplemented with two boundary conditions:
∆Tc=1
r
∂
∂r r∂T
∂r = 0 T(r=R1) = T1= 1 T(r=R2) = T2= 0
We obtain
Tc(r) = log(r/R2)
log(R1/R2)
Note that this profile differs from the straight line that is used in [524] and in section 35.
Examples of initial temperature fields for N0= 3,5,11
Boundary conditions can be either no-slip or free-slip on both inner and outer boundary. However,
when free-slip is used on both a velocity null space exists and must be filtered out. In other words, the
solver may be able to come up with a solution to the Stokes operator, but that solution plus an arbitrary
rotation is also an equally valid solution. This additional velocity field can be problematic since it is used
for advecting temperature (and/or compositions) and it also essentially determines the time step value
for a chosen mesh size (CFL condition).
For these reasons the nullspace must be removed from the obtained solution after every timestep.
There are two types of nullspace removal: removing net angular momentum, and removing net rotations.
We calculate the following output parameters:
•the average temperature < T >
hTi=RΩT dΩ
RΩdΩ=1
VΩZΩ
T dΩ (408)
•the root mean square velocity vrms as given by equation (27).
•the root mean square of the radial and tangential velocity components as given by equations (29)
and (30).
227
•the heat transfer through both boundaries Q:
Qinner,outer =ZΓi,o
q·ndΓ (409)
•the Nusselt number at both boundaries N u as given by equations (32) and (33).
•the power spectrum of the temperature field:
P Sn(T) = ZΩ
T(r, θ)einθdΩ
2
.(410)
features
•Q1×P0element
•incompressible flow
•penalty formulation
•Dirichlet boundary conditions
•non-isothermal
•non-isoviscous
•annulus geometry
228
41 fieldstone 34: the Cartesian geometry elastic aquarium
This fieldstone was developed in collaboration with Lukas van de Wiel.
The setup is as follows: a 2D square of elastic material of size Lis subjected to the following boundary
conditions: free slip on the sides, no slip at the bottom and free at the top. It has a density ρand is
placed is a gravity field g=−gey. For an isotropic elastic medium the stress tensor is given by:
σ=λ(∇·u)1+ 2µε
where λis the Lam´e parameter and µis the shear modulus. The displacement field is u= (0, uy(y))
because of symmetry reasons (we do not expect any of the dynamic quantities to depend on the x
coordinate and also expect the horizontal displacement to be exactly zero). The velocity divergence is
then ∇·u=∂uy/∂y and the strain tensor:
ε= 0 0
0∂uy
∂y !
so that the stress tensor is:
σ= λ∂uy
∂y 0
0 (λ+ 2µ)∂uy
∂y !
∇·σ= (∂x∂y)· λ∂uy
∂y 0
0 (λ+ 2µ)∂uy
∂y != 0
(λ+ 2µ)∂2uy
∂y2!=0
ρg
so that the vertical displacement is then given by:
uy(y) = 1
2
ρg
λ+ 2µy2+αy +β
where αand βare two integration constants. We need now to use the two boundary conditions: the
first one states that the displacement is zero at the bottom, i.e. uy(y= 0) = 0 which immediately
implies β= 0. The second states that the stress at the top is zero (free surface), which implies that
∂uy/∂y(y=L) = 0 which allows us to compute α. Finally:
uy(y) = ρg
λ+ 2µ(y2
2−Ly)
The pressure is given by
p=−(λ+2
3µ)∇·u= (λ+2
3µ)ρg
λ+ 2µ(L−y) = λ+2
3µ
λ+ 2µρg(L−y) = 1 + 2µ
3λ
1+2µ/λ ρg(L−y)
In the incompressible limit, the poisson ratio is ν∼0.5. Materials are characterised by a finite Young’s
modulus E, which is related to νand λ:
λ=Eν
(1 + ν)(1 −2ν)µ=E
2(1 + ν)
It is then clear that for incompressible parameters λbecomes infinite while µremains finite. In that case
the pressure then logically converges to the well known formula:
p=ρg(L−y)
229
In what follows we set L= 1000m, ρ= 2800, ν= 0.25, E= 6 ·1010,g= 9.81.
0.000001
0.000100
0.010000
1.000000
100.000000
10000.000000
1000000.000000
100000000.000000
0.01 0.1
error
h
velocity
pressure
x2
x1
230
42 fieldstone 35: 2D analytical sol. in annulus from stream
function
We seek an exact solution to the incompressible Stokes equations for an isoviscous, isothermal fluid in
an annulus.Given the geometry of the problem, we work in polar coordinates. We denote the orthonormal
basis vectors by erand eθ, the inner radius of the annulus by R1and the outer radius by R2. Further,
we assume that the viscosity µis constant, which we set to µ= 1 we set the gravity vector to g=−grer
with gr= 1.
Given these assumptions, the incompressible Stokes equations in the annulus are [476]
Ar=∂2vr
∂r2+1
r
∂vr
∂r +1
r2
∂2vr
∂θ2−vr
r2−2
r2
∂uθ
∂θ −∂p
∂r =ρgr(411)
Aθ=∂2vθ
∂r2+1
r
∂vθ
∂r +1
r2
∂2vθ
∂θ2+2
r2
∂vr
∂θ −vθ
r2−1
r
∂p
∂θ = 0 (412)
1
r
∂(rvr)
∂r +1
r
∂vθ
∂θ = 0 (413)
Equations (413) and (414) are the momentum equations in polar coordinates while Equation (415) is the
incompressibility constraint. The components of the velocity are obtained from the stream function as
follows:
vr=1
r
∂Ψ
∂θ vθ=−∂Ψ
∂r
where vris the radial component and vθis the tangential component of the velocity vector.
The stream function is defined for incompressible (divergence-free) flows in 2D (as well as in 3D with
axisymmetry). The stream function can be used to plot streamlines, which represent the trajectories of
particles in a steady flow. From calculus it is known that the gradient vector ∇Ψ is normal to the curve
Ψ = C. It can be shown that everywhere u·∇Ψ = 0 using the formula for uin terms of Ψ which proves
that level curves of Ψ are streamlines:
u· ∇Ψ = vr
∂Ψ
∂r +vθ
1
r
∂Ψ
∂θ =1
r
∂Ψ
∂θ
∂Ψ
∂r −∂Ψ
∂r
1
r
∂Ψ
∂θ = 0
In polar coordinates the curl of a vector Ais:
∇×A=1
r∂(rAθ)
∂r −∂Ar
∂θ
Taking the curl of vector Ayields:
1
r∂(rAθ)
∂r −∂Ar
∂θ =1
r−∂(ρgr)
∂θ
Multiplying on each side by r
∂(rAθ)
∂r −∂Ar
∂θ =−∂ρgr
∂θ
If we now replace Arand Aθby their expressions as a function of velocity and pressure, we see that the
pressure terms cancel out and assuming the viscosity and the gravity vector to be constant we get: Let
us assume the following separation of variables Ψ(r, θ) = φ(r)ξ(θ). Then
vr=1
r
∂Ψ
∂θ =φξ0
rvθ=−∂Ψ
∂r =−φ0ξ
231
Let us first express Arand Aθas functions of Ψ and
Ar=∂2vr
∂r2+1
r
∂vr
∂r +1
r2
∂2vr
∂θ2−vr
r2−2
r2
∂uθ
∂θ (414)
=∂2
∂r2(φξ0
r) + 1
r
∂
∂r (φξ0
r) + 1
r2
∂2
∂θ2(φξ0
r)−1
r2(φξ0
r)−2
r2
∂
∂θ (−φ0ξ) (415)
= (φ00
r−2φ0
r2+ 2 φ
r3)ξ0+ ( φ0
r2−φ
r3)ξ0+φ
r3ξ000 −φξ0
r3+2
r2φ0ξ0(416)
=φ00ξ0
r+φ0ξ0
r2+φξ000
r3(417)
∂Ar
∂θ =φ00ξ00
r+φ0ξ00
r2+φξ0000
r3(418)
(419)
Aθ=∂2vθ
∂r2+1
r
∂vθ
∂r +1
r2
∂2vθ
∂θ2+2
r2
∂vr
∂θ −vθ
r2(420)
=∂2
∂r2(−φ0ξ) + 1
r
∂
∂r (−φ0ξ) + 1
r2
∂2
∂θ2(−φ0ξ) + 2
r2
∂
∂θ (φξ0
r)−1
r2(−φ0ξ) (421)
=−φ000ξ−φ00ξ
r−φ0ξ00
r2+2φξ00
r2+φ0ξ
r2(422)
∂(rAθ)
∂r = (423)
232
WRONG:
∂(r∆v)
∂r =∂
∂r ∂
∂r r∂v
∂r +1
r
∂2v
∂θ2(424)
=∂2
∂r2r∂v
∂r +∂
∂r 1
r
∂2v
∂θ2(425)
=∂2
∂r2r∂
∂r (−∂Ψ
∂r )+∂
∂r 1
r
∂2
∂θ2(−∂Ψ
∂r )(426)
=−∂2
∂r2r∂2Ψ
∂r2−∂
∂r 1
r
∂3Ψ
∂θ2∂r (427)
=−2∂3Ψ
∂r3−r∂4Ψ
∂r4+1
r2
∂3Ψ
∂θ2∂r −1
r
∂4Ψ
∂θ2∂r2(428)
∂∆u
∂θ =∂
∂θ 1
r
∂
∂r r∂u
∂r +1
r2
∂2u
∂θ2(429)
=∂
∂θ 1
r
∂
∂r r∂u
∂r +1
r2
∂3u
∂θ3(430)
=∂
∂θ 1
r
∂
∂r r∂
∂r (1
r
∂Ψ
∂θ )+1
r2
∂3
∂θ3(1
r
∂Ψ
∂θ ) (431)
=1
r3
∂2Ψ
∂θ2−1
r2
∂3Ψ
∂r∂θ2+1
r
∂4Ψ
∂r2∂θ2+1
r3
∂4Ψ
∂θ4(432)
Assuming the following separation of variables Ψ(r, θ) = φ(r)ξ(θ):
∂(r∆v)
∂r =−2φ000ξ−rφ0000ξ+1
r2φ0ξ00 −1
rφ00ξ00 (433)
∂∆u
∂θ =1
r3φξ00 −1
r2φ0ξ00 +1
rφ00ξ00 +1
r3φξ0000 (434)
so that
∂(r∆v)
∂r −∂∆u
∂θ =−2φ000ξ−rφ0000ξ+1
r2φ0ξ00 −1
rφ00ξ00 −1
r3φξ00 +1
r2φ0ξ00 −1
rφ00ξ00 −1
r3φξ0000
Further assuming ξ(θ) = cos(kθ) , then ξ00 =−k2ξand ξ0000 =k4ξthen
∂(r∆v)
∂r −∂∆u
∂θ =−2φ000ξ−rφ0000ξ−k21
r2φ0ξ+k21
rφ00ξ+k21
r3φξ −k21
r2φ0ξ+k21
rφ00ξ−k41
r3φξ
By choosing ρsuch that ρ=λ(r)Υ(θ) and such that ∂θΥ = ξ= cos(kθ) then we have
−2φ000ξ−rφ0000ξ−k21
r2φ0ξ+k21
rφ00ξ+k21
r3φξ −k21
r2φ0ξ+k21
rφ00ξ−k41
r3φξ =−1
ηλξgr
and then dividing by ξ: (IS THIS OK ?)
−2φ000 −rφ0000 −k21
r2φ0+k21
rφ00 +k21
r3φ−k21
r2φ0+k21
rφ00 −k41
r3φ=−1
ηλgr
−2φ000 −rφ0000 −2k21
r2φ0+ 2k21
rφ00 + (k2−k4)1
r3φ=−1
ηλgr
so
λ(r) = η
gr2φ000 +rφ0000 + 2k21
r2φ0−2k21
rφ00 −(k2−k4)1
r3φ
Also not forget Υ = 1
ksin(kθ)
233
42.1 Linking with our paper
We have
φ(r) = −rg(r) (435)
φ0(r) = −g(r)−rg0(r) = −f(r) (436)
φ00(r) = −f0(r) (437)
φ000(r) = −f00(r) (438)
φ0000(r) = −f000(r) (439)
f(r) = η0
g02f00(r) + rf000(r)+2k21
r2f(r)−2k21
rf0(r)+(k2−k4)1
r2g(r)
42.2 No slip boundary conditions
No-slip boundary conditions inside and outside impose that all components of the velocity must be zero
on both boundaries, i.e.
v(r=R1) = v(r=R2) = 0
Due to the separation of variables, and since ξ(θ) = cos(kθ) we have
u(r, θ) = 1
r
∂Ψ
∂θ =1
rφξ0=−1
rφ(r)ksin(kθ)v(r, θ) = −∂Ψ
∂r =−φ0(r)ξ=−φ0(r) cos(kθ)
It is obvious that the only way to insure no-slip boundary conditions is to have
φ(R1) = φ(R2) = φ0(R1) = φ0(R2) = 0
We could then choose
φ(r)=(r−R1)2(r−R2)2F(r) (440)
φ0(r) = 2(r−R1)(r−R2)2F(r) + 2(r−R1)2(r−R2)F(r)+(r−R1)2(r−R2)2F0(r) (441)
which are indeed identically zero on both boundaries. Here F(r) is any (smooth enough) function of r.
We would then have
Ψ(r, θ)=(r−R1)2(r−R2)2F(r) cos(kθ)
In what follows we will take F(r) = 1 for simplicity.
234
COMPUTE ffrom φand then the pressure.
42.3 Free slip boundary conditions
Before postulating the form of φ(r), let us now turn to the boundary conditions that the flow must fulfill,
i.e. free-slip on both boundaries. Two conditions must be met:
•v·n= 0 (no flow through the boundaries) which yields u(r=R1) = 0 and u(r=R2) = 0, :
1
r
∂Ψ
∂θ (r=R1, R2) = 0 ∀θ
235
which gives us the first constraint since Ψ(r, θ) = φ(r)ξ(θ):
φ(r=R1) = φ(r=R2)=0
•(σ·n)×n=0(the tangential stress at the boundary is zero) which imposes: σθr = 0, with
σθr = 2η·1
2∂v
∂r −v
r+1
r
∂u
∂θ =η∂
∂r (−∂Ψ
∂r )−1
r(−∂Ψ
∂r ) + 1
r
∂
∂θ (1
r
∂Ψ
∂θ )
Finally Ψ must fulfill (on the boundaries!):
−∂2Ψ
∂r2+1
r
∂Ψ
∂r +1
r2
∂2Ψ
∂θ2= 0
−φ00ξ+1
rφ0ξ+1
r2φξ00 = 0
or,
−φ00 +1
rφ0−k21
r2φ= 0
Note that this equation is a so-called Euler Differential Equation30. Since we are looking for a
solution φsuch that φ(R1) = φ(R2) = 0 then the 3rd term of the equation above is by definition
zero on the boundaries. We have to ensure the following equality on the boundary:
−φ00 +1
rφ0= 0 for r=R1, R2
The solution of this ODE is of the form φ(r) = ar2+band it becomes evident that it cannot satisfy
φ(r=R1) = φ(r=R2) = 0.
Separation of variables leads to solutions which cannot fulfill the free slip boundary conditions
30http://mathworld.wolfram.com/EulerDifferentialEquation.html
236
43 fieldstone 36: the annulus geometry elastic aquarium
This fieldstone was developed in collaboration with Lukas van de Wiel.
The domain is an annulus with inner radius R1and outer radius R2. It is filled with a single elastic
material characterised by a Young’s modulus Eand a Poisson ratio ν, a density ρ0. The gravity g=−g0er
is pointing towards the center of the domain.
The problem at hand is axisymmetric so that the tangential component of the displacement vector vθ
is assumed to be zero as well as all terms containing ∂θ. The components of the strain tensor are
εrr =∂vr
∂r (442)
εθθ =vr
r+1
r
∂vθ
∂θ =vr
r(443)
εrθ =1
2∂vθ
∂r −vθ
r+1
r
∂vr
∂θ = 0 (444)
so that the tensor simply is
ε=εrr εrθ
εrθ εθθ =∂vr
∂r 0
0vr
r(445)
The pressure is
p=−λ∇·v=−λ1
r
∂(rvr)
∂r (446)
and finally the stress tensor:
σ=−p1+ 2µε= λ1
r
∂(rvr)
∂r + 2µ∂vr
∂r 0
0λ1
r
∂(rvr)
∂r + 2µvr
r!(447)
The divergence of the stress tensor is given by [476]:
∇·σ=
∂σrr
∂r +σrr −σθθ
r+1
r
∂σθr
∂θ
∂σrθ
∂r +1
r
σθθ
∂θ +σrθ +σθr
r
(448)
Given the diagonal nature of the stress tensor this simplifies to (also remember that ∂θ= 0):
∇·σ=
∂σrr
∂r +σrr −σθθ
r
0
(449)
Focusing on the r-component of the stress divergence:
(∇·σ)r=∂σrr
∂r +σrr −σθθ
r(450)
=∂
∂r λ1
r
∂(rvr)
∂r + 2µ∂vr
∂r +1
rλ1
r
∂(rvr)
∂r + 2µ∂vr
∂r −λ1
r
∂(rvr)
∂r −2µvr
r(451)
=λ∂
∂r
1
r
∂(rvr)
∂r + 2µ∂2vr
∂r2+λ1
r2
∂(rvr)
∂r +2µ
r
∂vr
∂r −λ1
r2
∂(rvr)
∂r −2µvr
r2(452)
=λ(−vr
r2+1
r
∂vr
∂r +∂2vr
∂r2)+2µ∂2vr
∂r2+2µ
r
∂vr
∂r −2µvr
r2(453)
=−(2µ+λ)vr
r2+ (2µ+λ)1
r
∂vr
∂r + (2µ+λ)∂2vr
∂r2(454)
So the momentum conservation in the rdirection is
(∇·σ+ρ0g)r=−(2µ+λ)vr
r2+ (2µ+λ)1
r
∂vr
∂r + (2µ+λ)∂2vr
∂r2−ρ0g0= 0 (455)
237
or,
∂2vr
∂r2+1
r
∂vr
∂r −vr
r2=ρ0g0
λ+ 2µ(456)
We now look at the boundary conditions. On the inner boundary we prescribe vr(r=R1) = 0 while free
surface boundary conditions are prescribed on the outer boundary, i.e. σ·n= 0 (i.e. there is no force
applied on the surface).
The general form of the solution can then be obtained:
vr(r) = C1r2+C2r+C3
r(457)
with
C1=ρ0g0
3(λ+ 2µ)C2=−C1R1−C3
R2
1
C3=k1+k2
(R2
1+R2
2)(2µ+λ)+(R2
2−R2
1)λ(458)
and
k1= (2µ+λ)C1(2R2
1R3
2−R3
1R2
2)k2=λC1(R2
1R3
2−R3
1R2
2) (459)
Pressure can then be computed as follows:
p=−λ∇·v=−λ1
r
∂(rvr)
∂r =−λ1
r(3C1r2+ 2C2r)=−λ(3C1r+ 2C2) (460)
We choose R1= 2890km, R2= 6371km, g0= 9.81ms−2,ρ0= 3300, E= 6 ·1010,ν= 0.49.
-140000
-120000
-100000
-80000
-60000
-40000
-20000
0
3x106 3.5x106 4x106 4.5x106 5x106 5.5x106 6x106
radial displacement
r
0
2x1010
4x1010
6x1010
8x1010
1x1011
1.2x1011
3x106 3.5x106 4x106 4.5x106 5x106 5.5x106 6x106
radial displacement
r
radial profiles of the displacement and pressure fields
displacement and pressure fields in the domain
238
0.000001
0.000100
0.010000
1.000000
100.000000
10000.000000
0.01
error
h
velocity
pressure
x2
x1
239
44 fieldstone 37: marker advection and population control
The domain is a unit square. The Stokes equations are not solved, the velocity is prescribed everywhere
in the domain as follows:
u=−(z−0.5) (461)
v= 0 (462)
w= (x−0.5) (463)
At the moment, velocity is computed on the marker itself (rk0 algorithm). When markers are advected
outside, they are arbitrarily placed at location (-0.0123,-0.0123).
in construction.
240
45 fieldstone 38: Critical Rayleigh number
This fieldstone was developed in collaboration with Arie van den Berg.
The system is a layer of fluid between y= 0 and y= 1, with boundary conditions T(x, y = 0) = 1
and T(x, y = 1) = 0, characterized by ρ,cp,k,η0. The Rayleigh number of the system is
Ra = ρ0g0α∆T h3
η0κ
We have ∆T= 1, h= 1 and choose κ= 1 so that the Rayleigh number simplifies to Ra = ρ0g0α/η0.
The Stokes equation is
∇ · σ+
b=
0 with
b=ρg. Then the components of the this equation on the
x- and y−axis are:
(
∇ · σ)x=−ρg ·ex= 0 (464)
(
∇ · σ)y=−ρg ·ey=ρg0(465)
since g and eyare in opposite directions (g =−g0ey, with g0>0). The stream function formulation of
the incompressible isoviscous Stokes equation is then
∇4Ψ = g0
η0
∂ρ
∂x
Assuming a linearised density field with regards to temperature ρ(T) = ρ0(1 −αT ) we have
∂ρ
∂x =−ρ0α∂T
∂x
and then
∇4Ψ = −ρ0g0α
η0
g∂T
∂x =−Ra ∂T
∂x (466)
For small perturbations of the conductive state T0(y)=1−ywe define the temperature perturbation
T1(x, y) such that
T(x, y) = T0(y) + T1(x, y)
The temperature perturbation T1satisfies the homogeneous boundary conditions T1(x, y = 0) = 0 and
T1(x, y = 1) = 0. The temperature equation is
ρcp
DT
Dt =ρcp∂T
∂t +
ν·
∇T=ρcp∂T0+T1
∂t +
ν·
∇(T0+T1)=k∆(T0+T1)
and can be simplified as follows:
ρcp∂T1
∂t +
ν·
∇T0=k∆T1
since T0does not depend on time, ∆T0= 0 and we assume the nonlinear term
ν·
∇T1to be second
order (temperature perturbations and coupled velocity changes are assumed to be small). Using the
relationship between velocity and stream function vy=−∂xΨ we have v·∇T0=−vy=∂xΨ and since
κ=k/ρcp= 1 we get
∂T1
∂t −κ∆T1=−∂Ψ
∂x (467)
Looking at these equations, we immediately think about a separation of variables approach to solve these
equations. Both equations showcase the Laplace operator ∆, and the eigenfunctions of the biharmonic
operator and the Laplace operator are the same. We then pose that Ψ and T1can be written:
Ψ(x, y, t) = AΨexp(pt) exp(±ikxx) exp(±ikyy) = AΨEψ(x, y, t) (468)
T1(x, y, t) = ATexp(pt) exp(±ikxx) exp(±ikyy) = ATET(x, y, t) (469)
where kxand kyare the horizontal and vertical wave number respectively. Note that we then have
∇2Ψ = −(k2
x+k2
y)Ψ ∇2T1=−(k2
x+k2
y)T1
241
The boundary conditions on T1, coupled with a choice of a real function for the xdependence yields:
ET(x, y, t) = exp(pt) cos(kxx) sin(nπy).
from here onwards check for minus signs!
The velocity boundary conditions are vy(x, y = 0) = 0 and vy(x, y = 1) = 0 which imposes conditions
on ∂Ψ/∂x and we find that we can use the same ydependence as for T1. Choosing again for a real
function for the xdependence yields:
EΨ(x, y, t) = exp(pt) sin(kxx) sin(nπz)
We then have
Ψ(x, y, t) = AΨexp(pt) sin(kxx) sin(nπz) = AΨEψ(x, y, t) (470)
T1(x, y, t) = ATexp(pt) cos(kxx) sin(nπz) = ATET(x, y, t) (471)
In what follows we simplify notations: k=kx. Then the two PDEs become:
pT1+κ(k2+n2π2)−kAΨexp(pt) cos(kxx) sin(nπz) = kAΨEθ(472)
−RaATcos(kx) sin(nπz) + κ(k2+n2π2)2AΨ=−RaATEΨ+κ(k2+n2π2)2AΨ= 0 (473)
These equations must then be verified for all ... which leads to write:
p+ (k2+n2π2)−k
−Ra k (k2+n2π2)2 Aθ
AΨ=0
0
The determinant of such system must be nul otherwise there is only a trivial solution to the problem, i.e.
Aθ= 0 and AΨ= 0 which is not helpful. CHECK/REPHRASE
D= [p+ (k2+n2π2)](k2+n2π2)2−Ra k2= 0
or,
p=Ra k2−(k2+n2π2)3
(k2+n2π2)2
The coefficient pdetermines the stability of the system: if it is negative, the system is stable and both
Ψ and T1will decay to zero (return to conductive state). If p= 0, then the system is meta-stable, and if
p > 0 then the system is unstable and the perturbations will grow. The threshold is then p= 0 and the
solution of the above system is
242
46 fieldstone 40: Rayleigh-Taylor instability
This benchmark is carried out in [155, 230, 516] and is based on the analytical solution by Ramberg
(1968). It consists of a two-layer system driven by gravity. Free slip are imposed on the sides while
no-slip boundary conditions are imposed on the top and the bottom of the box.
Fluid 1 (ρ1, η1) of thickness h1overlays fluid 2 (ρ2, η2) of thickness h2(with h1+h2=Ly). An
initial sinusoidal disturbance of the interface between these layers is introduced and is characterised by
an amplitude ∆ and a wavelength λ=Lx/2 as shown in Figure ??.
a) b)
a) Setup of the experiment, taken from [516]; b) grid setup.
Under this condition, the velocity of the diapiric growth vyis given by the relation
vy
∆=−Kρ1−ρ2
2η2
h2g
with the dimensionless growth factor Kbeing
K=−d12
c11j22 −d12i21
and
c11 =η12φ2
1
η2(cosh 2φ1−1−2φ2
1)−2φ2
2
cosh 2φ2−1−2φ2
2
(474)
d12 =η1(sinh 2φ1−2φ1)
η2(cosh 2φ1−1−2φ2
1)+sinh 2φ2−2φ2
cosh 2φ2−1−2φ2
2
(475)
i21 =η1φ2(sinh 2φ1+ 2φ1)
η2(cosh 2φ1−1−2φ2
1)+φ2(sinh 2φ2+ 2φ2)
cosh 2φ2−1−2φ2
2
(476)
j22 =η12φ2
1φ2
η2(cosh 2φ1−1−2φ2
1)−2φ3
2
cosh 2φ2−1−2φ2
2
(477)
φ1=2πh1
λ(478)
φ2=2πh2
λ(479)
243
47 fieldstone 42: 1D diffusion
This is the simplest case for a FE code: a 1D (temperature) diffusion problem. It puts into practice what
is presented in section 5.1. The initial temperature profile is as follows:
T(x, t = 0) = 200 x<Lx/2T(x, t = 0) = 100 x≥Lx/2
The properties of the material are as follows: ρ= 3000, k= 3, Cp= 1000 and the domain size is
Lx= 100km. Boundary conditions are T(t, x = 0) = 200◦Cand T(t, x =Lx) = 100◦C. There are nelx
elements and nnx nodes. All elements are hx long. The code will carry out nstep timesteps of length dt
or will stop before that when steady state is reached. The code structure is summarised hereunder:
245
48 fieldstone: Gravity: buried sphere
Before you proceed further, please read :
http://en.wikipedia.org/wiki/Gravity_anomaly
http://en.wikipedia.org/wiki/Gravimeter
Let us consider a vertical domain Lx ×Ly where Lx= 1000km and Ly = 500km. This domain
is discretised by means of a grid which counts nnp =nnx ×nny nodes. This grid then counts nel =
nelx ×nely = (nnx −1) ×(nny −1) cells. The horizontal spacing between nodes is hx and the vertical
spacing is hy.
Assume that this domain is filled with a rock type which mass density is given by ρmedium =
3000kg/m3, and that there is a circular inclusion of another rock type (ρsphere = 3200kg/m3) at lo-
cation (xsphere,ysphere) of radius rsphere. The density in the system is then given by
ρ(x, y) = ρsphere inside the circle
ρmedium outside the circle
Let us now assume that we place nsurf gravimeters at the surface of the model. These are placed
equidistantly between coordinates x= 0 and coordinates x=Lx. We will use the arrays xsurf and ysurf
to store the coordinates of these locations. The spacing between the gravimeters is δx=Lx/(nsurf −1).
At any given point (xi, yi) in a 2D space, one can show that the gravity anomaly due to the presence
of a circular inclusion can be computed as follows:
g(xi, yi)=2πG(ρsphere −ρ0)R2yi−ysphere
(xi−xsphere)2+ (yi−ysphere)2(480)
where rsphere is the radius of the inclusion, (xsphere, ysphere) are the coordinates of the center of the
inclusion, and ρ0is a reference density.
However, the general formula to compute the gravity anomaly at a given point (xi, yi) in space due
to a density anomaly of any shape is given by:
g(xi, yi)=2GZ ZΩ
∆ρ(x, y)(y−yi)
(x−xi)2+ (y−yi)2dxdy (481)
where Ω is the area of the domain on which the integration is to be carried out. Furthermore the density
anomaly can be written : ∆ρ(x, y) = ρ(x, y)−ρ0. We can then carry out the integration for each cell
and sum their contributions:
g(xi, yi)=2G
nel
X
ic=1 Z ZΩe
(ρ(x, y)−ρ0)(y−yi)
(x−xi)2+ (y−yi)2dxdy (482)
where Ωeis now the area of a single cell. Finally, one can assume the density to be constant within each
cell so that ρ(x, y)→ρ(ic) and RRΩedxdy →hx ×hy and then
g(xi, yi) = 2G
nel
X
ic=1
(ρ(ic)−ρ0)(y(ic)−yi)
(x(ic)−xi)2+ (y(ic)−yi)2sxsy(483)
We will then use the array gsurf to store the value of the gravity anomaly measured at each gravimeter
at the surface.
246
To go further
•explore the effect of the size of the inclusion on the gravity profile.
•explore the effect of the ρ0value.
•explore the effect of the grid resolution.
•measure the time that is required to compute the gravity. How does this time vary with nsurf ?
how does it vary when the grid resolution is doubled ?
•Assume now that ρ2< ρ1. What does the gravity profile look like ?
•what happens when the gravimeters are no more at the surface of the Earth but in a satellite ?
•if you feel brave, redo the whole exercise in 3D...
247
49 Problems, to do list and projects for students
•Darcy flow. redo WAFLE (see http://cedricthieulot.net/wafle.html)
•carry out critical Rayleigh experiments for various geometries/aspect ratios. Use Arie’s notes.
•Newton solver
•Corner flow
•elasticity with markers
•Indentor/punch with stress b.c. ?
•chunk grid
•read in crust 1.0 in 2D on chunk
•compute gravity based on tetrahedra
•compare Q2 with Q2-serendipity
•NS a la http://ww2.lacan.upc.edu/huerta/exercises/Incompressible/Incompressible Ex2.htm
•produce example of mckenzie slab temperature
•write about impose bc on el matrix
•constraints
•discontinuous galerkin
•formatting of code style
•navier-stokes ? (LUKAS) use dohu matlab code
•nonlinear poiseuille
•Finish nonlinear cavity case5.
•write about mappings
•write about stream functions
•free surface
•zaleski disk advection
•better yet simple matrix storage ?
•write Scott about matching compressible2 setup with his paper
•deal with large matrices.
•compositions, marker chain
•free-slip bc on annulus and sphere . See for example p540 Gresho and Sani book.
•non-linear rheologies (two layer brick spmw16, tosn15)
•Picard vs Newton
•including phase changes (w. R. Myhill)
•compute strainrate in middle of element or at quad point for punch?
•GEO1442 code
248
•GEO1442 indenter setup in plane ?
•in/out flow on sides for lith modelling
•Fehlberg RK advection
•redo puth17 2 layer experiment
•create stone for layeredflow (see folder one up)
•SIMPLE a la p667 [311]
•implement mms5 7.4.5
•implement mms7 7.4.7
•implement/monitor div v
•shape fct, trial fct, basis fct vs test fct doc
•Delaunay triangulation, Voronoi, stripack
•symmetric vs gradient formulation of Stokes
•write/draw the whole FEM process for a 4x3 grid for compgeo
•Sphere drag in a visco-plastic fluid [153]
•mention Lattice-Boltzmann in geosciences [289]
•lukas’ 2D and 3D benchmark
•ROTATING disc
•cylindrical footing on (elasto)-viscous medium - analytical solution, Haskell, etc ...
Why do I have to promise where I am going while I am not there yet?
You can’t google something you don’t know exists.
You can be correct or you can get stuff done
249
A Three-dimensional applications
In the following table I list many papers which showcase high-resolution models of geodynamical processes
(subduction, rifting, mantle flow, plume transport, ...). Given the yearly output of our community and
the long list of journal in which research can be disseminated, this list can not be exhaustive.
Ref. topic resolution
[30] Small-scale sublithospheric convection in the Pacific 448 ×56 ×64
[497] Migration and morphology of subducted slabs in the upper mantle 50 ×50 ×25
[442] Subduction scissor across the South Island of New Zealand 17 ×9×9
[385] Influence of a buoyant oceanic plateau on subduction zones 80 ×40 ×80
[114] Subduction dynamics, origin of Andean orogeny and the Bolivian orocline 96 ×96 ×64
[173] Feedback between rifting and diapirism, ultrahigh-pressure rocks exhumation 100 ×64 ×20
[13] Numerical modeling of upper crustal extensional systems 160 ×160 ×12
[14] Rift interaction in brittle-ductile coupled systems 160 ×160 ×23
[343] Kinematic interpretation of the 3D shapes of metamorphic core complexes 67 ×67 ×33
[304] Role of rheology and slab shape on rapid mantle flow: the Alaska slab edge 960 ×648 ×160
[113] Complex mantle flow around heterogeneous subducting oceanic plates 96 ×96 ×64
[81] Oblique rifting and continental break-up 150 ×50 ×30
[52] Influence of mantle plume head on dynamics of a retreating subduction zone 80 ×40 ×80
[80] Rift to break-up evolution of the Gulf of Aden 83 ×83 ×40
[82] Thermo-mechanical impact of plume arrival on continental break-up 100 ×70 ×20
[115] Subduction and slab breakoff controls on Asian indentation tectonics 96 ×96 ×64
[181] Modeling of upper mantle deformation and SKS splitting calculations 96 ×64 ×96
[470] Backarc extension/shortening, slab induced toroidal/poloidal mantle flow 352 ×80 ×64
[372] Sediment transports in the context of oblique subduction modelling 500 ×164 ×100
[605] Crustal growth at active continental margins 404 ×164 ×100
[345] Dynamics of India-Asia collision 257 ×257 ×33
[570] Strain-partitioning in the Himalaya 256 ×256 ×40
[355] Collision of continental corner from 3-D numerical modeling 500 ×340 ×164
[436] Dependence of mid-ocean ridge morphology on spreading rate 196 ×196 ×100
[180] Mid mantle seismic anisotropy around subduction zones 197 ×197 ×53
[281] Oblique rifting of the Equatorial Atlantic 120 ×80 ×20
[395] Dynamics of continental accretion 256 ×96 ×96
[461] Thrust wedges: infl. of decollement strength on transfer zones 309 ×85 ×149
[101] Asymmetric three-dimensional topography over mantle plumes 500 ×500 ×217
[521] modelled crustal systems undergoing orogeny and subjected to surface processes 96 ×32 ×14
[358] Thermo-mechanical modeling ontinental rifting and seafloor spreading 197 ×197 ×197
250
B Codes in geodynamics
In what follows I make a quick inventory of the main codes of computational geodynamics, for crust,
lithosphere and/or mantle modelling.
in order to find all CIG-codes citations go to: https://geodynamics.org/cig/news/publications-refbase/
•ABAQUS [222] [340] [378] [404] [422]
•ADELI [278] [556] [63] [64] [220] [246] [564] [117] [118]
•ASPECT
This code is hosted by CIG at https://geodynamics.org/cig/software/aspect/
[32] [339] [24] [524] [148] [212] [595] [280] [146] [282] [459] [460] [23] [517] [78] [413] [504] [592] [147]
[415] [248] [283] [213] [421] [433] [77] [36] [498] [137] [364]
•CHIC [410]
•CitcomS and CITCOMCU
These codes are hosted by CIG at https://geodynamics.org/cig/software/citcomcu/ and
https://geodynamics.org/cig/software/citcoms/.
[492] [398] [598] [543] [601] [274] [56] [507] [542] [134] [57] [490] [58] [43] [426] [505] [46] [135] [59]
[600] [376] [31] [456] [400] [133] [247] [211] [599] [287] [357] [20] [594] [17] [194] [97] [92] [552] [30] [98]
[593] [44] [348] [539] [352] [362] [304] [60] [66] [299] [603] [491] [286] [70] [71] [305] [446] [412] [21]
[136] [193] [91] [316] [22] [563] [479] [6] [371] [606] [69] [67] [482] [149] [540] [565] [562] [561] [277]
[509] [353] [569] [568] [370] [200] [279] [285] [326] [386]
cross check with CIG database
•CONMAN This code is hosted by CIG at https://geodynamics.org/cig/software/conman/
[330] [302] [327] [328] [303] [45] [329]
•CONVRS [589] [588]
•DOUAR
[75] [520] [582] [76] [367] [401] [570] [407]
•DYNEARTHSOL [124]
•M-DOODS [583] [581]
•FENICS [11]
•GAIA
•GALE
This code is hosted by CIG at https://geodynamics.org/cig/software/gale/
[186] [55] [141] [343] [21]
ADD:
Cruz, L.; Malinski, J.; Hernandez, M.; Take, A.; Hilley, G. Erosional control of the kinematics of the
Aconcagua fold-and-thrust belt from numerical simulations and physical experiments 2011 Geology
Goyette, S.; Takatsuka, M.; Clark, S.; Mller, R.D.; Rey, P.; Stegman, D.R. Increasing the usability
and accessibility of geodynamic modelling tools to the geoscience community: UnderworldGUI 2008
Visual Geosciences
Li, Y.; Qi, J. Salt-related Contractional Structure and Its Main Controlling Factors of Kelasu
Structural Zone in Kuqa Depression: Insights from Physical and Numerical Experiments 2012
Procedia Engineering
•GTECTON [256] [257] [87] [88] [258] [197] [366] [27] [28] [379]
251
•ELEFANT
[524] [369] [90] [342] [517] [429]
•ELLIPSIS
[396] [414] [397] [164] [416] [442] [352] [349]
•FANTOM
[516] [13] [14] [15] [178] [521] [176] [177]
FDCON [175] [203] [202]
•FLUIDITY [151] [210]
•IFISS: Incompressible Flow Iterative Solution Solver is a MATLAB package that is a very useful
tool for people interested in learning about solving PDEs. IFISS includes built-in software for 2D
versions of: the Poisson equation, the convection-diffusion equation, the Stokes equations and the
Navier-Stokes equations.
https://personalpages.manchester.ac.uk/staff/david.silvester/ifiss/
•the I2(3)E(L)VIS code
[239][240][238] [241][242][236] [96] [85][228][253][232] [229][252] [473][231][529][182][604] [233] [226][408]
[161][163][356][227][235] [138][160][591] [355][403][372][536][535][605][165][234][383] [162][436][461][558][29][359][499][377]
[101][254][29][537] [159][530][462][237][462] [3][373][192] [335]
•I3MG [180]
•LAMEM [473] [319] [344] [387] [345] [132] [188] [187] [434] [189] [131] [320]
•LAPEX2D [487] [85] [25] [473] [488]
•LITMOD [204] [4] [5] [205]
•MARC [406] [405]
•MILAMIN [145] [584] [217] [368] [218] [514] [308] [382]
•PARAVOZ/FLAMAR [430] [103] [99] [26] [130] [275] [223] [273] [225] [525] [102] [579] [104] [580]
[221] [582] [19] [220] [270] [219] [183] [198] [209] [100] [577] [384] [216] [156]
•PINK3D [559]
•PLASTI [206]
•PTATIN [423] [2] [388] [314] [313]
•RHEA [105] [494] [10] [107]
•SAMOVAR [170]
•SEPRAN [531] [557] [128] [541] [548] [549] [550] [551] [478] [360] [361] [547] [74] [73] [428] [555] [532]
[501] [545] [533] [47] [121] [18] [122] [399] [534] [596]
•SLIM3D
[431] [450] [81] [82] [80] [79] [281] [334] [129]
•SLOMO [317]
SNAC [125]
•SOPALE
[573] [37] [207] [171] [41] [571] [439] [42] [39] [296] [440] [295] [553] [574] [444] [40] [441] [438] [172]
[215] [214] [298] [437] [481] [297] [143] [394] [480] [566] [567] [322] [38] [89] [260] [486] [9] [8] [261]
[443] [142] [112] [294] [262] [263] [333] [259] [306] [110] [120] [190] [191] [255] [264] [332] [409] [307]
[250] [12] [111] [284] [363] [109]
252
•STAGYY [458] [587] [139]
•SUBMAR [381] [380] [457]
•SULEC SULEC is a finite element code that solves the incompressible Navier-Stokes equations for
slow creeping flows. The code is developed by Susan Ellis (GNS Sciences, NZ) and Susanne Buiter
(NGU).
[447] [173] [86] [511] [138] [269] [243] [244] [448] [402] [611] [512]
•TERRA [95] [94] [424] [576] [575] [150] [538]
•YACC [524] [523]
•UNDERWORLD 1&2 [496] [397] [469] [347] [417] [116] [385] [497] [495] [185] [114] [113] [52] [470]
[181] [184] [445] [53] [471] [484] [485] [418] [331] [391] [466] [586]
•VEMAN [54]
253
C Matrix properties
C.1 Symmetric matrices
Any symmetric matrix has only real eigenvalues, is always diagonalizable, and has orthogonal eigenvectors.
A symmetric N×Nreal matrix Mis said to be
•positive definite if x ·M·x > 0 for every non-zero vector x of n real numbers. All the eigenvalues
of a Symmetric Positive Definite (SPD) matrix are positive. If A and B are positive definite, then
so is A+B. The matrix inverse of a positive definite matrix is also positive definite. An SPD matrix
has a unique Cholesky decomposition. In other words the matrix Mis positive definite if and only
if there exists a unique lower triangular matrix L, with real and strictly positive diagonal elements,
such that M=LLT(the product of a lower triangular matrix and its conjugate transpose). This
factorization is called the Cholesky decomposition of M.
•positive semi-definite if x ·M·x ≥0
•negative definite if x ·M·x < 0
•negative semi-definite if x ·M·x ≤0
The Stokes linear system K G
GT0·v
p=f
g
is indefinite (i.e. it has positive as well as negative eigenvalues).
A square matrix that is not invertible is called singular or degenerate. A square matrix is singular if
and only if its determinant is 0. Singular matrices are rare in the sense that if you pick a random square
matrix, it will almost surely not be singular.
C.2 Schur complement
From wiki. In linear algebra and the theory of matrices, the Schur complement of a matrix block (i.e.,
a submatrix within a larger matrix) is defined as follows. Suppose A,B,C,Dare respectively p×p,
p×q,q×pand q×qmatrices, and Dis invertible. Let
M=A B
C D
so that Mis a (p+q)×(p+q) matrix. Then the Schur complement of the block Dof the matrix Mis
the p×pmatrix
S=A−B·D−1·C
Application to solving linear equations: The Schur complement arises naturally in solving a system of
linear equations such as
A·x +B·y =
f
C·x +D·y =g
where x,
fare p-dimensional vectors, y,g are q-dimensional vectors, and A,B,C,Dare as above.
Multiplying the bottom equation by B·D−1and then subtracting from the top equation one obtains
(A−B·D−1·C)·x =
f−B·D−1·g
Thus if one can invert Das well as the Schur complement of D, one can solve for x, and then by using the
equation C·x+D·y =g one can solve for y. This reduces the problem of inverting a (p+q)×(p+q) matrix
to that of inverting a p×pmatrix and a q×qmatrix. In practice one needs Dto be well-conditioned in
order for this algorithm to be numerically accurate.
Considering now the Stokes system:
K G
GT−C·v
p =
f
g
254
Factorising for p we end up with a velocity-Schur complement. Solving for p in the second equation
and inserting the expression for p into the first equation we have
Sv·v =
fwith Sv=K+G·C−1·GT
Factorising for v we get a pressure-Schur complement.
Sp·p =GT·K−1·
fwith Sp=GT·K−1·G+C
255
D Dont be a hero - unless you have to
What follows was published online on July 17th, 2017 at https://blogs.egu.eu/divisions/gd/2017/
07/19/dont-be-a-hero-unless-you-have-to/ It was written by me and edited by Iris van Zelst, at
the time PhD student at ETH Z¨urich.
In December 2013, I was invited to give a talk about the ASPECT code [1] at the American Geological
Union conference in San Francisco. Right after my talk, Prof. Louis Moresi took the stage and gave a
talk entitled: Underworld: What we set out to do, How far did we get, What did we Learn?
The abstract went as follows:
”Underworld was conceived as a tool for modelling 3D lithospheric deformation coupled with the
underlying / surrounding mantle flow. The challenges involved were to find a method capable of repre-
senting the complicated, non-linear, history dependent rheology of the near surface as well as being able
to model mantle convection, and, simultaneously, to be able to solve the numerical system efficiently. []
The elegance of the method is that it can be completely described in a couple of sentences. However,
there are some limitations: it is not obvious how to retain this elegance for unstructured or adaptive
meshes, arbitrary element types are not sufficiently well integrated by the simple quadrature approach,
and swarms of particles representing volumes are usually an inefficient representation of surfaces.”
Aside from the standard numerical modelling jargon, Louis used a term during his talk which I thought
at the time had a nice ring to it: hero codes. In short, I believe he meant the codes written essentially
by one or two people who at some point in time spent great effort into writing a code (usually choosing
a range of applications, a geometry, a number of dimensions, a particular numerical method to solve the
relevant PDEs(1), and a tracking method for the various fields of interest).
In the long list of Hero codes, one could cite (in alphabetical order) CITCOM [1], DOUAR [8],
FANTOM [2], IELVIS [5], LaMEM [3], pTatin [4], SLIM3D [10], SOPALE [7], StaggYY [6], SULEC [11],
Underworld [9], and I apologise to all other heroes out there whom I may have overlooked. And who
does not want to be a hero? The Spiderman of geodynamics, the Superwoman of modelling?
Louis’ talk echoed my thoughts on two key choices we (computational geodynamicists) are facing:
Hero or not, and if yes, what type?
Hero or not?
Speaking from experience, it is an intense source of satisfaction when peer-reviewed published results
are obtained with the very code one has painstakingly put together over months, if not years. But is it
worth it?
On the one hand, writing one owns code is a source of deep learning, a way to ensure that one
understands the tool and knows its limitations, and a way to ensure that the code has the appropriate
combination of features which are necessary to answer the research question at hand. On the other hand,
it is akin to a journey; a rather long term commitment; a sometimes frustrating endeavour, with no
guarantee of success. Let us not deny it many a student has started with one code only to switch to
plan B sooner or later. Ultimately, this yiels a satisfactory tool with often little to no perennial survival
over the 5 year mark, a scarce if at all existent documentation, and almost always not compliant with
the growing trend of long term repeatability. Furthermore, the resulting code will probably bear the
marks of its not-all-knowing creator in its DNA and is likely not to be optimal nor efficient by modern
computational standards.
This brings me to the second choice: elegance & modularity or taylored code & raw performance?
Should one develop a code in a very broad framework using as much external libraries as possible or is
there still space for true heroism?
It is my opinion that the answer to this question is: both. The current form of heroism no more lies
in writing ones own FEM(2)/FDM(3) packages, meshers, or solvers from scratch, but in cleverly taking
advantage of state-of-the-art packages such as for example p4est [15] for Adaptive Mesh Refinement,
PetSc [13] or Trilinos [14] for solvers, Saint Germain [17] for particle tracking, deal.ii [12] or Fenics [16]
for FEM, and sharing their codes through platforms such as svn, bitbucket or github.
In reality, the many different ways of approaching the development or usage of a (new) code is linked
to the diversity of individual projects, but ultimately anyone who dares to touch a code (let alone write
one) is a hero in his/her own right: although (super-)heroes can be awesome on their own, they often
256
complete each other, team up and join forces for maximum efficiency. Let us all be heroes, then, and join
efforts to serve Science to the best of our abilities.
Abbreviations
(1) PDE: Partial Differential Equation
(2) FEM: Finite Element Method
(3) FDM: Finite Difference Method
References
[1] Zhong et al., JGR 105, 2000;
[2] Thieulot, PEPI 188, 2011;
[3] Kaus et al., NIC Symposium proceedings, 2016;
[4] May et al, CMAME 290, 2015
[5] Gerya and Yuen, PEPI 163, 2007
[6] Tackley, PEPI 171, 2008
[7] Fullsack, GJI 120, 1995
[8] Braun et al., PEPI 171, 2008
[9] http://www.underworldcode.org/
[10] Popov and Sobolev, PEPI 171, 2008
[11] http://www.geodynamics.no/buiter/sulec.html
[12] Bangerth et al., J. Numer. Math., 2016; http://www.dealii.org/
[13] http://www.mcs.anl.gov/petsc/
[14] https://trilinos.org/
[15] Burstedde et al., SIAM journal on Scientific Computing, 2011; http://www.p4est.org/
[16] https://fenicsproject.org/
[17] Quenette et al., Proceedings 19th IEEE, 2007
257
E A FANTOM, an ELEFANT and a GHOST
While a post-doctoral researcher at Bergen University I developed the FANTOM code. Here is what
other people and I have published with it:
•FANTOM : two- and three-dimensional numerical modelling of creeping flows for the solution of
geological problems, C. Thieulot, Physics of the Earth and Planetary Interiors, 188, 2011.
•Three-dimensional numerical modeling of upper crustal extensional systems, V. Allken, R.S. Huis-
mans and C. Thieulot, JGR 116, 2011. https://doi:10.1029/2011JB008319
•Factors controlling the mode of rift interaction in brittle-ductile coupled systems: A 3D numerical
study, V. Allken, R.S. Huismans and C. Thieulot, Geochem. Geophys. Geosyst. 13(5), 2012.
https://doi:10.1029/2012GC004077
•3D numerical modelling of graben interaction and linkage: a case study of the Canyonlands grabens,
Utah, V. Allken, R.S. Huismans, Haakon Fossen and C. Thieulot, Basin Research, 25, 1-14, 2013.
https://doi:10.1111/bre.12010
258
•Three-dimensional numerical simulations of crustal systems undergoing orogeny and subjected to
surface processes, C. Thieulot, P. Steer and R.S. Huismans, Geochem. Geophys. Geosyst., 15,
2014. doi:10.1002/2014GC005490
•Extensional inheritance and surface processes as controlling factors of mountain belt structure, Z.
Erd¨os, R.S. Huismans, P. van der Beek, and C. Thieulot, J. Geophys. Res. Solid Earth, 119, 2014.
doi:10.1002/2014JB011408
•First-order control of syntectonic sedimentation on crustal-scale structure of mountain belts, Z.
Erd¨os, R.S. Huismans, P. van der Beek, J. Geophys. Res. Solid Earth, 120, 5362-5377, 2015.
doi:10.1002/2014JB011785
•Control of increased sedimentation on orogenic fold-and-thrust belt structure - insights into the
evolution of the Western Alps, Z. Erd¨os, R.S. Huismans and P. van der Beek, Solid Earth, 10,
391-404, 2019. https://doi.org/10.5194/se-10-391-2019
Upon my arrival at Utrecht University in 2012 I started working an a more flexible code, called
ELEFANT, which has since very much diverged from FANTOM.
•The effect of obliquity on temperature in subduction zones: insights from 3-D numerical modeling,
A. Plunder, C. Thieulot and D.J.J. van Hinsbergen, Solid Earth 9, 759-776, 2018. https://doi.
org/10.5194/se-9-759-2018
•Analytical solution for viscous incompressible Stokes flow in a spherical shell, C. Thieulot, Solid
Earth 8, 1181-1191, 2017. https://doi.org/10.5194/se-8-1181-2017
259
•Lithosphere erosion and continental breakup: interaction of extension, plume upwelling and melting,
A. Lavecchia, C. Thieulot, F. Beekman, S. Cloetingh and S. Clark, E.P.S.L. 467, p89-98, 2017.
•Benchmarking numerical models of brittle thrust wedges, Susanne J.H. Buiter, Guido Schreurs,
Markus Albertz, Taras V. Gerya, Boris Kaus, Walter Landry, Laetitia le Pourhiet, Yury Mishin,
David L. Egholm, Michele Cooke, Bertrand Maillot, Cedric Thieulot, Tony Crook, Dave May,
Pauline Souloumiac, Christopher Beaumont Journal of Structural Geology 92, p140-177, 2016.
https://doi:10.1016/j.jsg.2016.03.003
•A community benchmark for viscoplastic thermal convection in a 2-D square box, N. Tosi, C. Stein,
L. Noack, C. Huettig, P. Maierova, H. Samuel, D.R. Davies, C.R. Wilson, S.C. Kramer, C. Thieulot,
A. Glerum, M. Fraters, W. Spakman, A. Rozel, P.J. Tackley, Geochem. Geophys. Geosyst. 16,
doi:10.1002/2015GC005807, 2015.
•Dynamics of intraoceanic subduction initiation: 1. Oceanic detachment fault inversion and the
formation of supra-subduction zone ophiolites, M. Maffione, C. Thieulot, D.J.J. van Hinsbergen, A.
Morris, O. Pluemper and W. Spakman, Geochem. Geophys. Geosyst. 16, p1753-1770, 2015.
•GHOST: Geoscientific Hollow Sphere Tessellation, C. Thieulot, Solid Earth, 9, 11691177, 2018.
https://doi.org/10.5194/se-9-1169-2018
260
F Some useful Python commands
F.1 Sparse matrices
So far, the best way I have found to deal with sparse matrices is to declare the matrix as a ’lil matrix’
(linked list).
from s c i p y . s p a r s e import c s r m a t r i x , l i l m a t r i x
A mat = l i l m a t r i x ( ( Nfem , Nfem) , dtype=np . f l o a t 6 4 )
One then adds terms to it as if it was a full/dense matrix. Once the assembly is done, the conversion
to CSR format is trivial:
A mat=A mat . t o c s r ( )
Finally the solver can be called:
s o l=s p s . l i n a l g . s p s o l v e ( A mat , r h s )
F.2 condition number
if the matrix has been declared as lil matrix, first convert it to a dense matrix:
A mat=A mat . den se ( )
The condition number of the matrix is simply obtained as follows:
from numpy import l i n a l g as LA
p r i n t (LA . cond ( A mat ) )
261
G Some useful maths
G.1 Inverse of a 3x3 matrix
Let us assume we wish to solve the system A·
X=
b, with
X= (x, y). Then the solution is given by
The solution is given by
x=1
det(A)
b1a21
b2a22 y=1
det(A)
a11 b1
a21 b2
G.2 Inverse of a 3x3 matrix
Let us consider the 3x3 matrix M
M=
Mxx Mxy Mxz
Myx Myy Myz
Mzx Mzy Mzz
1. Find det(M), the determinant of the Matrix M. The determinant will usually show up in the
denominator of the inverse. If the determinant is zero, the matrix won’t have an inverse.
2. Find MT, the transpose of the matrix. Transposing means reflecting the matrix about the main
diagonal.
MT=
Mxx Myx Mzx
Mxy Myy Mzy
Mxz Myz Mzz
3. Find the determinant of each of the 2x2 minor matrices. For instance ˜
Mxx =MyyMzz −Myz Mzy,
or ˜
Mxz =MxyMyz −MxzMyy.
4. assemble the ˜
Mmatrix:
˜
M=
+˜
Mxx −˜
Mxy +˜
Mxz
−˜
Myx +˜
Myy −˜
Myz
+˜
Mzx −˜
Mzy +˜
Mzz
5. the inverse of Mis then given by
M1=1
det(M)˜
M
Another approach which of course is equivalent to the above is Cramer’s rule. Let us assume we wish
to solve the system A·
X=
b, with
X= (x, y, z). Then the solution is given by
x=1
det(M)
b1a12 a13
b2a22 a23
b3a32 a33
y=1
det(M)
a11 b1a13
a21 b2a23
a31 b3a33
z=1
det(M)
a11 a12 b1
a21 a22 b2
a31 a32 b3
262
References
[1] PhD thesis.
[2] pTatin3D: High-Performance Methods for Long-Term Lithospheric Dynamics, 2014.
[3] A. Koptev aand E. Burov, E. Calais, S. Leroy, T. Gerya, L. Guillou-Frottier, and S. Cloetingh.
Contrasted continental rifting via plume-craton interaction: Applications to Central East African
Rift. Geoscience Frontiers, 7:221–236, 2016.
[4] J. C. Afonso, M. Fernandez, G. Ranalli, W.L. Griffin, and J.A.D. Connolly. Integrated geophysical-
petrological modeling of the lithosphere and sublithospheric upper mantle: Methodology and ap-
plications. Geochem. Geophys. Geosyst., 9(5):doi:10.1029/2007GC001834, 2008.
[5] J.C. Afonso, G. Ranalli, and M. Fernandez. Density structure and buoyancy of the oceanic litho-
sphere revisited. Geophys. Res. Lett., 34:L10302, 2007.
[6] R. Agrusta, J. van Hunen, and S. Goes. The effect of metastable pyroxene on the slab dynamics.
Geophys. Res. Lett., 41:8800–8808, 2014.
[7] M. Albers. A local mesh refinement multigrid method for 3D convection problems with strongly
variable viscosity. J. Comp. Phys., 160:126–150, 2000.
[8] M. Albertz and C. Beaumont. An investigation of salt tectonic structural styles in the Scotian Basin,
offshore Atlantic Canada: 2. Comparison of observations with geometrically complex numerical
models. Tectonics, 29(TC4018), 2010.
[9] M. Albertz, C. Beaumont, J.W. Shimeld, S.J. Ingsand, and S. Gradmann. An investigation of salt
tectonic structural styles in the Scotian Basin, offshore Atlantic Canada: Part 1, comparison of
observations with geometrically simple numerical models. Tectonics, 29, 2010.
[10] L. Alisic, M. Gurnis, G. Stadler, C. Burstedde, and O. Ghattas. Multi-scale dynamics and rheology
of mantle flow with plates. J. Geophys. Res., 117, 2012.
[11] L. Alisic, J.F. Rudge, R.F. Katz, G.N. Wells, and S. Rhebergen. Compaction around a rigid,
circular inclusion in partially molten rock. J. Geophys. Res., 119:5903–5920, 2014.
[12] J. Allen and C. Beaumont. Continental Margin Syn-Rift Salt Tectonics at Intermediate Width
Margins. Basin Research, page doi: 10.1111/bre.12123, 2014.
[13] V. Allken, R. Huismans, and C. Thieulot. Three dimensional numerical modelling of upper crustal
extensional systems. J. Geophys. Res., 116:B10409, 2011.
[14] V. Allken, R. Huismans, and C. Thieulot. Factors controlling the mode of rift interaction in brittle-
ductile coupled systems: a 3d numerical study. Geochem. Geophys. Geosyst., 13(5):Q05010, 2012.
[15] V. Allken, R.S. Huismans, H. Fossen, and C. Thieulot. 3D numerical modelling of graben interaction
and linkage: a case study of the Canyonlands grabens, Utah. Basin Research, 25:1–14, 2013.
[16] J.D. Anderson. Computational Fluid Dynamics. McGraw-Hill, 1995.
[17] E.R. Andrews and M.I. Billen. Rheologic controls on the dynamics of slab detachment. Tectono-
physics, 464:60–69, 2009.
[18] A. Androvicova, H. ˇ
C´ıˇzkov´a, and A. van den Berg. The effects of rheological decoupling on slab
deformation in the Earth’s upper mantle. Stud. Geophys. Geod., 57:460–481, 2013.
[19] S. Angiboust, S. Wolf, E. Burov, P. Agard, and P. Yamato. Effect of fluid circulation on
subduction interface tectonic processes: Insights from thermo-mechanical numerical modelling.
Earth Planet. Sci. Lett., 357-358:238–248, 2012.
[20] J.J. Armitage, T.J. Henstock, T.A. Minshull, and J.R. Hopper. Lithospheric controls on melt
production during continental breakup at slow rates of extension: Application to the North Atlantic.
Geochem. Geophys. Geosyst., 10(6), 2009.
263
[21] P.-A. Arrial and M.I. Billen. Influence of geometry and eclogitization on oceanic plateau subduction
.Earth Planet. Sci. Lett., 363:34–43, 2013.
[22] P.A. Arrial, N. Flyer, G.B. Wright, and L.H. Kellogg. On the sensitivity of 3-D thermal convection
codes to numerical discretization: a model intercomparison. Geosci. Model Dev., 7:2065–2076, 2014.
[23] J. Austermann, J. X. Mitrovica, P. Huybers, and A. Rovere. Detection of a dynamic topography
signal in last interglacial sea-level records. Science Advances, 3(7):1700457, 2017.
[24] J. Austermann, D. Pollard, J. X. Mitrovica, R. Moucha, A. M. Forte, R. M. DeConto, D. B. Rowley,
and M. E. Raymo. The impact of dynamic topography change on antarctic ice sheet stability during
the mid-pliocene warm period. Geology, 43(10):927–930, 2015.
[25] A. Babeyko and S. Sobolev. High-resolution numerical modeling of stress distribution in visco-
elasto-plastic subducting slabs. Lithos, 103:205–216, 2008.
[26] A.Yu. Babeyko, S.V. Sobolev, R.B. Trumbull, O. Oncken, and L.L. Lavier. Numerical
models of crustal scale convection and partial melting beneath the Altiplano-Puna plateau.
Earth Planet. Sci. Lett., 199:373–388, 2002.
[27] M. Baes, R. Govers, and R. Wortel. Subduction initiation along the inherited weakness zone at the
edge of a slab: Insights from numerical models. Geophys. J. Int., 184:991–1008, 2011.
[28] M. Baes, R. Govers, and R. Wortel. Switching between alternative responses of the lithosphere to
continental collision. Geophys. J. Int., 2011.
[29] B. Baitsch-Ghirardello, Taras V. Gerya, and J.-P. Burg. Geodynamic regimes of intra-oceanic
subduction: Implications for arc extension vs. shortening processes. Gondwana Research, 25:546–
560, 2014.
[30] M.D. Ballmer, G. Ito, J. van Hunen, and P.J. Tackley. Small-scale sublithospheric convection
reconcilies geochemistry and geochronology of ’Superplume’ volcanism in th western and south
pacific. Earth Planet. Sci. Lett., 290:224–232, 2010.
[31] M.D. Ballmer, J. van Hunen, G. Ito, P.J. Tackley, and T.A. Bianco. Non-hotspot vol-
cano chains originating from small-scale sublithospheric convection. Geophys. Res. Lett.,
34(L23310):doi:10.1029/2007GL031636, 2007.
[32] W. Bangerth, R. Hartmann, and G. Kanschat. deal.II - a general purpose object oriented finite
element library. ACM Transaction on mathematical software, 33(4), 2007.
[33] R. Barrett, M. Berry, T.F. Chan, J. Demmel, J.M. Donato, J. Dongarra, V. Eijkhout, R. Pozo,
C. Romine, and H. Van der Vorst. Templates for the solution of linear systems: building blocks for
iterative methods. SIAM, 1994.
[34] K.-J. Bathe. Finite Element Procedures in Engineering Analysis. Prentice-Hall, 1982.
[35] L. Battaglia, M.A. Storti, and J. D’Elia. An interface capturing finite element approach for free
surface flows using unstructured grids. Mecanica Computational, XXVII:33–48, 2008.
[36] A. Bauville and T. S. Baumann. geomio: an open-source matlab toolbox to create the initial
configuration of 2d/3d thermo-mechanical simulations from 2d vector drawings. Geochemistry,
Geophysics, Geosystems, 2019.
[37] C. Beaumont, P. Fullsack, and J. Hamilton. Styles of crustal deformation in compressional orogens
caused by subduction of the underlying lithosphere. Tectonophysics, 232:119–132, 1994.
[38] C. Beaumont, R.A. Jamieson, J.P. Butler, and C.J. Warren. Crustal structure: A key constraint
on the mechanism of ultra-high-pressure rock exhumation. Earth Planet. Sci. Lett., 287:116–129,
2009.
264
[39] C. Beaumont, R.A. Jamieson, M.H. Nguyen, and B. Lee. Himalayan tectonics explained by extru-
sion of a low-viscosity crustal channel coupled to focused surface denudation. Nature, 414:738–742,
2001.
[40] C. Beaumont, R.A. Jamieson, M.H. Nguyen, and S. Medvedev. Crustal channel flows: 1. Numerical
models with applications to the tectonics of the Himalayan-Tibetan orogen. J. Geophys. Res.,
109(B06406), 2004.
[41] C. Beaumont, P.J. Kamp, J. Hamilton, and P. Fullsack. The continental collision zone, south
island, new zealand: comparison of geodynamical models and observations. J. Geophys. Res.,
101:3333–3359, 1996.
[42] C. Beaumont, J.A. Munoz, J. Hamilton, and P. Fullsack. Factors controlling the alpine evolu-
tion of the central pyrenees inferred from a comparison of observations and geodynamical models.
J. Geophys. Res., 105:8121–8145, 2000.
[43] T.W. Becker. On the effect of temperature and strain-rate dependent viscosity on global mantle
flow, net rotation, and plate-driving forces. Geophy. J. Int., 167:943–957, 2006.
[44] T.W. Becker and C. Faccenna. Mantle conveyor beneath the Tethyan collisional belt.
Earth Planet. Sci. Lett., 310:453–461, 2011.
[45] T.W. Becker, C. Faccenna, R. O’Connell, and D. Giardini. The development of slabs in the upper
mantle: Insights from numerical and laboratory experiments. J. Geophys. Res., 104(B7):15,207–
15,226, 1999.
[46] T.W. Becker, V. Schulte-Pelkum, D.K. Blackman, J.B. Kellogg, and R.J. O’Connell. Mantle flow
under the western United States from shear wave splitting. Earth Planet. Sci. Lett., 247:235–251,
2006.
[47] A.K. Bengtson and P.E. van Keken. Three-dimensional thermal structure of subduction zones:
effects of obliquity and curvature. Solid Earth, 3:365–373, 2012.
[48] M. Benzi, G.H. Golub, and J. Liesen. Numerical solution of saddle point problems. Acta Numerica,
14:1–137, 2005.
[49] D. Bercovici, G. Schubert, and G.A. Glatzmaier. Three-dimensional convection of an infinite
Prandtl-number compressible fluid in a basally heated spherical shell. J. Fluid Mech., 239:683–
719, 1992.
[50] M. Bercovier and M. Engelman. A finite-element for the numerical solution of viscous incompressible
flows. J. Comp. Phys., 30:181–201, 1979.
[51] M. Bercovier and M. Engelman. A finite-element method for incompressible Non-Newtonian flows.
J. Comp. Phys., 36:313–326, 1980.
[52] P.G. Betts, W.G. Mason, and L. Moresi. The influence of a mantle plume head on the dynamics of
a retreating subduction zone. Geology, 40(8):739–742, 2012.
[53] P.G. Betts, L. Moresi, M.S. Miller, and D. Willis. Geodynamics of oceanic plateau and plume head
accretion and their role in Phanerozoic orogenic systems of China. Geoscience Frontiers, 6:49–59,
2015.
[54] M.J. Beuchert and Y.Y. Podladchikov. Viscoelastic mantle convection and lithospheric stresses.
GJI, 183:35–63, 2010.
[55] E. Beutel, J. van Wijk, C. Ebinger, D. Keir, and A. Agostini. Formation and stability of magmatic
segments in the Main Ethiopian and Afar rifts. Earth Planet. Sci. Lett., 293:225–235, 2010.
[56] M.I. Billen and M. Gurnis. A low wedge in subduction zones. Earth Planet. Sci. Lett., 193:227–236,
2001.
265
[57] M.I. Billen and M. Gurnis. Comparison of dynamic flow models for the Central Aleutian and
Tonga-Kermadec subduction zones. Geochem. Geophys. Geosyst., 4(4), 2003.
[58] M.I. Billen and G. Hirth. Newtonian versus non-Newtonian upper mantle viscosity: Implications
for subduction initiation. Geophys. Res. Lett., 32(L19304):doi:10.1029/2005GL023457, 2005.
[59] M.I. Billen and G. Hirth. Rheologic controls on slab dynamics. Geochem. Geophys. Geosyst.,
8(8):doi:10.1029/2007GC001597, 2007.
[60] M.I. Billen and M. Jadamec. Origin of localized fast mantle f low velocity in numerical models of
subduction. Geochem. Geophys. Geosyst., 13(1):doi:10.1029/2011GC003856, 2012.
[61] B. Blankenbach, F. Busse, U. Christensen, L. Cserepes, D. Gunkel, U. Hansen, H. Harder, G. Jarvis,
M. Koch, G. Marquart, D. Moore, P. Olson, H. Schmeling, and T. Schnaubelt. A benchmark
comparison for mantle convection codes. Geophys. J. Int., 98:23–38, 1989.
[62] P. B. Bochev, C. R. Dohrmann, and M. D. Gunzburger. Stabilization of low-order mixed finite
elements for the stokes equations. SIAM Journal on Numerical Analysis, 44(1):82–101, 2006.
[63] M.-A. Bonnardot, R. Hassani, and E. Tric. Numerical modelling of lithosphereasthenosphere inter-
action in a subduction zone. Earth Planet. Sci. Lett., 272:698–708, 2008.
[64] M.-A. Bonnardot, R. Hassani, E. Tric, E. Ruellan, and M. Regnier. Effect of margin curvature on
plate deformation in a 3-D numerical model of subduction zones. Geophy. J. Int., 173:1084–1094,
2008.
[65] O. Botella and R. Peyret. Benchmark spectral results on the lid-driven cavity flow. Computers and
Fluids, 27(4):421–433, 1998.
[66] A.D. Bottrill, J. van Hunen, and M.B. Allen. Insight into collision zone dynamics from topography:
numerical modelling results and observations. Solid Earth, 3:387–399, 2012.
[67] P. Bouilhol, V. Magni, J. van Hunen, and L. Kaislaniemi. A numerical approach to melting in
warm subduction zones. Earth Planet. Sci. Lett., 411:37–44, 2015.
[68] L. Bourgouin, H.-B. M¨uhlhaus, A.J. Hale, and A. Arsac. Towards realistic simulations of lava dome
growth using the level set method. Acta Geotecnica, 1:225–236, 2006.
[69] D.J. Bower, M. Gurnis, and N. Flament. Assimilating lithosphere and slab history in 4-D Earth
models. Phys. Earth. Planet. Inter., 238:8–22, 2015.
[70] D.J. Bower, M. Gurnis, and M. Seton. Lower mantle structure from paleogeographically constrained
dynamic Earth models. Geochem. Geophys. Geosyst., 14(1):44–63, 2012.
[71] D.J. Bower, M. Gurnis, and D. Sun. Dynamic origins of seismic wavespeed variation in D”.
Phys. Earth. Planet. Inter., 214:74–86, 2013.
[72] D. Braess. Finite Elements. Cambridge, 2007.
[73] J.P. Brandenburg and P.E. van Keken. Deep storage of oceanic crust in a vigorously convecting
mantle. J. Geophys. Res., 112(B06403), 2007.
[74] J.P. Brandenburg and P.E. van Keken. Methods for thermochemical convection in Earths mantle
with force-balanced plates. Geochem. Geophys. Geosyst., 8(11), 2007.
[75] J. Braun, C. Thieulot, P. Fullsack, M. DeKool, and R.S. Huismans. DOUAR: a new three-
dimensional creeping flow model for the solution of geological problems. Phys. Earth. Planet. Inter.,
171:76–91, 2008.
[76] J. Braun and P. Yamato. Structural evolution of a three-dimensional, finite-width crustal wedge.
Tectonophysics, 484:181–192, 2009.
266
[77] E. Bredow and B. Steinberger. Variable melt production rate of the kerguelen hotspot due to
long-term plume-ridge interaction. Geophysical Research Letters, 45(1):126–136, 2018.
[78] E. Bredow, B. Steinberger, R. Gassm¨oller, and J. Dannberg. How plume-ridge interaction shapes
the crustal thickness pattern of the r´eunion hotspot track. Geochemistry, Geophysics, Geosystems,
2017.
[79] S. Brune. Evolution of stress and fault patterns in oblique rift systems: 3-D numerical lithospheric-
scale experiments from rift to breakup. Geochem. Geophys. Geosyst., 15:3392–3415, 2014.
[80] S. Brune and J. Autin. The rift to break-up evolution of the Gulf of Aden: Insights from 3D
numerical lithospheric-scale modelling. Tectonophysics, 607:65–79, 2013.
[81] S. Brune, A.A. Popov, and S. Sobolev. Modeling suggests that oblique extension facilitates rifting
and continental break-up. J. Geophys. Res., 117(B08402), 2012.
[82] S. Brune, A.A. Popov, and S. Sobolev. Quantifying the thermo-mechanical impact of plume arrival
on continental break-up. Tectonophysics, 604:51–59, 2013.
[83] C.-H. Bruneau and M. Saad. The 2D lid-driven cavity problem revisited. Computers & Fluids,
35:326–348, 2006.
[84] H.H. Bui, R. Fukugawa, K. Sako, and S. Ohno. Lagrangian meshfree particles method (SPH) for
large deformation and failure flows of geomaterial using elasticplastic soil constitutive model. Int.
J. Numer. Anal. Geomech., 32(12):1537–1570, 2008.
[85] S. Buiter, A.Y. Babeyko, S. Ellis, T.V. Gerya, B.J.P. Kaus, A. Kellner, G. Schreurs, and Y. Yamada.
The numerical sandbox: comparison of model results for a shortening and an extension experiment.
Analogue and Numerical Modelling of Crustal-Scale Processes. Geological Society, London. Special
Publications, 253:29–64, 2006.
[86] S.J.H. Buiter. A review of brittle compressional wedge models. Tectonophysics, 530:1–17, 2012.
[87] S.J.H. Buiter, R. Govers, and M.J.R. Wortel. A modelling study of vertical surface displacements
at convergent plate margins. Geophy. J. Int., 147:415–427, 2001.
[88] S.J.H. Buiter, R. Govers, and M.J.R. Wortel. Two-dimensional simulations of surface deformation
caused by slab detachment. Tectonophysics, 354:195–210, 2002.
[89] S.J.H. Buiter, O.A. Pfiffner, and C. Beaumont. Inversion of extensional sedimentary basins: A
numerical evaluation of the localisation of shortening. Earth Planet. Sci. Lett., 288:492–504, 2009.
[90] S.J.H. Buiter, G. Schreurs, M. Albertz, T.V. Gerya, B. Kaus, W. Landry, L. le Pourhiet, Y. Mishin,
D.L. Egholm, M. Cooke, B. Maillot, C. Thieulot, T. Crook, D. May, P. Souloumiac, and C. Beau-
mont. Benchmarking numerical models of brittle thrust wedges. Journal of Structural Geology,
92:140–177, 2016.
[91] A.L. Bull, M. Domeier, and T.H. Torsvik. The effect of plate motion history on the longevity of
deep mantle heterogeneities. Earth Planet. Sci. Lett., 401:172–182, 2014.
[92] A.L. Bull, A.K. McNamara, T.W. Becker, and J. Ritsema. Global scale models of the mantle flow
field predicted by synthetic tomography models. Phys. Earth. Planet. Inter., 182:129–138, 2010.
[93] P.S. Bullen. Handbook of Means and Their Inequalities. Springer; 2nd edition, 2003.
[94] H.-P. Bunge, M. Richards, C. Lithgow-Bertelloni, J.R. Baumgardner, S.P. Grand, and B. Romanow-
icz. Time scales and heterogeneous structure in geodynamic Earth models. Science, 280:91–95,
1998.
[95] H.-P. Bunge, M.A. Richards, and J.R. Baumgardner. A sensitivity study of three-dimensional
spherical mantle convection at 108Rayleigh number: Effects of depth-dependent viscosity, heating
mode, and endothermic phase change . J. Geophys. Res., 102(B6):11,991–12,007, 1997.
267
[96] J.-P. Burg and T.V. Gerya. The role of viscous heating in Barrovian metamorphism of collisional
orogens: thermomechanical models and application to the Lepontine Dome in the Central Alps. J.
Metamorphic Geology, 23:75–95, 2005.
[97] E.R. Burkett and M.I. Billen. Dynamics and implications of slab detachment due to ridge-trench
collision. J. Geophys. Res., 114(B12402), 2009.
[98] E.R. Burkett and M.I. Billen. Three-dimensionality of slab detachment due to ridge-trench collision:
Laterally simultaneous boudinage versus tear propagation. Geochem. Geophys. Geosyst., 11(11),
2010.
[99] E. Burov and A.Poliakov. Erosion and rheology controls on synrift and postrift evolution: Verifying
old and new ideas using a fully coupled numerical model. J. Geophys. Res., 106(B8):16,461–16,481,
2001.
[100] E. Burov, T. Francois, P. Agard, L. Le Pourhiet, B. Meyer, C. Tirel, S. Lebedev, P. Yamato, and
J.-P. Brun. Rheological and geodynamic controls on the mechanisms of subduction and HP/UHP
exhumation of crustal rocks during continental collision: Insights from numerical models. Tectono-
physics, 2014.
[101] E. Burov and T. Gerya. Asymmetric three-dimensional topography over mantle plumes. Nature,
513:doi:10.1038/nature13703, 2014.
[102] E. Burov and L. Guillou-Frottier. The plume head-continental lithosphere interaction using a
tectonically realistic formulation for the lithosphere. Geophy. J. Int., 161:469–490, 2005.
[103] E. Burov, L. Jolivet, L. Le Pourhiet, and A. Poliakov. A thermomechanical model of exhumation
of high pressure (HP) and ultra-high pressure (UHP) metamorphic rocks in Alpine-type collision
belts. Tectonophysics, 342:113–136, 2001.
[104] E. Burov and G. Toussaint. Surface processes and tectonics: Forcing of continental subduction and
deep processes. Global and Planetary Change, 58:141–164, 2007.
[105] C. Burstedde, O. Ghattas, M. Gurnis, G. Stadler, E. Tan, T. Tu, L.C. Wilcox, and S. Zhong.
Scalable Adaptive Mantle Convection Simulation on Petascale Supercomputers. ACM/IEEE SC
Conference Series, 2008, 2008.
[106] C. Burstedde, O. Ghattas, G. Stadler, T. Tu, and L.C. Wilcox. Parallel scalable adjoint-based adap-
tive solution of variable-viscosity Stokes flow problems. Computer Methods in Applied Mechanics
and Engineering, 198:1691–1700, 2009.
[107] C. Burstedde, G. Stadler, L. Alisic, L.C. Wilcox, E. Tan, M. Gurnis, and O. Ghattas. Large-scale
adaptive mantle convection simulation. Geophy. J. Int., 192:889–906, 2013.
[108] F.H. Busse, U. Christensen, R. Clever, L. Cserepes, C. Gable, E. Giannandrea, L. Guillou, G. House-
man, H.-C. Nataf, M. Ogawa, M. Parmentier, C. Sotin, and B. Travis. 3D convection at infinite
Prandtl number in Cartesian geometry - a benchmark comparison. Geophys. Astrophys. Fluid
Dynamics, 75:39–59, 1993.
[109] J.P. Butler and C. Beaumont. Subduction zone decoupling/retreat modeling explains south
Tibet (Xigaze) and other supra-subduction zone ophiolites and their UHP mineral phases.
Earth Planet. Sci. Lett., 463:101–117, 2017.
[110] J.P. Butler, C. Beaumont, and R.A. Jamieson. The Alps 1: A woring geodynamic model for burial
and exhumation of (ultra)high-pressure rocks in Alpine-type orogens. Earth Planet. Sci. Lett.,
337-378:114–131, 2013.
[111] J.P. Butler, C. Beaumont, and R.A. Jamieson. Paradigm lost: Buoyancy thwarted by the
strength of the Western Gneiss Region (ultra)high-pressure terrane, Norway. Lithosphere, page
doi:10.1130/L426.1, 2015.
268
[112] J.P. Butler, C. Veaumont, and R.A. Jamieson. Crustal emplacement of exhuming (ultra)high-
pressure rocks: Will that be pro- or retro-side ? Geology, 39:635–638, 2011.
[113] F.A. Capitanio and M. Faccenda. Complex mantle flow around heterogeneous subducting oceanic
plates. Earth Planet. Sci. Lett., 353-354:29–37, 2012.
[114] F.A. Capitanio, C. Faccenna, S. Zlotnik, and D.R. Stegman. Subduction dynamics and the origin
of Andean orogeny and the Bolivian orocline. Nature, 480:doi:10.1038/nature10596, 2011.
[115] F.A. Capitanio and A. Replumaz. Subduction and slab breakoff controls on Asian inden-
tation tectonics and Himalayan western syntaxis formation . Geochem. Geophys. Geosyst.,
14(9):doi:10.1002/ggge.20171, 2013.
[116] F.A. Capitanio, D.R. Stegman, L.N. Moresi, and W. Sharples. Upper plate controls on deep
subduction, trench migrations and deformations at convergent margins. Tectonophysics, 483:80–92,
2010.
[117] N.G. Cerpa, R. Araya, M. Gerbault, and R. Hassani. Relationship between slab dip and topography
segmentation in an oblique subduction zone: Insights from numerical modeling. Geophys. Res. Lett.,
41:10.1002/2015GL064047, 2015.
[118] N.G. Cerpa, B. Guillaume, and J.Martinod. The interplay between overriding plate kinematics,
slab dip and tectonics. Geophy. J. Int., 215:1789–1802, 2018.
[119] J.S. Chen, C. Pan, and T.Y.P. Chang. On the control of pressure oscillation in bilinear-displacement
constant-pressure element. Comput. Methods Appl. Mech. Engrg., 128:137–152, 1995.
[120] P. Chenin and C. Beaumont. Influence of offset weak zones on the development of rift basins:
Activation and abandonment during continental extension and breakup. J. Geophys. Res., 118:1–
23, 2013.
[121] M.V. Chertova, T. Geenen, A. van den Berg, and W. Spakman. Using open sidewalls for modelling
self-consistent lithosphere subduction dynamics . Solid Earth, 3:313–326, 2012.
[122] M.V. Chertova, W. Spakman, T. Geenen, A.P. van den Berg, and D.J.J. van Hinsbergen. Under-
pinning tectonic reconstructions of the western Mediterranean region with dynamic slab evolution
from 3-D numerical modeling. J. Geophys. Res., 119:10.1002/ 2014JB011150, 2014.
[123] S. Chiu-Webster, E.J. Hinch, and J.R. Lister. Very viscous horizontal convection. J. Fluid Mech.,
611:395–426, 2008.
[124] E. Choi, E. Tan, L.L. Lavier, and V.M. Calo. DynEarthSol2D: An efficient unstructured finite
element method to study long-term tectonic deformation. J. Geophys. Res., 118:1–16, 2013.
[125] Eunseo Choi, Luc Lavier, and Michael Gurnis. Thermomechanics of mid-ocean ridge segmentation.
Phys. Earth Planet. Interiors, 171:374–386, 2008.
[126] Edmund Christiansen and Knud D. Andersen. Computation of collapse states with von mises type
yield condition. International Journal for Numerical Methods in Engineering, 46:1185–1202, 1999.
[127] Edmund Christiansen and Ole S. Pedersen. Automatic mesh refinement in limit analysis. Interna-
tional Journal for Numerical Methods in Engineering, 50:1331–1346, 2001.
[128] H. Ciskova, J. van Hunen, A.P. van den Berg, and N.J. Vlaar. The inuence of rheological weakening
and yield stress on the interaction of slabs with the 670 km discontinuity. Earth Planet. Sci. Lett.,
199:447–457, 2002.
[129] P.D. Clift, S. Brune, and J. Quinteros. Climate changes control offshore crustal structure at South
China Sea continental margin. Earth Planet. Sci. Lett., 420:66–72, 2015.
[130] S. Cloetingh, E. Burov, F. Beekman, B. Andeweg, P.A.M. Andriessen, D. Garcia-
Castellanos, G. de Vicente, and R. Vegas. Lithospheric folding in Iberia. Tectonics,
21(5):10.1029/2001TC901031, 2002.
269
[131] M. Collignon, N. Fernandez, and B.J.P. Kaus. Influence of surface processes and initial topography
on lateral fold growth and fold linkage mode. Tectonics, 34:1622–1645, 2015.
[132] M. Collignon, B.J.P. Kaus, D.A. May, and N. fernandez. Influences of surface pro-
cesses on fold growth during 3-D detachment folding. Geochem. Geophys. Geosyst.,
15:doi:10.1002/2014GC005450, 2014.
[133] C.P. Conrad, M.D. Behn, and P.G. Silver. Global mantle flow and the development of seismic
anisotropy: Differences between the oceanic and continental upper mantle. J. Geophys. Res.,
112(B07317), 2007.
[134] C.P. Conrad and M. Gurnis. Seismic tomography, surface uplift, and the breakup of Gondwanaland:
Integrating mantle convection backwards in time. Geochem. Geophys. Geosyst., 4(3), 2003.
[135] C.P. Conrad and C. Lithgow-Bertelloni. Influence of continental roots and asthenosphere on plate-
mantle coupling. Geophys. Res. Lett., 33(L05312), 2006.
[136] C.P. Conrad, B. Steinberger, and T.H. Torsvik. Stability of active mantle upwelling revealed by
net characteristics of plate tectonics. Nature, 498:479, 2013.
[137] G. Corti, R. Cioni, Z. Franceschini, F. Sani, St´ephane Scaillet, P. Molin, I. Isola, F. Mazzarini,
S. Brune, D. Keir, A. Erbello, A. Muluneh, F. Illsley-Kemp, and A. Glerum. Aborted propagation
of the ethiopian rift caused by linkage with the kenyan rift. Nature Communications, 10, 2019.
[138] F. Crameri, H. Schmeling, G.J. Golabek, T. Duretz, R. Orendt, S.J.H. Buiter, D.A. May, B.J.P.
Kaus, T.V. Gerya, and P.J. Tackley. A comparison of numerical surface topography calculations in
geodynamic modelling: an evaluation of the ’sticky air’ method. Geophy. J. Int., 189:38–54, 2012.
[139] F. Crameri and P.J. Tackley. Spontaneous development of arcuate single-sided subduction in global
3-D mantle convection models with a free surface. J. Geophys. Res., 119:doi:10.1002/2014JB010939,
2014.
[140] M. Crouzeix and P.-A. Raviart. Conforming and nonconforming finite element methods for solving
the stationary Stokes equations I. R.A.I.R.O., 7(3):33–75, 1973.
[141] L. Cruz, J. Malinski, A. Wilson, W.A. Take, and G. Hilley. Erosional control of kinematics and
geometry of fold-and-thrust belts imaged in a physical and numerical sandbox. J. Geophys. Res.,
115(B09404):doi:10.1029/2010JB007472, 2010.
[142] C.A. Currie and C. Beaumont. Are diamond-bearing Cretaceous kimberlites related to low-angle
subduction beneath western North America. Earth Planet. Sci. Lett., 303:59–70, 2011.
[143] C.A. Currie, C. Beaumont, and R.S. Huismans. The fate of subducted sediments: a case for backarc
intrusion and underplating. Geology, 35(12):1111–1114, 2007.
[144] C. Cuvelier, A. Segal, and A.A. van Steenhoven. Finite Element Methods and Navier-Stokes Equa-
tions. D. Reidel Publishing Company, 1986.
[145] M. Dabrowski, M. Krotkiewski, and D.W. Schmid. Milamin: Matlab based finite element solver
for large problems. Geochem. Geophys. Geosyst., 9(4):Q04030, 2008.
[146] J. Dannberg, Z. Eilon, U. Faul, R. Gassmoeller, P. Moulik, and R. Myhill. The importance of grain
size to mantle dynamics and seismological observations. Geochem. Geophys. Geosyst., 18:3034–3061,
2017.
[147] J. Dannberg and R. Gassm¨oller. Chemical trends in ocean islands explained by plume-slab inter-
action. PNAS, 115(17):4351–4356, 2018.
[148] J. Dannberg and T. Heister. Compressible magma/mantle dynamics: 3-D, adaptive simulations in
ASPECT. Geophy. J. Int., 207:1343–1366, 2016.
[149] J. Dannberg and S.V. Sobolev. Low-buoyancy thermochemical plumes resolve controversy of clas-
sical mantle plume concept. Nature Communications, 6(6960):doi:10.1038/ncomms7960, 2015.
270
[150] D.R. Davies, J.H. Davies, P.C. Bollada, O. Hassan, K. Morgan, and P. Nithiarasu. A hierarchical
mesh refinement technique for global 3-D spherical mantle convection modelling. Geosci. Model
Dev., 6:1095–1107, 2013.
[151] D.R. Davies, C.R. Wilson, and S.C. Kramer. Fluidity: A fully unstructured anisotropic adaptive
mesh computational modeling framework for geodynamics. Geochem. Geophys. Geosyst., 12(6),
2011.
[152] P. Davy and P. Cobbold. Indentation tectonics in nature and experiment. 1. experiments scaled for
gravity. Bulletin of the Geological Institutions of Uppsala, 14:129–141, 1988.
[153] B. Deglo de Besses, A. Magnin, and P. Jay. Sphere drag in a viscoplastic fluid. AIChE Journal,
50(10):2627–2629, 2004.
[154] J. de Frutos, V. John, and J. Novo. Projection methods for incompressible ow problems with
WENO nite difference schemes. J. Comp. Phys., 309:368–386, 2016.
[155] Y. Deubelbeiss and B.J.P. Kaus. Comparison of Eulerian and Lagrangian numerical techniques for
the Stokes equations in the presence of strongly varying viscosity. Phys. Earth Planet. Interiors,
171:92–111, 2008.
[156] A.E. Svartman Dias, L.L. Lavier, and N.W. Hayman. Conjugate rifted margins width and asymme-
try: The interplay between lithospheric strength and thermomechanical processes. J. Geophys. Res.,
120:8672–8700, 2015.
[157] C.R. Dohrmann and P.B. Bochev. A stabilized finite element method for the Stokes problem based
on polynomial pressure projections. Int. J. Num. Meth. Fluids, 46:183–201, 2004.
[158] Jean Donea and Antonio Huerta. Finite Element Methods for Flow Problems. John Wiley & Sons,
2003.
[159] T. Duretz, Ph. Agard, Ph. Yamato, C. Ducassou, E.B. Burov, and T.V. Gerya. Thermo-mechanical
modeling of the obduction process based on the Oman Ophiolite case. Gondwana Research, 2015.
[160] T. Duretz, T.V. Gerya, B.J.P. Kaus, and T.B. Andersen. Thermomechanical modeling of slab
eduction. J. Geophys. Res., 117(B08411), 2012.
[161] T. Duretz, T.V. Gerya, and D.A. May. Numerical modelling of spontaneous slab breakoff and
subsequent topographic response. Tectonophysics, 502:244–256, 2011.
[162] T. Duretz, T.V. Gerya, and W. Spakman. Slab detachment in laterally varying subduction zones:
3-D numerical modeling. Geophys. Res. Lett., 41:1951–1956, 2014.
[163] T. Duretz, D.A. May, T.V. Gerya, and P.J. Tackley. Discretization errors and free surface stabilisa-
tion in the finite difference and marker-in-cell method for applied geodynamics: A numerical study.
Geochem. Geophys. Geosyst., 12(Q07004), 2011.
[164] S. Dyksterhuis, P. Rey, R.D. Mueller, and L. Moresi. Effects of initial weakness on rift architecture.
Geological Society, London, Special Publications, 282:443–455, 2007.
[165] D. Dymkova and T. Gerya. Porous fluid flow enables oceanic subduction initiation on Earth.
Geophys. Res. Lett., 2013.
[166] David L. Egholm. A new strategy for discrete element numerical models: 1. Theory. J. Geo-
phys. Res., 112:B05203, doi:10.1029/2006JB004557, 2007.
[167] David L. Egholm, Mike Sandiford, Ole R. Clausen, and Søren B. Nielsen. A new strategy
for discrete element numerical models: 2. Sandbox applications. J. Geophys. Res., 112:B05204,
doi:10.1029/2006JB004558, 2007.
[168] R. Eid. Higher order isoparametric finite element solution of Stokes flow . Applied Mathematics
and Computation, 162:1083–1101, 2005.
271
[169] V. Eijkhout. Introduction to High Performance Scientific Computing. Creative Commons, 2013.
[170] Y. Elesin, T. Gerya, I.M. Artemieva, and H. Thybo. Samovar: a thermomechanical code for
modeling of geodynamic processes in the lithospshere - application to basin evolution. Arabian
Journal of Geosciences, 3:477–497, 2010.
[171] S. Ellis, P. Fullsack, and C. Beaumont. Oblique convergence of the crust driven by basal forcing:
implications for length-scales of deformation and strain partitioning in orogens. Geophys. J. Int.,
120:24–44, 1995.
[172] S. Ellis, G. Schreurs, and M. Panien. Comparisons between analogue and numerical models of
thrust wedge development. Journal of Structural Geology, 26:1649–1675, 2004.
[173] S.M. Ellis, T.A. Little, L.M. Wallace, B.R. Hacker, and S.J.H. Buiter. Feedback between rifting
and diapirism can exhume ultrahigh-pressure rocks. Earth Planet. Sci. Lett., 311:427–438, 2011.
[174] H. Elman, D. Silvester, and A. Wathen. Finite Elements and Fast Iterative Solvers. Oxford Science
Publications, 2014.
[175] A. Enns, T.W. Becker, and H. Schmeling. The dynamics of subduction and trench migration for
viscosity stratification. Geophy. J. Int., 160:761–775, 2005.
[176] Z. Erdos, R.S. huismans, and P. van der Beek. First-order control of syntectonic sedimentation on
crustal-scale structure of mountain belts . J. Geophys. Res., 120:doi:10.1002/2014JB011785, 2015.
[177] Z. Erdos, R.S. Huismans, and P. van der Beek. Control of increased sedimentation on orogenic fold-
and-thrust belt structure - insights into the evolution of the Western Alps. Solid Earth, 10:391–404,
2019.
[178] Z. Erdos, R.S. huismans, P. van der Beek, and C. Thieulot. Extensional inheritance
and surface processes as controlling factors of mountain belt structure. J. Geophys. Res.,
119:doi:10.1002/2014JB011408, 2014.
[179] E. Erturk. Discussions on Driven Cavity Flow. Int. J. Num. Meth. Fluids, 60:275–294, 2009.
[180] M. Faccenda. Mid mantle seismic anisotropy around subduction zones. Phys. Earth. Planet. Inter.,
227:1–19, 2014.
[181] M. Faccenda and F.A. Capitanio. Seismic anisotropy around subduction zones: Insights from three-
dimensional modeling of upper mantle deformation and SKS splitting calculations . Geochem. Geo-
phys. Geosyst., 14(1):doi:10.1029/2012GC004451, 2013.
[182] M. Faccenda, T.V. Gerya, and S. Chakraborty. Styles of post-subduction collisional orogeny:
Influence of convergence velocity, crustal rheology and radiogenic heat production. Lithos, 103:257–
287, 2008.
[183] M. Faccenda, T.V. Gerya, N.S. Mancktelow, and L. Moresi. Fluid flow during slab unbending
and dehydration: Implications for intermediate-depth seismicity, slab weakening and deep water
recycling. Geochem. Geophys. Geosyst., 13(1):doi:10.1029/2011GC003860, 2012.
[184] R.J. Farrington, L.-N. Moresi, and F.A. Capitanio. The role of viscoelasticity in subducting plates.
Geochem. Geophys. Geosyst., 15:4291–4304, 2014.
[185] R.J. Farrington, D.R. Stegman, L.N. Moresi, M. Sandiford, and D.A. May. Interactions of 3D
mantle flow and continental lithosphere near passive margins. Tectonophysics, 483:20–28, 2010.
[186] N.P. Fay, R.A. Bennett, J.C. Spinler, and E.D. Humphreys. Small-scale upper mantle convection
and crustal dynamics in southern California. Geochem. Geophys. Geosyst., 9(8), 2008.
[187] N. Fernandez and B. Kaus. Influence of pre-existing salt diapirs on 3D folding patterns . Tectono-
physics, 637:354–369, 2014.
272
[188] N. Fernandez and B. Kaus. Fold interaction and wavelength selection in 3D models of multilayer
detachment folding. Tectonophysics, 632:199–217, 2014.
[189] N. Fernandez and B. Kaus. Pattern formation in 3-D numerical models of down-built diapirs
initiated by a RayleighTaylor instability. Geophy. J. Int., 202:1253–1270, 2015.
[190] C. Fillon, R.S. Huismans, and P. van der Beek. Syntectonic sedimentation effects on the growth of
fold-and-thrust belts . Geology, 41(1):83–86, 2013.
[191] C. Fillon, R.S. Huismans, P. van der Beek, and J.A. Mu noz. Syntectonic sedimentation controls
on the evolution of the southern Pyrenean fold-and-thrust belt: Inferences from coupled tectonic-
surface processes models. J. Geophys. Res., 118:5665–5680, 2013.
[192] R. Fischer and T. Gerya. Early Earth plume-lid tectonics: A high-resolution 3D numerical modelling
approach. Journal of Geodynamics, 100:198–214, 2016.
[193] N. Flament, M. Gurnis, S. Williams, M. Seton, J. Skogseid, C. Heine, and D. M¨uller. Topographic
asymmetry of the South Atlantic from global models of mantle flow and lithospheric stretching.
Earth Planet. Sci. Lett., 387:107–119, 2014.
[194] B.J. Foley and T.W. Becker. Generation of plate-like behavior and mantle hetero-
geneity from a spherical, viscoplastic convection model. Geochem. Geophys. Geosyst.,
10(8):doi:10.1029/2009GC002378, 2009.
[195] M. Fortin. Old and new finite elements for incompressible flows. Int. J. Num. Meth. Fluids,
1:347–364, 1981.
[196] M. Fortin and A. Fortin. Experiments with several elements for viscous incompressible flows.
Int. J. Num. Meth. Fluids, 5:911–928, 1985.
[197] R. De Franco, R. Govers, and R. Wortel. Numerical comparison of different convergent plate
contacts: subduction channel and subduction fault. Geophy. J. Int., pages doi: 10.1111/j.1365–
246X.2006.03498.x, 2006.
[198] T. Francois, E. Burov, P. Agard, and B. Meyer. Buildup of a dynamically supported orogenic
plateau: Numerical modeling of the Zagros/Central Iran case study. Geochem. Geophys. Geosyst.,
15:doi:10.1002/ 2013GC005223, 2014.
[199] M.R.T. Fraters, W. Bangerth, C. Thieulot, A.C. Glerum, and W. Spakman. Efficient and Practical
Newton Solvers for Nonlinear Stokes Systems in Geodynamic Problems. Geophy. J. Int., 2019.
[200] R. Freeburn, P. Bouilhol, B. Maunder, V. Magni, and J. van Hunen. Numerical models of the
magmatic processes induced by slab breakoff. Earth Planet. Sci. Lett., 478:203–213, 2017.
[201] P.J. Frey and P.-L. George. Mesh generation. Hermes Science, 2000.
[202] L. Fuchs, H. Koyi, and H. Schmeling. Numerical modeling of the effect of composite rheology on
internal deformation in down-built diapirs. Tectonophysics, 646:79–95, 2015.
[203] L. Fuchs and H. Schmeling. A new numerical method to calculate inhomogeneous and time-
dependent large deformation of two-dimensional geodynamic flows with application to diapirism.
Geophy. J. Int., 194(2):623–639, 2013.
[204] J. Fullea, J.C. Afonso, J.A.D. Connolly, M. Fernandez, D. Garcia-Castellanos, and H. Zeyen. Lit-
Mod3D: An interactive 3-D software to model the thermal, compositional, density, seismological,
and rheological structure of the lithosphere and sublithospheric upper mantle. Geochem. Geo-
phys. Geosyst., 10(8):doi:10.1029/2009GC002391, 2009.
[205] J. Fullea, M. Fernandez, J.C. Afonso, J. Verges, and H. Zeyen. iThe structure and evolution of the
lithosphereasthenosphere boundary beneath the AtlanticMediterranean Transition Region. Lithos,
2010.
273
[206] Christopher W. Fuller, Sean D. Willett, and Mark T. Brandon. Formation of forearc basins and
their influence on subduction zone earthquakes. Geology, 34(2):65–68, 2006.
[207] P. Fullsack. An arbitrary Lagrangian-Eulerian formulation for creeping flows and its application in
tectonic models. Geophy. J. Int., 120:1–23, 1995.
[208] M. Furuichi and D. Nishiura. Robust coupled fluid-particle simulation scheme in Stokes-flow
regime: Toward the geodynamic simulation including granular media. Geochem. Geophys. Geosyst.,
15:2865–2882, 2014.
[209] J. Ganne, M. Gerbault, and S. Block. Thermo-mechanical modeling of lower crust exhumationCon-
straints from the metamorphic record of the Palaeoproterozoic Eburnean orogeny, West African
Craton. Precambrian Research, 243:88–109, 2014.
[210] F. Garel, S. Goes, D.R. Davies, J.H. Davies, S.C. Kramer, and C.R. Wilson. Interaction of sub-
ducted slabs with the mantle transition-zone: A regime diagram from 2-D thermo-mechanical
models with a mobile trench and an overriding plate. Geochem. Geophys. Geosyst., 15(1739–
1765):doi:10.1002/2014GC005257, 2014.
[211] E.J. Garnero and A.K. McNamara. Structure and Dynamics of Earths Lower Mantle. Science,
320:626–628, 2008.
[212] R. Gassm¨oller, J. Dannberg, E. Bredow, B. Steinberger, and T. H. Torsvik. Major influence
of plume-ridge interaction, lithosphere thickness variations, and global mantle flow on hotspot
volcanism-the example of tristan. Geochem. Geophys. Geosyst., 17(4):1454–1479, 2016.
[213] R. Gassm¨oller, H. Lokavarapu, E. M. Heien, E. G. Puckett, and W. Bangerth. Flexible and
scalable particle-in-cell methods with adaptive mesh refinement for geodynamic computations.
Geochem. Geophys. Geosyst., 19(9):3596–3604, 2018.
[214] L. Gemmer, C. Beaumont, and S. Ings. Dynamic modelling of passive margin salt tectonics: effects
of water loading, sediment properties and sedimentation patterns. Basin Research, 17:383–402,
2005.
[215] L. Gemmer, S.J. Ings, S. Medvedev, and C. Beaumont. Salt tectonics driven by differential sediment
loading: stability analysis and finite-element experiments. Basin Research, 16:199–218, 2004.
[216] L. Geoffroy, E.B. Burov, and P. Werner. Volcanic passive margins: another way to break up
continents. Scientific Reports, 5:DOi:10.1038/srep14828, 2015.
[217] M. Gerault, T.W. Becker, B.J.P. Kaus, C. Faccenna, L. Moresi, and L. Husson. The role of slabs
and oceanic plate geometry in the net rotation of the lithosphere, trench motions, and slab return
flow. Geochem. Geophys. Geosyst., 13(4):Q04001, doi:10.1029/2011GC003934, 2012.
[218] M. G´erault, L. Husson, M.S. Miller, and E.D. Humphreys. Flat-slab subduction, topography, and
mantle dynamics in southwestern Mexico. Tectonics, 34:10.1002/2015TC003908, 2015.
[219] M. Gerbault. Pressure conditions for shear and tensile failure around a circular magma chamber;
insight from elasto-plastic modelling. Geological Society, London, Special Publications, 367:111–130,
2012.
[220] M. Gerbault, F. Cappa, and R. Hassani. Elasto-plastic and hydromechanical mod-
els of failure around an infinitely long magma chamber. Geochem. Geophys. Geosyst.,
13(3):doi:10.1029/2011GC003917, 2012.
[221] M. Gerbault, J. Cembrano, C. Mpodozis, M. Farias, and M. Pardo. Continental margin deforma-
tion along the Andean subduction zone: Thermo-mechanical models. Phys. Earth. Planet. Inter.,
177:180–205, 2009.
[222] M. Gerbault, F. Davey, and S. Henrys. Three-dimensional lateral crustal thickening in continental
oblique collision: an example from the Southern Alps, New Zealand. Geophy. J. Int., 150:770–779,
2002.
274
[223] M. Gerbault, S. Henrys, and F. Davey. Numerical models of lithospheric deformation forming the
Southern Alps of New Zealand. J. Geophys. Res., 108(B7), 2003.
[224] M. Gerbault, A.N.B. Poliakov, and M. Daignieres. Prediction of faulting from the theories of
elasticity and plasticity: what are the limits? Journal of Structural Geology, 20:301–320, 1998.
[225] M. Gerbault and W. Willingshofer. Lower crust indentation or horizontal ductile flow during
continental collision? Tectonophysics, 387:169–187, 2004.
[226] T. Gerya. Dynamical instability produces transform faults at mid-ocean ridges. Science, 329:1047–
1050, 2010.
[227] T. Gerya. Future directions in subduction modeling. Journal of Geodynamics, 52:344–378, 2011.
[228] T. Gerya and B. St¨ockhert. Two-dimensional numerical modeling of tectonic and metamorphic
histories at active continental margins. Int J Earth Sci (Geol Rundsch), 95:250–274, 2006.
[229] T. Gerya and D.A. Yuen. Robust characteristics method for modelling multiphase visco-elasto-
plastic thermo-mechanical problems. Phys. Earth. Planet. Inter., 163:83–105, 2007.
[230] Taras Gerya. Numerical Geodynamic Modelling. Cambridge University Press, 2010.
[231] T.V. Gerya, J.A.D. Connolly, and D.A. Yuen. Why is terrestrial subduction one-sided ? Geology,
36(1):43–46, 2008.
[232] T.V. Gerya, J.A.D. Connolly, D.A. Yuen, W. Gorczyk, and A.M. Capel. Seismic implications of
mantle wedge plumes. Phys. Earth. Planet. Inter., 156:59–74, 2006.
[233] T.V. Gerya, D. Fossati, C. Cantieni, and D. Seward. Dynamic effects of aseismic ridge subduction:
numerical modelling. Eur. J. Mineral, 21:649–661, 2009.
[234] T.V. Gerya, D.A. May, and T. Duretz. An adaptive staggered grid finite difference method for
modeling geodynamic Stokes flows with strongly variable viscosity. Geochem. Geophys. Geosyst.,
14(4), 2013.
[235] T.V. Gerya and F.I. Meilick. Geodynamic regimes of subduction under an active margin: effects
of rheological weakening by fluids and melts. Journal of Metamorphic Geology, 29:7–31, 2011.
[236] T.V. Gerya, L.L. Perchuk, W.V. Maresch, and A.P. Willner. Inherent gravitational instability of
hot continental crust: Implications for doming and diapirism in granulite facies terrains. Geological
Society of America, 380:97–115, 2004.
[237] T.V. Gerya, R.J. Stern, M.Baes, S.V. Sobolev, and S.A. Whattam. Plate tectonics on the Earth
triggered by plume-induced subduction initiation. Nature, 527, 2015.
[238] T.V. Gerya, R. Uken, J. Reinhardt, M. Watkeys, W.V. Maresch, and B.M. Clarke. Cold fingers in
a hot magma: Numerical modeling of country-rock diapirs in the Bushveld Complex, South Africa.
Geology, 31(9):753–756, 2003.
[239] T.V. Gerya and D.A. Yuen. Characteristics-based marker-in-cell method with conservative finite-
differences schemes for modeling geological flows with strongly variable transport properties.
Phys. Earth. Planet. Inter., 140:293–318, 2003.
[240] T.V. Gerya and D.A. Yuen. Rayleigh-Taylor instabilities from hydration and melting propel ’cold
plumes’ at subduction zones. Earth Planet. Sci. Lett., 212:47–62, 2003.
[241] T.V. Gerya, D.A. Yuen, and W.V. Maresch. Thermomechanical modelling of slab detachment.
Earth Planet. Sci. Lett., 226:101–116, 2004.
[242] T.V. Gerya, D.A. Yuen, and E.O.D. Sevre. Dynamical causes for incipient magma chambers above
slabs. Geology, 32(1):89–92, 2004.
275
[243] R.K. Ghazian and S.J.H. Buiter. A numerical investigation of continental collision styles. GJI,
2013.
[244] R.K. Ghazian and S.J.H. Buiter. Numerical modelling of the role of salt in continental collision:
An application to the southeast Zagros fold-and-thrust belt. Tectonophysics, in press, 2014.
[245] U. Ghia, K.N. Ghia, and C.T. Shin. High-Re Solutions for incompressible flow using the Navier-
Stokes equations and a multigrid method. J. Comp. Phys., 48:387–411, 1982.
[246] G. Gibert, M. Gerbault, R. Hassani, and E. Tric. Dependency of slab geometry on absolute velocities
and conditions for cyclicity: insights from numerical modelling. Geophy. J. Int., 189:747–760, 2012.
[247] E. Di Giuseppe, J. van Hunen, F. Funiciello, C. Faccenna, and D. Giardini. Slab stiffness control
of trench motion: Insights from numerical models. Geochem. Geophys. Geosyst., 9(2), 2008.
[248] A. Glerum, C. Thieulot, M. Fraters, C. Blom, and W. Spakman. Nonlinear viscoplasticity in
ASPECT: benchmarking and applications to subduction. Solid Earth, 9(2):267–294, 2018.
[249] R. Glowinski. Handbook of Numerical Analysis, vol IX: Numerical methods for fluids. North-
Holland, 2003.
[250] Oguz H. Gogus. Rifting and subsidence following lithospheric removal in continental back arcs.
Geology, page doi:10.1130/G36305.1, 2014.
[251] G.H. Golub and C.F. van Loan. Matrix Computations, 4th edition. John Hopkins University Press,
2013.
[252] W. Gorczyk, T.V. Gerya, J.A.D. Connolly, and D.A. Yuen. Growth and mixing dynamics of mantle
wedge plumes. Geology, 35(7):587–590, 2007.
[253] W. Gorczyk, T.V. Gerya, J.A.D. Connolly, D.A. Yuen, and M. Rudolph. Large-scale rigid-body
rotation in the mantle wedge and its implications for seismic tomography . Geochem. Geo-
phys. Geosyst., 7(5):10.1029/2005GC001075, 2006.
[254] W. Gorczyk, H. Smithies, F. Korhonen, H. Howard, and R. Quentin De Gromard. Ultra-hot
Mesoproterozoic evolution of intracontinental central Australia. Geoscience Frontiers, 6(1):23–37,
2014.
[255] R. Goteti, C. Beaumont, and S.J. Ings. Factors controlling early stage salt tectonics at rifted
continental margins and their thermal consequences. J. Geophys. Res., 117:1–31, 2013.
[256] R. Govers and M.J.R. Wortel. Extension of stable continental lithosphere and the initiation of
lithospheric scale faults. Tectonics, 14(4):1041–1055, 1995.
[257] R. Govers and M.J.R. Wortel. Some remarks on the relation between vertical motions of the
lithosphere during extension and the necking depth parameter inferred from kinematic modeling
studies. J. Geophys. Res., 104:23,245–23,253, 1999.
[258] R. Govers and M.J.R. Wortel. Lithosphere tearing at STEP faults: Response to edges of subduction
zones . Earth Planet. Sci. Lett., 236:505–523, 2005.
[259] S. Gradmann and C. Beaumont. Coupled fluid flow and sediment deformation in margin-scale salt-
tectonic systems: 2. Layered sediment models and application to the northwestern Gulf of Mexico.
Tectonics, 31(TC4011), 2012.
[260] S. Gradmann, C. Beaumont, and M. Albertz. Factors controlling the evolution of the Perdido Fold
Belt, northwestern Gulf of Mexico, determined from numerical models. Tectonics, 28(TC2002),
2009.
[261] R. Gray and R.N. Pysklywec. Geodynamic models of Archean continental collision and the forma-
tion of mantle lithosphere keels. Geophys. Res. Lett., 37(L19301), 2010.
276
[262] R. Gray and R.N. Pysklywec. Geodynamic models of mature continental collision: Evolution of
an orogen from lithospheric subduction to continental retreat/delamination. J. Geophys. Res.,
117(B03408), 2012.
[263] R. Gray and R.N. Pysklywec. Influence of sediment deposition on deep lithospheric tectonics.
Geophys. Res. Lett., 39(L11312), 2012.
[264] R. Gray and R.N. Pysklywec. Influence of viscosity pressure dependence on deep lithospheric
tectonics during continental collision. J. Geophys. Res., 118, 2013.
[265] P.M. Gresho, S.T. Chan, M.A. Christon, and A.C. Hindmarsch. A little more on stabilised Q1Q1
for transient viscous incompressible flow. Int. J. Num. Meth. Fluids, 21:837–856, 1995.
[266] P.M. Gresho and R.L. Sani. Incompressible flow and the Finite Element Method, vol II. John Wiley
and Sons, Ltd, 2000.
[267] M. Griebel, T. Dornseifer, and T. Neunhoeffer. Numerical simulation in Fluid Dynamics. SIAM.
[268] D. Griffiths and D. Silvester. Unstable modes of the q1-p0 element. Technical Report 257, University
of MAnchester/UMIST, 1994.
[269] S.G. Grigull, S.M. Ellis, T.A. Little, M.P. Hill, and S.J.H. Buiter. Rheological constraints on
quartz derived from scaling relationships and numerical models of sheared brittle-ductile quartz
veins, central Southern alps, New Zealand. Journal of Structural Geology, 37:200–222, 2012.
[270] L. Guillou-Frottier, E. Burov, S. Cloetingh, E. Le Goff, Y. Deschamps, B. Huet, and V. Bou-
chot. Plume-induced dynamic instabilities near cratonic blocks: Implications for PTt paths and
metallogeny. Global and Planetary Change, 90-91:37–50, 2012.
[271] M. Gunzburger. Finite Element Methods for Viscous Incompressible Flows: A Guide to Theory,
Practice and Algorithms. Academic, Boston, 1989.
[272] M. Gunzburger, P. Bochev, and R. Lehoucq. On stabilized finite element methods for the Stokes
problem in the small time step limit. 2006.
[273] M. Gurnis, C. Hall, and L. Lavier. Evolving force balance during incipient subduction.
Geochem. Geophys. Geosyst., 5(7), 2004.
[274] M. Gurnis, J.X. Mitrovica, J. Ritsema, and H.-J. van Heijst. Constraining mantle density structure
using geological evidence of surface uplift rates: The case of the African superplume. Geochem. Geo-
phys. Geosyst., 1, 2000.
[275] C.E. Hall, M. Gurnis, M. Sdrolias, L.L. Lavier, and R.D. Mueller. Catastrophic initiation of
subduction following forced convergence across fracture zones. Earth Planet. Sci. Lett., 212:15–30,
2003.
[276] D.L. Hansen. A meshless formulation for geodynamic modeling. J. Geophys. Res.,
108:doi:10.1029/2003JB002460, 2003.
[277] R. Hassan, N. Flament, M. Gurnis, D.J. Bower, and D. M´uller. Provenance of plumes in global
convection models. Geochem. Geophys. Geosyst., 16:1465–1489, 2015.
[278] R. Hassani, D. Jongmans, and Jean Ch´ery. Study of plate deformation and stress in subduction
processes using two-dimensional numerical models. J. Geophys. Res., 102(B8):17,951–17,96, 1997.
[279] K.L. Haynie and M.A. Jadamec. Tectonic drivers of the Wrangell block: Insights on fore-arc sliver
processes from 3-D geodynamic models of Alaska. Tectonics, 36, 2017.
[280] Y. He, E.G. Puckett, and M.I. Billen. A discontinuous Galerkin method with a bound preserving
limiter for the advection of non-diffusive fields in solid Earth geodynamics. Phys. Earth. Planet. In-
ter., 263:23–37, 2017.
277
[281] C. Heine and S. Brune. Oblique rifting of the Equatorial Atlantic: Why there is no Saharan Atlantic
Ocean. Geology, 42(3):211–214, 2014.
[282] T. Heister, J. Dannberg, R. Gassm¨oller, and W. Bangerth. High Accuracy Mantle Convection
Simulation through Modern Numerical Methods. II: Realistic Models and Problems. Geophy. J. Int.,
210(2):833–851, 2017.
[283] P. J. Heron, R. N. Pysklywec, R. Stephenson, and J. van Hunen. Deformation driven by deep and
distant structures: Influence of a mantle lithosphere suture in the ouachita orogeny, southeastern
united states. Geology, 2018.
[284] P.J. Heron, R.N. Pysklywec, and R. Stephenson. Intraplate orogenesis within accreted and scarred
lithosphere: Example of the Eurekan Orogeny, Ellesmere Island. Tectonophysics, 2015.
[285] B.H. Heyn, C.P. Conrad, and R.G. Tronnes. Stabilizing Effect of Compositional Viscosity Contrasts
on Thermochemical Piles. Geophys. Res. Lett., 45:7523–7532, 2018.
[286] J.M. Hines and M.I. Billen. Sensitivity of the short- to intermediate-wavelength geoid to rheologic
structure in subduction zones. J. Geophys. Res., 117(B05410), 2012.
[287] T. H¨oink and A. Lenardic. Three-dimensional mantle convection simulations with a low-viscosity
asthenosphere and the relationship between heat flow and the horizontal length scale of convection.
Geophys. Res. Lett., 35(L10304), 2008.
[288] P. Hood and C. Taylor. NavierStokes equations using mixed interpolation. In J.T. Oden, R.H.
Gallagher, O.C. Zienkiewicz, and C. Taylor, editors, Finite element methods in flow problems.
Huntsville Press, University of Alabama, 1974.
[289] Ch. Huber, A. Parmigiani, B. Chopard, M. Manga, and O. Bachmann. Lattice Boltzmann model
for melting with natural convection. International Journal of Heat and Fluid Flow, 29:1469–1480,
200.
[290] T.J.R. Hughes. The Finite Element Method. Linear Static and Dynamic Finite Element Analysis.
Dover Publications, Inc., 2000.
[291] T.J.R. Hughes, L.P. Franca, and M. Balestra. A new finite element formulation for computational
fluid dynamics: V. Circumventing the Babuka-Brezzi condition: A stable Petrov-Galerkin formu-
lation of the Stokes problem accommodating equal-order interpolations. Computer Methods in
Applied Mechanics and Engineering, 59(1):85–99, 1986.
[292] T.J.R. Hughes, W.K. Liu, and A. Brooks. Finite element analysis of Incompressible viscous flows
by the penalty function formulation. J. Comp. Phys., 30:1–60, 1979.
[293] Hoon Huh, Choong Ho Lee, and Wei H. Yang. A general algorithm for plastic flow simulation by
finite element limit analysis. International Journal of Solids and Structures, 36:1193–1207, 1999.
[294] R. Huismans and C. Beaumont. Depth-dependent extension, two-stage breakup and cratonic un-
derplating at rifted margins. Nature, 473:74–79, 2011.
[295] R. S. Huismans and C. Beaumont. Symmetric and asymmetric lithospheric extension: Relative
effects of frictional-plastic and viscous strain softening. J. Geophys. Res., 108 (B10)(2496), 2003.
[296] R.S. Huismans and C. Beaumont. Complex rifted continental margins explained by dynamical
models of depth-dependent lithospheric extension. Geology, 30(3):211–214, 2002.
[297] R.S. Huismans and C. Beaumont. Roles of lithospheric strain softening and heterogeneity in de-
termining the geometry of rifts and continental margins. In Imaging, Mapping and Modelling
Continental Lithosphere Extension and Breakup, volume 282, pages 111–138. Geological Society,
London, Special Publications, 2007.
[298] R.S. Huismans, S.J.H. Buiter, and C. Beaumont. Effect of plastic-viscous layering and strain
softening on mode selection during lithospheric extension. J. Geophys. Res., 110:B02406, 2005.
278
[299] L. Husson, C.P. Conrad, and C. Faccenna. Plate motions, Andean orogeny, and volcanism above
the South Atlantic convection cell. Earth Planet. Sci. Lett., 317-318:126–135, 2012.
[300] F. Ilinca and D. Pelletier. Computation of accurate nodal derivatives of finite element solutions:
The finite node displacement method. Int. J. Num. Meth. Eng., 71:1181–1207, 2007.
[301] Alik Ismail-Zadeh and Paul Tackley. Computational Methods for Geodynamics. Cambridge Uni-
versity Press, 2010.
[302] J. Ita and S.D. King. Sensitivity of convection with an endothermic phase change to the form of gov-
erning equations, initial conditions, boundary conditions, and equation of state. J. Geophys. Res.,
99(B8):15,919–15,938, 1994.
[303] J. Ita and S.D. King. The influence of thermodynamic formulation on simulations of subduction
zone geometry and history. Geophys. Res. Lett., 25(9):1463–1466, 1998.
[304] M.A. Jadamec and M.I. Billen. The role of rheology and slab shape on rapid mantle flow: Three-
dimensional numerical models of the Alaska slab edge. J. Geophys. Res., 117(B02304), 2012.
[305] M.A. Jadamec, M.I. Billen, and S.M. Roeske. Three-dimensional numerical models of flat slab sub-
duction and the Denali fault driving deformation in south-central Alaska. Earth Planet. Sci. Lett.,
376:29–42, 2013.
[306] S. Jammes and R.S. Huismans. Structural styles of mountain building: Controls of lithospheric
rheologic stratification and extensional inheritance. J. Geophys. Res., 117, 2012.
[307] S. Jammes, R.S. Huismans, and J.A. Mu˜noz. Lateral variation in structural style of mountain
building: controls of rheological and rift inheritance. Terra Nova, 0:doi:10.1111/ter.12087, 2013.
[308] Y. Jaquet, Th. Duretz, and S.M. Schmalholz. Dramatic effect of elasticity on thermal softening
and strain localization during lithospheric shortening. Geophy. J. Int., 204:780–784, 2016.
[309] G.T. Jarvis. Effects of curvature on two-dimensional models of mantle convection: cylindrical polar
coordinates. J. Geophys. Res., 98(B3):4477–4485, 1993.
[310] C. Jaupart and J.-C. Mareschal. Heat Generation and Transport in the Earth. Cambridge, 2011.
[311] V. John. Finite Element Methods for Incompressible Flow Problems . Springer, 2016.
[312] L. Jolivet, P. Davy, and P. Cobbold. Right-lateral shear along the Northwest Pacific margin and
the India-Eurasia collision. Tectonics, 9(6):1409–1419, 1990.
[313] A. Jourdon, L. Le Pourhiet, Mouthereau F, and E. Masini. Role of rift maturity on the architecture
and shortening distribution in mountain belts. Earth Planet. Sci. Lett., 512:89–99, 2019.
[314] A. Jourdon, L. Le Pourhiet, C. Petit, and Y. Rolland. Impact of range-parallel sediment transport
on 2D thermo-mechanical models of mountain belts: Application to the Kyrgyz Tien Shan. Terra
Nova, 30:279–288, 2018.
[315] L.M. Kachanov. Fundamentals of the Theory of Plasticity. Dover Publications, Inc., 2004.
[316] L. Kaislaniemi and J. van Hunen. Dynamics of lithospheric thinning and mantle melting by
edge-driven convection: Application to Moroccan Atlas mountains. Geochem. Geophys. Geosyst.,
15:3175–3189, 2014.
[317] B. Kaus. Modelling approaches to geodynamic processes, PhD thesis. PhD thesis, ETH Zurich,
2005.
[318] B.J.P. Kaus. Factors that control the angle of shear bands in geodynamic numerical models of
brittle deformation. Tectonophysics, 484:36–47, 2010.
[319] B.J.P. Kaus, H. M¨uhlhaus, and D.A. May. A stabilization algorithm for geodynamic numerical
simulations with a free surface. Phys. Earth. Planet. Inter., 181:12–20, 2010.
279
[320] B.J.P. Kaus, A.A. Popov, T.S. Baumann, A.E. Pusok, A. Bauville, N. Fernandez, and M. Col-
lignon. Forward and Inverse Modelling of Lithospheric Deformation on Geological Timescales. NIC
Symposium 2016, pages 299–307, 2016.
[321] M. Kawaguti. Numerical solution of the Navier-Stokes equations for the flow in a two-dimensional
cavity. Journal of the Physical Society of Japan, 16(12):2307–2315, 1961.
[322] D.F. Keppie, C.A. Currie, and C. Warren. Subduction erosion modes: comparing finite element
numerical models with the geological record. Earth Planet. Sci. Lett., 287:241–254, 2009.
[323] M. Kimmritz and M. Braack. iDiscretization of the hydrostatic Stokes system by stabilized finite
elements of equal order.
[324] S. King, C. Lee, P. van Keken, W. Leng, S. Zhong, E. Tan, N. Tosi, and M. Kameyama. A commu-
nity benchmark for 2D Cartesian compressible convection in the Earths mantle. Geophy. J. Int.,
180:7387, 2010.
[325] S.D. King. On topography and geoid from 2-D stagnant lid convection calculations. Geochem. Geo-
phys. Geosyst., 10(3), 2009.
[326] S.D. King. Venus Resurfacing Constrained by Geoid and Topography. JGR: Planets, 123:1041–
1060, 2018.
[327] S.D. King and D.L. Anderson. An alternative mechanism of flood basalt formation.
Earth Planet. Sci. Lett., 136:269–279, 1995.
[328] S.D. King and D.L. Anderson. Edge-driven convection. Earth Planet. Sci. Lett., 160:289–296, 1998.
[329] S.D. King, D.J. Frost, and D.C. Rubie. Why cold slabs stagnate in the transition zone. Geology,
page doi:10.1130/G36320.1, 2015.
[330] S.D. King, A. Raefsky, and B.H. Hager. ConMan: Vectorizing a finite element code for incompress-
ible two-dimensional convection in the Earths mantle. Phys. Earth. Planet. Inter., 59:195–208,
1990.
[331] A. Kiraly, F.A. Capitanio, F. Funiciello, and C. Faccenna. Subduction zone interaction: Controls
on arcuate belts. Geology, 2016.
[332] Erik A. Kneller, Markus Albertz, Garry D. Karner, , and Christopher A. Johnson. Testing inverse
kinematic models of paleocrustal thickness in extensional systems with high- resolution forward
thermo-mechanical models. Geochem. Geophys. Geosyst., 2013.
[333] T. Komut, R. Gray, R. Pysklywec, and O. Gogus. Mantle flow uplift of western Anatolia and the
Aegean: Interpretation from geophysical analyses and geodynamic modeling. J. Geophys. Res.,
117(B11412), 2012.
[334] H. Koopmann, S. Brune, D. Franke, and S. Breuer. Linking rift propagation barriers to excess
magmatism at volcanic rifted margins. Geology, page doi:10.1130/G36085.1, 2014.
[335] A. Koptev, A. Beniest, L. Jolivet, and S. Leroy. PlumeInduced Breakup of a Subducting Plate:
Microcontinent Formation Without Cessation of the Subduction Process. Geophys. Res. Lett.,
46:3663–3675, 2019.
[336] J.R. Koseff and R.L. Street. The Lid-Driven Cavity Flow: A Synthesis of Qualitative and Quanti-
tative Observations. J. Fluids Eng, 106:390–398, 1984.
[337] L.I.G. Kovasznay. Laminar flow behind a two-dimensional grid. Mathematical Proceedings of the
Cambridge Philosophical Society, 44(1):58–62, 1948.
[338] Peter Kovesi. Good colour maps: How to design them. CoRR, abs/1509.03700, 2015.
[339] M. Kronbichler, T. Heister, and W. Bangerth. High accuracy mantle convection simulation through
modern numerical methods . Geophy. J. Int., 191:12–29, 2012.
280
[340] D. Kurfess and O. Heidbach. CASQUS: A new simulation tool for coupled 3D finite element
modeling of tectonic and surface processes based on ABAQUS and CASCADE. Computers and
Geosciences, 35:1959–1967, 2009.
[341] W. Landry, L. Hodkinson, and S. Kientz. Gale user manual. Technical report, CIG, VPAC, 2011.
[342] A. Lavecchia, C. Thieulot, F. Beekman, S. Cloetingh, and S. Clark. Lithosphere erosion and con-
tinental breakup: Interaction of extension, plume upwelling and melting. Earth Planet. Sci. Lett.,
467:89–98, 2017.
[343] L. Le Pourhiet, B. Huet, D.A. May, L. Labrousse, and L. Jolivet. Kinematic interpretation of the
3D shapes of metamorphic core complexes. Geochem. Geophys. Geosyst., 13(Q09002), 2012.
[344] S.M. Lechmann, D.A. May, B.J.P. Kaus, and S.M. Schmalholz. Comparing thin-sheet models with
3-D multilayer models for continental collision. Geophy. J. Int., 187:10–33, 2011.
[345] S.M. Lechmann, S.M. Schmalholz, G. Hetenyi, D.A. May, and B.J.P. Kaus. Quantifying the impact
of mechanical layering and underthrusting on the dynamics of the modern India-Asia collisional
system with 3-D numerical models. J. Geophys. Res., 119:doi:10.1002/2012JB009748, 2014.
[346] R. Lee, P. Gresho, and R. Sani. Smooting techniques for certain primitive variable solutions of the
Navier-Stokes equations. . Int. Journal for Numerical Methods in Engineering, 14:1785–1804, 1979.
[347] V. Lemiale, H.-B. M¨uhlhaus, L. Moresi, and J. Stafford. Shear banding analysis of plastic models
formulated for incompressible viscous flows. Phys. Earth. Planet. Inter., 171:177–186, 2008.
[348] A. Lenardic, L. Moresi, A.M. Jellinek, C.J. O’Neill, C.M. Cooper, and C.T. Lee. Continents, super-
continents, mantle thermal mixing, and mantle thermal isolation: Theory, numerical simulations,
and laboratory experiments. Geochem. Geophys. Geosyst., 12(10), 2011.
[349] W. Leng, M. Gurnis, and P. Asimov. From basalts to boninites: The geodynamics of volcanic
expression during induced subduction initiation. Initiation and Termination of Subduction: Rock
Re- cord, Geodynamic Models, Modern Plate Boundaries, 2012.
[350] W. Leng and S. Zhong. Viscous heating, adiabatic heating and energetic consistency in compressible
mantle convection. Geophy. J. Int., 173:693–702, 2008.
[351] W. Leng and S. Zhong. Implementation and application of adaptive mesh refinement for thermo-
chemical mantle convection studies. Geochem. Geophys. Geosyst., 12(4), 2011.
[352] Wei Leng and Michael Gurnis. Dynamics of subduction initiation with different evolutionary path-
ways. Geochem. Geophys. Geosyst., 12(12):Q12018, doi:10.1029/2011GC003877, 2011.
[353] Wei Leng and Michael Gurnis. Subduction initiation at relic arcs. Geophys. Res. Lett., 42:7014–
7021, 2015.
[354] J. Li, Y. He, and Z. Chen. Performance of several stabilized finite element methods for the Stokes
equations based on the lowest equal-order pairs. Computing, 86:37–51, 2009.
[355] Z.-H. Li, Z. Xu, T. Gerya, and J.-P. Burg. Collision of continental corner from 3-D numerical
modeling. Earth Planet. Sci. Lett., 380:98–111, 2013.
[356] Z.H. Li, Z.Q. Xu, and T.V. Gerya. Flat versus steep subduction: Contrasting modes for the
formation and exhumation of high- to ultrahigh-pressure rocks in continental collision zones.
Earth Planet. Sci. Lett., 301:65–77, 2011.
[357] Z.-X. Lia and S. Zhong. Supercontinentsuperplume coupling, true polar wander and plume mobility:
Plate dominance in whole-mantle tectonics. Phys. Earth. Planet. Inter., 176:143–156, 2009.
[358] J. Liao and T. Gerya. From continental rifting to seafloor spreading: Insight from 3D thermo-
mechanical modeling. Gondwana Research, 2014.
281
[359] J. Liao and T. Gerya. Influence of lithospheric mantle stratification on craton exten-
sion: Insight from two-dimensional thermo-mechanical modeling. Tectonophysics, page
doi:10.1016/j.tecto.2014.01.020, 2014.
[360] S.-C. Lin and P.E. van Keken. Dynamics of thermochemical plumes: 1. Plume formation and
entrainment of a dense layer. Geochem. Geophys. Geosyst., 7(2), 2006.
[361] S.-C. Lin and P.E. van Keken. Dynamics of thermochemical plumes: 2. Complexity of plume
structures and its implications for mapping mantle plumes . Geochem. Geophys. Geosyst., 7(3),
2006.
[362] L. Liu and D.R. Stegman. Segmentation of the Farallon slab. Earth Planet. Sci. Lett., 311:1–10,
2011.
[363] S. Liu and C.A. Currie. Farallon plate dynamics prior to the Laramide orogeny: Numerical models
of flat subduction. Tectonophysics, 666:33–47, 2016.
[364] S. Liu and S.D. King. A benchmark study of incompressible Stokes flow in a 3-D spherical shell
using ASPECT. Geophy. J. Int., 217:650–667, 2019.
[365] X. Liu and S. Zhong. Analyses of marginal stability, heat transfer and boundary layer properties for
thermal convection in a compressible fluid with infinite Prandtl number. Geophy. J. Int., 194:125–
144, 2013.
[366] Z. Liu and P. Bird. Two-dimensional and three-dimensional finite element modelling of mantle
processes beneath central South Island, New Zealand. Geophy. J. Int., 165:1003–1028, 2006.
[367] C. Loiselet, J. Braun, L. Husson, C. Le Carlier de Veslud, C. Thieulot, P. Yamato, and
D. Grujic. Subducting slabs: Jellyfishes in the Earth’s mantle. Geochem. Geophys. Geosyst.,
11(8):doi:10.1029/2010GC003172, 2010.
[368] G. Lu, B.J.P. Kaus, L. Zhao, and T. Zheng. Self-consistent subduction initiation induced by mantle
flow. Terra Nova, page doi: 10.1111/ter.12140, 2015.
[369] M. Maffione, C. Thieulot, D.J.J. van Hinsbergen, A. Morris, O. Pl¨umper, and W. Spakman. Dynam-
ics of intraoceanic subduction initiation: 1. Oceanic detachment fault inversion and the formation
of supra-subduction zone ophiolites. Geochem. Geophys. Geosyst., 16:1753–1770, 2015.
[370] V. Magni, M.B. Allen, J. van Hunen, and P. Bouilhol. Continental underplating after slab break-off.
Earth Planet. Sci. Lett., 474:59–67, 2017.
[371] V. Magni, P. Bouilhol, and J. van Hunen. Deep water recycling through time. Geochem. Geo-
phys. Geosyst., 15:4203–4216, 2014.
[372] C. Malatesta, T. Gerya, L. Crispini, L. Federico, and G. Capponi. Oblique subduction modelling
indicates along-trench tectonic transport of sediments. Nature Communications, 4, 2013.
[373] C. Malatesta, T. Gerya, L. Crispini, L. Federico, and G. Capponi. Interplate deformation at early-
stage oblique subduction: 3-D thermomechanical numerical modeling. Tectonics, 35:1610–1625,
2016.
[374] D.S. Malkus and T.J.R. Hughes. Mixed finite element methods - reduced and selective integration
techniques: a unification of concepts. Comput. Meth. Appl. Mech. Eng., 15:63–81, 1978.
[375] L.E. Malvern. Introduction to the mechanics of a continuous medium. Prentice-Hall, Inc., 1969.
[376] V. Manea and M. Gurnis. Subduction zone evolution and low viscosity wedges and channels.
Earth Planet. Sci. Lett., 264:22–45, 2007.
[377] V.C. Manea, W.P. Leeman, T. Gerya, M. Manea, and G. Zhu. Subduction of fracture zones
controls mantle melting and geochemical signature above slabs. Nature Communications, page
doi:10.1038/ncomms6095, 2014.
282
[378] G. Maniatis, D. Kurfess, A. Hampel, and O. Heidbach. Slip acceleration on normal faults due
to erosion and sedimentation Results from a new three-dimensional numerical model coupling
tectonics and landscape evolution. Earth Planet. Sci. Lett., 284:570–582, 2009.
[379] G. Marketos, R. Govers, and C.J. Spiers. Ground motions induced by a producing hydrocarbon
reservoir that is overlain by a viscoelastic rocksalt layer: a numerical model. Geophy. J. Int.,
203:228–242, 2015.
[380] A.M. Marotta and M.I. Spalla. Permian-Triassic high thermal regime in the Alps: Result of
late Variscan collapse or continental rifting? Validation by numerical modeling. Tectonics,
26(TC4016):oi:10.1029/2006TC002047, 2007.
[381] A.M. Marotta, E. Spelta, and C. Rizzetto. Gravity signature of crustal subduction inferred from
numerical modelling. Geophys. J. Int., 166:923–938, 2006.
[382] F.O. Marques and B.J.P. Kaus. Speculations on the impact of catastrophic subduction initiation
on the Earth System. Journal of Geodynamics, 93:1–16, 2016.
[383] F.O. Marques, K. Nikolaeva, M. Assumpcao, T.V. Gerya, F.H.R. Bezerra, A.F. do Nascimento,
and J.M. Ferreira. Testing the influence of far-field topographic forcing on subduction initiation at
a passive margin. Tectonophysics, 608:517–524, 2013.
[384] J. Martinod, V. Regard, Y. Letourmy, H. Henry, R. Hassani, S. Baratchart, and S. Carretier. How
do subduction processes contribute to forearc Andean uplift? Insights from numerical models.
Journal of Geodynamics, 2015.
[385] W.G. Mason, L. Moresi, P.G. Betts, and M.S. Miller. Three-dimensional numerical models of the
influence of a buoyant oceanic plateau on subduction zones. Tectonophysics, 483:71–79, 2010.
[386] B. Maunder, J. van Hunen, P. Bouilhol, and V. Magni. Modeling Slab Temperature: A Reevaluation
of the Thermal Parameter. Geochem. Geophys. Geosyst., 2019.
[387] D.A. May. Volume reconstruction of point cloud data sets derived from computational geodynamic
simulations. Geochem. Geophys. Geosyst., 13(5):Q05019, 2012.
[388] D.A. May, J. Brown, and L. Le Pourhiet. A scalable, matrix-free multigrid preconditioner for finite
element discretizations of heterogeneous Stokes flow. Computer Methods in Applied Mechanics and
Engineering, 290:496–523, 2015.
[389] D.P. McKenzie. Speculations on the consequences and causes of plate motions. Geophys. J. R.
astr. Soc., 18:1–32, 1969.
[390] D.P. McKenzie. Temperature and potential temperature beneath island arcs. Tectonophysics,
10:357–366, 1970.
[391] C.A. M´eriaux, A. May D, J. Mansour, Z. Chen, and O. Kaluza. Benchmark of three-dimensional
numerical models of subduction against a laboratory experiment. Phys. Earth. Planet. Inter.,
283:110–121, 2018.
[392] A. Mizukami. A mixed Finite Element method for boundary flux computation. Computer Methods
in Applied Mechanics and Engineering, 57:239–243, 1986.
[393] P. Molnar and P. Tapponnier. Relation of the tectonics of eastern China to the India-Eurasia
collision: Application of the slip-line field theory to large-scale continental tectonics. Geology,
5:212–216, 1977.
[394] C. Morency, R.S. Huismans, C. Beaumont, and P. Fullsack. A numerical model for coupled fluid
flow and matrix deformation with applications to disequilibrium compaction and delta stability.
J. Geophys. Res., 112(B10407), 2007.
[395] L. Moresi, P.G. Betts, M.S. Miller, and R.A. Cayley. Dynamics of continental accretion. Nature,
2014.
283
[396] L. Moresi, F. Dufour, and H.B. M¨uhlhaus. A Lagrangian integration point finite element method
for large deformation modeling of visco-elastic geomaterials. J. Comp. Phys., 184(2):476–497, 2003.
[397] L. Moresi, S. Quenette, V. Lemiale, C. M´eriaux, B. Appelbe, and H.-B. M¨uhlhaus. Computational
approaches to studying non-linear dynamics of the crust and mantle. Phys. Earth. Planet. Inter.,
163:69–82, 2007.
[398] L. Moresi and V. Solomatov. Mantle convection with a brittle lithosphere: thoughts on the global
tectonics styles of the earth and venus. Geophys. J. Int., 133:669–682, 1998.
[399] M. Morishige and P.E. van Keken. Along-arc variation in the 3-D thermal structure around the
junction between the Japan and Kurile arcs. Geochem. Geophys. Geosyst., 15:2225–2240, 2014.
[400] R. Moucha, A.M. Forte, J.X. Mitrovica, and A. Daradich. Lateral variations in mantle rheology: im-
plications for convection related surface observables and inferred viscosity models. Geophy. J. Int.,
169:113–135, 2007.
[401] M.A. Murphy, M.H. Taylor, J. Gosse, C.R.P. Silver, D.M. Whipp, and C. Beaumont. Limit of strain
partitioning in the Himalaya marked by large earthquakes in western Nepal. Nature Geoscience,
2013.
[402] J. Naliboff and S.J.H. Buiter. Rift reactivation and migration during multiphase extension.
Earth Planet. Sci. Lett., 421:58–67, 2015.
[403] J.B. Naliboff, M.I. Billen, T. Gerya, and J. saunders. Dynamics of outer-rise faulting in oceanic-
continental subduction systems. Geochem. Geophys. Geosyst., 14(7):10.1002/ggge.20155, 2013.
[404] J.B. Naliboff, C. Lithgow-Bertelloni, L.J. Ruff, and N. de Koker. The effects of lithospheric thickness
and density structure on Earths stress field. Geophy. J. Int., 188:1–17, 2012.
[405] A.M. Negredo, R. Sabadini, G. Bianco, and M. Fernandez. Three-dimensional modelling of crustal
motions caused by subduction and continental convergence in the central Mediterranean. Geo-
phy. J. Int., 136:261–274, 1999.
[406] A.M. Negredo, R. Sabadini, and C. Giunchi. Interplay between subduction and continental con-
vergence:a three- dimensional dynamic model for the Central Mediterranean. Geophy. J. Int.,
131:F9–F13, 1997.
[407] M. Nettesheim, T.A. Ehlers, D.M. Whipp, and A. Koptev. The influence of upper-plate advance
and erosion on overriding plate deformation in orogen syntaxes. Solid Earth, 9:1207–1224, 2018.
[408] K. Nikolaeva, T.V. Gerya, and F.O. Marques. Subduction initiation at passive margins: numerical
modeling. J. Geophys. Res., 115(B03406), 2010.
[409] F. Nilfouroushan, R. Pysklywec, A. Cruden, and H. Koyi. Thermal-mechanical modeling of salt-
based mountain belts with pre-existing basement faults: Application to the Zagros fold and thrust
belt, southwest Iran. Tectonics, 32:1212–1226, 2013.
[410] L. Noack, A. Rivoldini, and T. Van Hoolst. CHIC Coupling Habitability, Interior and Crust. INFO-
COMP 2015 : The Fifth International Conference on Advanced Communications and Computation,
2015.
[411] S. Norburn and D. Silvester. Fourier analysis of stabilized Q1-Q1 mixed finite element approxima-
tion. SIAM J. Numer. Anal., 39:817–833, 2001.
[412] P. Olson, R. Deguen, L.A. Hinnov, and S. Zhong. Controls on geomagnetic reversals and core
evolution by mantle convection in the Phanerozoic. Phys. Earth. Planet. Inter., 214:87–103, 214.
[413] C. O’Neill, S. Marchi, S. Zhang, and W. Bottke. Impact-driven subduction on the hadean earth.
Nature Geoscience, 10(10):793, 2017.
284
[414] C. O’Neill, L. Moresi, D. M¨uller, R. Albert, and F. Dufour. Ellipsis 3D: a particle-in-cell finite
element hybrid code for modelling mantle convection and lithospheric deformation. Computers and
Geosciences, 32:1769–1779, 2006.
[415] C. J. O’Neill and S. Zhang. Lateral mixing processes in the hadean. Journal of geophysical research.,
123:7074¡96¿ 7089, 2018.
[416] C.J. O’Neill, A. Lenardic, W.L. Griffin, and S.Y. O’Reilly. Dynamics of cratons in an evolving
mantle. Lithos, 102:12–24, 2008.
[417] M. OzBench, K. Regenauer-Lieb, D.R. Stegman, G. Morra, R. Farrington, A. Hale, D.A. May,
J. Freeman, L. Bourgoin, H.-B. M¨uhlhaus, and L. Moresi. A model comparison study of large-scale
mantle-lithosphere dynamics driven by subduction. Phys. Earth. Planet. Inter., 171:224–234, 2008.
[418] C. ONeill, A. Lenardic, M. Weller, L. Moresi, S. Quenette, and S. Zhang. A window for plate
tectonics in terrestrial planet evolution? Phys. Earth. Planet. Inter., 255(80–92), 2016.
[419] F. Pan and A. Acrivos. Steady flows in rectangular cavities. J. Fluid Mech., 28(4):643–655, 1967.
[420] G. Peltzer and P. Tapponnier. Formation and evolution of strike-slip faults, rifts, and basins during
the india-asia collision: an experimental approach. J. Geophys. Res., 93(B12):15085–15177, 1988.
[421] J. Perry-Houts and L. Karlstrom. Anisotropic viscosity and time-evolving lithospheric instabilities
due to aligned igneous intrusions. Geophysical Journal International, 216(2):794–802, 2018.
[422] M. Peters, M. Veveakis, T. Poulet, A. Karrech, M. Herwegh, and K. Regenauer-Lieb. Boudinage as
a material instability of elasto-visco-plastic rocks. Journal of Structural Geology, 78:86–102, 2015.
[423] Thomas Philippe. Single viscous layer fold interplay and linkage. PhD thesis, ETH Zurich, 2013.
[424] B.R. Phillips, H.-P. Bunge, and K. Schaber. True polar wander in mantle convection models with
multiple, mobile continents. Gondwana Research, 15:288–296, 2009.
[425] A. Pinelli and A. Vacca. Chebyshev collocation method and multidomain decomposition for the
incompressible Navier-Stokes equations. International Journal for numerical methods in fluids,
18:781–799, 1994.
[426] C. Piromallo, T.W. Becker, F. Funiciello, and C. Faccenna. Three-dimensional instantaneous mantle
flow induced by subduction. Geophys. Res. Lett., 33(L08304), 2006.
[427] J. Pitk¨aranta and T. Saarinen. A Multigrid Version of a Simple Finite Element Method for the
Stokes Problem. Mathematics of Computation, 45(171):1–14, 1985.
[428] T. Plank and P.E. van Keken. The ups and downs of sediments. Nature Geoscience, 1:17, 2008.
[429] A. Plunder, C. Thieulot, and D.J.J. van Hinsbergen. The effect of obliquity on temperature in
subduction zones: insights from 3D numerical modeling. Solid Earth, 9:759–776, 2018.
[430] A. Poliakov, P. Cundall, P. Podlachikov, and V. Lyakhovsky. An explicit inertial method for the
simulation of viscoelastic flow: an evaluation of elastic effects on diapiric flow in two- and three-
layers models. In Flow and creep in the solar system: Observations, Modeling and theory, pages
175–195. Kluwer Academic Publishers, 1993.
[431] A.A. Popov and S.V. Sobolev. SLIM3D: a tool for three-dimensional thermomechanical modelling of
lithospheric deformation with elasto-visco-plastic rheology. Phys. Earth. Planet. Inter., 171(1):55–
75, 2008.
[432] A. Prosperetti. Motion of two superposed viscous fluids. Phys. Fluids, 24(7):1217–1223, 1981.
[433] E. G. Puckett, D. L. Turcotte, Y. He, H. Lokavarapu, J. M. Robey, and L. H. Kellogg. New
numerical approaches for modeling thermochemical convection in a compositionally stratified fluid.
Physics of the Earth and Planetary Interiors, 276:10–35, 2018.
285
[434] A.E. Pusok and B.J.P. Kaus. Development of topography in 3D continental collision models.
Geochem. Geophys. Geosyst., page doi:10.1002/2015GC005732, 2015.
[435] A.E. Pusok, B.J.P. Kaus, and A.A. Popov. On the Quality of Velocity Interpolation
Schemes for Marker-in-Cell Method and Staggered Grids. Pure and Applied Geophysics, pages
doi:10.1007/s00024–016–1431–8, 2016.
[436] C. P¨uthe and T. Gerya. Dependence of mid-ocean ridge morphology on spreading rate in numerical
3-D models. Gondwana Research, 25:270–283, 2014.
[437] R.N. Pysklywec. Surface erosion control on the evolution of the deep lithosphere. Geology, 34:225–
228, 2006.
[438] R.N. Pysklywec and C. Beaumont. Intraplate tectonics: feedback between radioactive thermal weak-
ening and crustal deformation driven by mantle lithosphere instabilities. Earth Planet. Sci. Lett.,
221:275–292, 2004.
[439] R.N. Pysklywec, C. Beaumont, and P. Fullsack. Modeling the behavior of continental mantle
lithosphere during plate convergence. Geology, 28(7):655–658, 2000.
[440] R.N. Pysklywec, C. Beaumont, and P. Fullsack. Lithospheric deformation during the early stages
of continental collision: Numerical experiments and comparison with South Island, New Zealand.
J. Geophys. Res., 107(B72133), 2002.
[441] R.N. Pysklywec and A.R. Cruden. Coupled crust-mantle dynamics and intraplate tectonics: Two-
dimensional numerical and three-dimensional analogue modeling. Geochem. Geophys. Geosyst.,
5(10), 2004.
[442] R.N. Pysklywec, S.M. Ellis, and A.R. Gorman. Three-dimensional mantle lithosphere deformation
at collisional plate boundaries: A subduction scissor across the South Island of New Zealand.
Earth Planet. Sci. Lett., 289:334–346, 2010.
[443] R.N. Pysklywec, O. Gogus, J. Percival, A.R. Cruden, and C. Beaumont. Insights from geodynamical
modeling on possible fates of continental mantle lithosphere: collision, removal, and overturn. Can.
J. Earth Sci., 47:541–563, 2010.
[444] R.N. Pysklywec, J.X. Mitrovica, and M. Ishii. Mantle avalanche as a driving force for tectonic
reorganization in the southwest Pacic. Earth Planet. Sci. Lett., 209:29–38, 2003.
[445] S. Quenette, Y. Xi, J. Mansour, L. Moresi, and D. Abramson. Underworld-GT Applied to Guang-
dong, a Tool to Explore the Geothermal Potential of the Crust. Journal of Earth Sciences, 26(1):78–
88, 2015.
[446] S. Quere, J.P. Lowman, J. Arkani-Hamed, J.H. Roberts, and R. Moucha. Subcontinental sinking
slab remnants in a spherical geometry mantle model. J. Geophys. Res., 118:1760–1777, 2013.
[447] Matthieu E.T. Quinquis, Suzanne J.H. Buiter, and Susan Ellis. The role of boundary conditions in
numerical models of subduction zone dynamics. Tectonophysics, 497:57–70, 2011.
[448] M.E.T. Quinquis and S.J.H. Buiter. Testing the effects of basic numerical implementations of water
migration on models of subduction dynamics. Solid Earth, 5:537–555, 2014.
[449] J. Quinteros, V.A. Ramos, and P.M. Jacovkis. An elasto-visco-plastic model using the finite element
method for crustal and lithospheric deformation. Journal of Geodynamics, 48:83–94, 2009.
[450] J. Quinteros, S.V. Sobolev, and A.A. Popov. Viscosity in transition zone and lower mantle: Impli-
cations for slab penetration . Geophys. Res. Lett., 37(L09307,), 2010.
[451] T. Rabczuk, P.M.A. Areias, and T. Belytschko. A simplified mesh-free method for shear bands
with cohesive surfaces . Int. J. Num. Meth. Eng., 69:993–1021, 2007.
[452] J.N. Reddy. On penalty function methods in the finite element analysis of flow problems.
Int. J. Num. Meth. Fluids, 2:151–171, 1982.
286
[453] J.N. Reddy and D.K. Gartling. The Finite Element Method in Heat Transfer and Fluid Dynamics.
CRC Press, 2010.
[454] J. Revenaugh and B. Parsons. Dynamic topography and gravity anomalies for fluid layers whose
viscosity varies exponentially with depth. Geophysical Journal of the Royal Astronomical Society,
90(2):349–368, 1987.
[455] J.G. Rice and R.J. Schnipke. An equal-order velocity-pressure formulation that does not exhibit
spurious pressure modes. Computer Methods in Applied Mechanics and Engineering, 58:135–149,
1986.
[456] J. Ritsema, A.K. McNamara, and A.L. Bull. Tomographic filtering of geodynamic models: Impli-
cations for model interpretation and large-scale mantle structure. J. Geophys. Res., 112(B01303),
2007.
[457] M. Roda, A.M. Marotta, and M.I. Spalla. Numerical simulations of an oceancontinent conver-
gent system: Influence of subduction geometry and mantle wedge hydration on crustal recycling.
Geochem. Geophys. Geosyst., 11(5):10.1029/2009GC003015, 2010.
[458] T. Rolf and P.J. Tackley. Focussing of stress by continents in 3D spherical mantle convection with
selfconsistent plate tectonics. Geophys. Res. Lett., 38(L18301):10.1029/2011GL048677, 2011.
[459] I. Rose, B. Buffet, and T. Heister. Stability and accuracy of free surface time integration in viscous
flows. Phys. Earth. Planet. Inter., 262:90–100, 2017.
[460] I. Rose and B. Buffett. Scaling rates of true polar wander in convecting planets and moons. Physics
of the Earth and Planetary Interiors, 2017.
[461] J.B. Ruh, T. Gerya, and J.-P. Burg. High-resolution 3D numerical modeling of thrust wedges:
Influence of d´ecollement strength on transfer zones. Geochem. Geophys. Geosyst., 14(4):1131–1155,
2014.
[462] J.B. Ruh, L. Le Pourhiet, Ph. Agard, E. Burov, and T. Gerya. Tectonic slicing of subduct-
ing oceanic crust along plate interfaces: Numerical modeling. Geochem. Geophys. Geosyst.,
16:10.1002/2015GC005998, 2015.
[463] Y. Saad. Iterative methods for sparse linear systems. SIAM, 2003.
[464] Y. Saad and M.H. Schultz. GMRES: A Generalized Minimal Residual Algorithm for Solving Non-
symmetric Linear Systems. SIAM Journal on Scientific and Statistical Computing, 7(3):856–869,
1986.
[465] H. Samuel and M. Evonuk. Modeling advection in geophysical flows with particle level sets.
Geochem. Geophys. Geosyst., 11(8):doi:10.1029/2010GC003081, 2010.
[466] D. Sandiford and L. Moresi. Improving subduction interface implementation in dynamic numerical
models. Solid Earth, 2019.
[467] R.L. Sani, P.M. Gresho, R.L. Lee, and D.F. Griffiths. The cause and cure (?) of the spurious
pressures generated by certain FEM solutions of the incompressible Navier-Stokes equations: part
1. Int. J. Num. Meth. Fluids, 1:17–43, 1981.
[468] R.L. Sani, P.M. Gresho, R.L. Lee, D.F. Griffiths, and M. Engelman. The cause and cure (?) of the
spurious pressures generated by certain fem solutions of the incompressible navier-stokes equations:
part 2. Int. J. Num. Meth. Fluids, 1:171–204, 1981.
[469] W.P. Schellart, J. Freeman, D.R. Stegman, L. Moresi, and D. May. Evolution and diversity of
subduction zones controlled by slab width. Nature, 446:308–311, 2007.
[470] W.P. Schellart and L. Moresi. A new driving mechanism for backarc extension and backarc short-
ening through slab sinking induced toroidal and poloidal mantle flow: Results from dynamic sub-
duction models with an overriding plate. J. Geophys. Res., 118:1–28, 2013.
287
[471] W.P. Schellart and W. Spakman. Australian plate motion and topography linked to fossil New
Guinea slab below Lake Eyre. Earth Planet. Sci. Lett., 421:107–116, 2015.
[472] S.M. Schmalholz. A simple analytical solution for slab detachment. Earth Planet. Sci. Lett.,
304:45–54, 2011.
[473] H. Schmeling, A.Y. Babeyko, A. Enns, C. Faccenna, F. Funiciello, T. Gerya, G.J. Golabek,
S. Grigull, B.J.P. Kaus, G. Morra, S.M. Schmalholz, and J. van Hunen. A benchmark comparison of
spontaneous subduction models - Towards a free surface. Phys. Earth. Planet. Inter., 171:198–223,
2008.
[474] D.W. Schmid and Y.Y. Podlachikov. Analytical solutions for deformable elliptical inclusions in
general shear. Geophy. J. Int., 155:269–288, 2003.
[475] G.E. Schneider, G.D. Raithby, and M.M. Yovanovich. Finite-element solution procedures for solving
the incompressible Navier-Stokes equations using equal order variable interpolation. Numerical Heat
Transfer, 1:433–451, 1978.
[476] G. Schubert, D.L. Turcotte, and P. Olson. Mantle Convection in the Earth and Planets. Cambridge
University Press, 2001.
[477] A. Segal. Finite element methods for the incompressible Navier-Stokes equations. 2012.
[478] A. Segal and N.P. Praagman. The sepran fem package. Technical report, Technical Report, Inge-
nieursbureau Sepra, The Netherlands. http://ta.twi.tudelft.nl/sepran/sepran.html, 2005.
[479] P. Sekhar and S.D. King. 3D spherical models of Martian mantle convection constrained by melting
history. Earth Planet. Sci. Lett., 388:27–37, 2014.
[480] C. Selzer, S.J.H. Buiter, and O.A. Pfiffner. Numerical modeling of frontal and basal accretion at
collisional margins. Tectonics, 27(TC3001):doi:10.1029/2007TC002169, 2008.
[481] Cornelia Selzer. Tectonic accretion styles at convergent margins: A numerical modelling study. PhD
thesis, University of Bern, 2006.
[482] M. Seton, N. Flament, J. Whittaker, R.D. M¨uller, M. Gurnis, and D.J. Bower. Ridge sub-
duction sparked reorganization of the Pacific plate-mantle system 6050 million years ago. Geo-
phys. Res. Lett., 42:doi:10.1002/2015GL063057, 2015.
[483] P.N. Shankar and M.D. Deshpande. Fluid mechanics in the driven cavity. Annu. Rev. Fluid Mech.,
32:93–136, 2000.
[484] W. Sharples, L.-N. Moresi, and M. A. Jadamec andJ. Revote. Styles of rifting and fault spacing in
numerical models of crustal extension. J. Geophys. Res., 120:4379–4404, 2015.
[485] W. Sharples, L.N. Moresi, M. Velic, M.A. Jadamec, and D.A. May. Simulating faults and plate
boundaries with a transversely isotropic plasticity model. Phys. Earth. Planet. Inter., 252:77–90,
2016.
[486] K. Simon, R.S. Huismans, and C. Beaumont. Dynamical modelling of lithospheric extension and
small-scale convection: implications for magmatism during the formation of volcanic rifted margins.
Geophy. J. Int., 176:327–350, 2009.
[487] S.V. Sobolev, A. Petrunin, Z. Garfunkel, and A.Y. Babeyko. Thermo-mechanical model of the
Dead Sea Transform. Earth Planet. Sci. Lett., 238:78–95, 2005.
[488] S.V. Sobolev, A.V. Sobolev, D.V. Kuzmin, N.A. Krivolutskaya, A.G. Petrunin, N.T. Arndt, V.A.
Radko, and Y.R. Vasiliev. Linking mantle plumes, large igneous provinces and environmental
catastrophes. Nature, 477:312, 2011.
[489] F. Soboutia, A. Ghodsb, and J. Arkani-Hamed. On the advection of sharp material interfaces in
geodynamic problems: entrainment of the D” layer. Journal of Geodynamics, 31:459–479, 2001.
288
[490] V.S. Solomatov. Initiation of subduction by small-scale convection. J. Geophys. Res., 109(B01412),
2004.
[491] V.S. Solomatov. Localized subcritical convective cells in temperature-dependent viscosity fluids.
Phys. Earth. Planet. Inter., 200-201:63–71, 2012.
[492] V.S. Solomatov and L.-N. Moresi. Stagnant lid convection on Venus. J. Geophys. Res.,
101(E2):4737–4753, 1996.
[493] M. Spiegelman, D.A. May, and C. Wilson. On the solvability of incompressible Stokes with vis-
coplastic rheologies in geodynamics. Geochem. Geophys. Geosyst., 17:2213–2238, 2016.
[494] G. Stadler, M. Gurnis, C. Burstedde, L.C. Wilcox, L. Alisic, and O. Ghattas. The dynamics of
plate tectonics and mantle flow: from local to global scales. Science, 329:1033–1038, 2010.
[495] D.R. Stegman, R. Farrington, F.A. Capitanio, and W.P. Schellart. A regime diagram for subduction
styles from 3-D numerical models of free subduction. Tectonophysics, 483:29–45, 2010.
[496] D.R. Stegman, J. Freeman, W.P. Schellart, L. Moresi, and D. May. Influence of trench width
on subduction hinge retreat rates in 3-D models of slab rollback. Geochem. Geophys. Geosyst.,
7(3):doi:10.1029/2005GC001056, 2006.
[497] D.R. Stegman, W.P. Schellart, and J. Freeman. Competing influences of plate width and far-field
boundary conditions on trench migration and morphology of subducted slabs in the upper mantle.
Tectonophysics, 483:46–57, 2010.
[498] B. Steinberger, E. Bredow, S. Lebedev, A. Schaeffer, and T. H. Torsvik. Widespread volcanism in
the greenland-north atlantic region explained by the iceland plume. Nature Geoscience, 12(1):61,
2019.
[499] P. Sternai, L. Jolivet, A. Menant, and T. Gerya. Driving the upper plate surface deformation by
slab rollback and mantle flow. Earth Planet. Sci. Lett., 405:110–118, 2014.
[500] J. Suckale, J.-C. Nave, and B.H. Hager. It takes three to tango: 1. Simulating buoyancy-driven
flow in the presence of large viscosity contrasts. J. Geophys. Res., 115(B07409), 2010.
[501] E.M. Syracuse, P.E. van Keken, and G.A. Abers. The global range of subduction zone thermal
models. Phys. Earth. Planet. Inter., 183:73–90, 2010.
[502] P. Tackley. Three-dimensional models of mantle convection: Influence of phase transitions and
temperature-dependent viscosity. PhD thesis, California Institute of Technology, 1994.
[503] P.J. Tackley and S.D. King. Testing the tracer ratio method for modeling active compositional
fields in mantle convection simulations. Geochem. Geophys. Geosyst., 4(4), 2003.
[504] K. Takeyama, T. R. Saitoh, and J. Makino. Variable inertia method: A novel numerical method
for mantle convection simulation. New Astronomy, 2017.
[505] E. Tan, E. Choi, P. Thoutireddy, M. Gurnis, and M. Aivazis. GeoFramework: Coupling multiple
models of mantle convection within a computational framework. Geochem. Geophys. Geosyst.,
7(6):10.1029/2005GC001155, 2006.
[506] E. Tan and M. Gurnis. Compressible thermochemical convection and application to lower mantle
structures. J. Geophys. Res., 112(B06304), 2007.
[507] E. Tan, M. Gurnis, and L. Han. Slabs in the lower mantle and their modulation of plume formation.
Geochem. Geophys. Geosyst., 3(11), 2002.
[508] Paul Tapponnier and Peter Molnar. Slip-line field theory and large-scale continental tectonics.
Nature, 264:319–324, November 1976.
289
[509] J.M. Taramon, J. Rodriguez-Gonzalez, A.M. Negredo, and M.I. Billen. Influence of cratonic litho-
sphere on the formation and evolution of flat slabs: Insights from 3-D time-dependent modeling.
Geochem. Geophys. Geosyst., 16:doi:10.1002/2015GC005940, 2015.
[510] C. Tayloor and P. Hood. A numerical solution of the Navier-Stokes equations using the finite
element technique. Comput. Fluids, 1:73–100, 1973.
[511] J.L. Tetreault and S.J.H. Buiter. Geodynamic models of terrane accretion: Testing the fate of
island arcs, oceanic plateaus, and continental fragments in subduction zones. J. Geophys. Res.,
2012.
[512] J.L. Tetreault and S.J.H. Buiter. The influence of extension rate and crustal rheology on the
evolution of passive margins from rifting to break-up. Tectonophysics, 2017.
[513] T.E. Tezduyar, S. Mittal, S.E. Ray, and R. Shih. Incompressible flow computations with stabilized
bilinear and linear equal-order-interpolation velocity-pressure elements. Comput. Methods Appl.
Mech. Engrg., 95:221–242, 1992.
[514] M. Thielmann, B.J.P. Kaus, and A.A. Popov. Lithospheric stresses in RayleighBe nard convection:
effects of a free surface and a viscoelastic Maxwell rheology. Geophy. J. Int., 203:2200–2219, 2015.
[515] M. Thielmann, D.A. May, and B.J.P. Kaus. Discretization errors in the Hybrid Finite Element
Particle-In-Cell Method. Pure and Applied Geophysics, 171(9):2164–2184, 2014.
[516] C. Thieulot. FANTOM: two- and three-dimensional numerical modelling of creeping flows for the
solution of geological problems. Phys. Earth. Planet. Inter., 188(1):47–68, 2011.
[517] C. Thieulot. Analytical solution for viscous incompressible stokes flow in a spherical shell. Solid
Earth Discussions, 2017:1–19, 2017.
[518] C. Thieulot. GHOST: Geoscientific Hollow Sphere Tesselation. Solid Earth, 9(1–9), 2018.
[519] C. Thieulot and W. Bangerth. On the use of equal order elements in geodynamics. Solid Earth,
2019.
[520] C. Thieulot, P. Fullsack, and J. Braun. Adaptive octree-based finite element analysis of two- and
three-dimensional indentation problems. J. Geophys. Res., 113:B12207, 2008.
[521] C. Thieulot, P. Steer, and R.S. Huismans. Three-dimensional numerical simulations of crustal
systems undergoing orogeny and subjected to surface processes. Geochem. Geophys. Geosyst., 15,
2014.
[522] J.F. Thompson, B.K. Soni, and N.P. Weatherill. Handbook of grid generation. CRC press, 1998.
[523] N. Tosi, P. Maierov´a, and D.A. Yuen. Influence of Variable Thermal Expansivity and Conductivity
on Deep Subduction. In Subduction Dynamics: From Mantle Flow to Mega Disasters, Geophysical
Monograph 211, pages 115–133. John Wiley & Sons, Inc., 2016.
[524] N. Tosi, C. Stein, L. Noack, C. Huettig, P. Maierova, H. Samuel, D.R. Davies, C.R. Wilson,
S.C. Kramer, C. Thieulot, A. Glerum, M. Fraters, W. Spakman, A. Rozel, and P.J. Tackley. A
community benchmark for viscoplastic thermal convection in a 2-D square box. Geochem. Geo-
phys. Geosyst., 16(7):21752196, 2015.
[525] G. Toussaint, E. Burov, and J.-P. Avouac. Tectonic evolution of a continental collision zone: A
thermomechanical numerical model. Tectonics, 23(TC6003):doi:10.1029/2003TC001604, 2004.
[526] B.J. Travis, C. Anderson, J. Baumgardner, C.W. Gable, B.H. Hager, R.J. O’Connell, P. Olson,
A. Raefsky, and G. Schubert. A benchmark comparison of numerical methods for infinite Prandtl
number thermal convection in two- dimensional Cartesian geometry. Geophysical & Astrophysical
Fluid Dynamics, 55(3-4):137–160, 1990.
[527] R.A. Trompert and U. Hansen. On the Rayleigh number dependence of convection with a strongly
temperature-dependent viscosity. Physics of Fluids, 10(2):351–360, 1998.
290
[528] D.L. Turcotte and G. Schubert. Geodynamics, 2nd edition. Cambridge, 2012.
[529] K. Ueda, T. Gerya, and S.V. Sobolev. Subduction initiation by thermalchemical plumes: Numerical
studies. Phys. Earth. Planet. Inter., 171:296–312, 2008.
[530] K. Ueda, S.D. Willett, T. Gerya, and J. Ruh. Geomorphologicalthermo-mechanical modeling:
Application to orogenic wedge dynamics. Tectonophysics, 659:12–30, 2015.
[531] A. van den Berg, P.E. van Keken, and D.A. Yuen. The effects of a composite non-Newtonian and
Newtonian rheology on mantle convection. Geophy. J. Int., 115:62–78, 1993.
[532] A.P. van den Berg, M.V. De Hoop, D.A. Yuen, A. Duchkov, R.D. van der Hilst, and M.H.G. Jacobs.
Geodynamical modeling and multiscale seismic expression of thermo-chemical heterogeneity and
phase transitions in the lowermost mantle. Phys. Earth. Planet. Inter., 180:244–257, 2010.
[533] A.P. van den Berg, G. Segal, and D. Yuen. SEPRAN: A Versatile Finite-Element Package for
Realistic Problems in Geosciences. International Workshop of Deep Geothermal Systems, Wuhan,
China, June 29-30, 2012.
[534] A.P. van den Berg, G. Segal, and D.A. Yuen. SEPRAN: A Versatile Finite-Element Package for a
Wide Variety of Problems in Geosciences. Journal of Earth Science, 26(1):089–095, 2015.
[535] Y. van Dinther, T.V. Gerya, L.A. Dalguer, F. Corbi, F. Funiciello, and P.M. Mai. The seismic
cycle at subduction thrusts: 2. Dynamic implications of geodynamic simulations validated with
laboratory models. J. Geophys. Res., 118:1502–1525, 2013.
[536] Y. van Dinther, T.V. Gerya, L.A. Dalguer, P.M. Mai, G. Morra, and D. Giardini. The seismic
cycle at subduction thrusts: Insights from seismo-thermo-mechanical models. J. Geophys. Res.,
118:1–20, 2013.
[537] Y. van Dinther, P.M. Mai, L.A. Dalguer, and T.V. Gerya. Modeling the seismic cycle in subduction
zones: The role and spatiotemporal occurrence of off-megathrust earthquakes. Geophys. Res. Lett.,
41:1194–1201, 2014.
[538] H.J. van Heck, J.H. Davies, T. Elliott, and D. Porcelli. Global-scale modelling of melting and
isotopic evolution of Earths mantle: melting modules for TERRA. Geosci. Model Dev., 9:1399–
1411, 2016.
[539] J. van Hunen and M.B. Allen. Continental collision and slab break-off: A comparison of 3-D
numerical models with observations. Earth Planet. Sci. Lett., 302:27–37, 2011.
[540] J. van Hunen and M.S. Miller. Collisional processes and links to episodic changes in subduction
zones. Elements, 11:119–124, 2015.
[541] J. van Hunen, A.P. van den Berg, and N.J. Vlaar. On the role of subducting oceanic plateaus in
the development of shallow flat subduction. Tectonophysics, 352(3-4):317–333, 2002.
[542] J. van Hunen and S. Zhong. New insight in the Hawaiian plume swell dynamics from scaling laws.
Geophys. Res. Lett., 30(15):doi:10.1029/2003GL017646,, 2003.
[543] P. van Keken and S. Zhong. Mixing in a 3D spherical model of present-day mantle convection.
Earth Planet. Sci. Lett., 171:533–547, 1999.
[544] P.E. van Keken, C. Currie, S.D. King, M.D. Behn, Amandine Cagnioncle, J. Hee, R.F. Katz, S.-C.
Lin, E.M. Parmentier, M. Spiegelman, and K. Wang. A community benchmark for subduction zone
modelling. Phys. Earth. Planet. Inter., 171:187–197, 2008.
[545] P.E. van Keken, B.R. Hacker, E.M. Syracuse, and G.A. Abers. Subduction factory: 4. Depthde-
pendent flux of H2O from subducting slabs worldwide. J. Geophys. Res., 116(B01401), 2011.
[546] P.E. van Keken, S.D. King, H. Schmeling, U.R. Christensen, D. Neumeister, and M.-P. Doin.
A comparison of methods for the modeling of thermochemical convection. J. Geophys. Res.,
102(B10):22,477–22,495, 1997.
291
[547] P. van Thienen. Convective vigour and heat flow in chemically differentiated systems. Geo-
phy. J. Int., 169(2):747–766, 2007.
[548] P. van Thienen, A.P. van den Berg, J.H. de Smet, J. van Hunen, and M.R. Drury. Interac-
tion between small-scale mantle diapirs and a continental root. Geochem. Geophys. Geosyst.,
4(2):doi:10.1029/2002GC000338, 2003.
[549] P. van Thienen, A.P. van den Berg, and N.J. Vlaar. On the formation of continental silicic melts
in thermochemical mantle convection models: implications for early Earth. Tectonophysics, 394(1-
2):111–124, 2004.
[550] P. van Thienen, N.J. Vlaar, and A.P. van den Berg. Plate tectonics on the terrestrial planets.
Phys. Earth. Planet. Inter., 142:61–74, 2004.
[551] P. van Thienen, N.J. Vlaar, and A.P. van den Berg. Assessment of the cooling capacity of plate
tectonics and flood volcanism in the evolution of Earth, Mars and Venus. Phys. Earth. Planet. Inter.,
150:287–315, 2005.
[552] J.W. van Wijk, W.S. Baldridge, J. van Hunen, S. Goes, R. Aster, D.D. Coblentz, S.P. Grand, and
J. Ni. Small-scale convection at the edge of the Colorado Plateau: Implications for topography,
magmatism, and evolution of Proterozoic lithosphere. Geology, 38:611–614, 2010.
[553] O. Vanderhaeghe, S. Medvedev, P. Fullsack, C. Beaumont, and R.A. Jamieson. Evolution of oro-
genic wedges and continental plateaux: insights from crustal thermal-mechanical overlying subduc-
tion mantle lithosphere. Geophys. J. Int., 153:27–51, 2003.
[554] R.S. Varga. Matrix Iterative Analysis. Prentice-Hall, Inc., 1963.
[555] J. Vatteville, P.E. van Keken, A. Limare, and A. Davaille. Starting laminar
plumes: Comparison of laboratory and numerical modeling. Geochem. Geophys. Geosyst.,
10(12):doi:10.1029/2009GC002739, 2009.
[556] Ph. Vernant and J. Chery. Mechanical modelling of oblique convergence in the Zagros, Iran.
Geophy. J. Int., 165:991–1002, 2006.
[557] N.J. Vlaar, P.E. van Keken, and A.P. van den Berg. Cooling of the Earth in the Archean: Conse-
quences of pressure-release melting in a hotter mantle. Earth Planet. Sci. Lett., 121:1–18, 1994.
[558] K. Vogt and T. Gerya. Deep plate serpentinization triggers skinning of subducting slabs. Geology,
page doi:10.1130/G35565.1, 2014.
[559] M. von Tscharner and S. M. Schmalholz. A 3-D Lagrangian finite element algorithm with
remeshing for simulating large-strain hydrodynamic instabilities in power law viscoelastic fluids.
Geochem. Geophys. Geosyst., 16:215–245, 2015.
[560] L. Vynnytska, M.E. Rognes, and S.R. Clark. Benchmarking FEniCS for mantle convection simula-
tions. Computers & Geosciences, 50:95–105, 2013.
[561] H. Wang, R. Agrusta, and J. van Hunen. Advantages of a conservative velocity interpolation
(CVI) scheme for particle-in-cell methods with application in geodynamic modeling. Geochem. Geo-
phys. Geosyst., 16:doi:10.1002/2015GC005824, 2015.
[562] H. Wang, J. van Hunen, , and D.G. Pearson. The thinning of subcontinental lithosphere: The roles
of plume impact and metasomatic weakening. Geochem. Geophys. Geosyst., 16:1156–1171, 2015.
[563] H. Wang, J. van Hunen, D.G. Pearson, and M.B. Allen. Craton stability and longevity: The roles
of composition-dependent rheology and buoyancy. Earth Planet. Sci. Lett., 391:224–233, 2014.
[564] X. Wang, J. He, L. Ding, and R. Gao. A possible mechanism for the initiation of the Yinggehai
Basin: A visco-elasto-plastic model. Journal of Asian Earth Sciences, 74:25–36, 2013.
292
[565] Y. Wang, J. Huang, and S. Zhong. Episodic and multistaged gravitational instability of cra-
tonic lithosphere and its implications for reactivation of the North China Craton. Geochem. Geo-
phys. Geosyst., 16:815–833, 2015.
[566] C.J. Warren, C. Beaumont, and R.A. Jamieson. Formation and exhumation of ultra-high-pressure
rocks during continental collision: Role of detachment in the subduction channel. Geochem. Geo-
phys. Geosyst., 9, 2008.
[567] C.J. Warren, C. Beaumont, and R.A. Jamieson. Modelling tectonic styles and ultra-high pressure
(UHP) rock exhumation during the transition from oceanic subduction to continental collision.
Earth Planet. Sci. Lett., 267:129–145, 2008.
[568] M.B. Weller and A. Lenardic. The energetics and convective vigor of mixed-mode heating: Velocity
scalings and implications for the tectonics of exoplanets. Geophys. Res. Lett., 43, 2016.
[569] M.B. Weller, A. Lenardic, and W.B. Moore. Scaling relationships and physics for mixed heating
convection in planetary interiors: Isoviscous spherical shells. J. Geophys. Res., 121, 2016.
[570] D.M. Whipp, C. Beaumont, and J. Braun. Feeding the aneurysm: Orogen-parallel mass
transport into Nanga Parbat and the western Himalayan syntaxis. J. Geophys. Res.,
119:doi:10.1002/2013JB010929, 2014.
[571] S. D. Willett. Rheological dependence of extension in wedge models of convergent orogens. Tectono-
physics, 305:419–435, 1999.
[572] S.D. Willett. Dynamic and kinematic growth and change of a coulomb wedge. In K.R. McClay,
editor, Thrust Tectonics, pages 19–31. Chapman and Hall, 1992.
[573] S.D. Willett and C. Beaumont. Subduction of Asian lithosphere mantle beneath Tibet inferred
from models of continental collision. Nature, 369:642–645, 1994.
[574] Sean D. Willett and Daniel C. Pope. Thermo-mechanical models of convergent orogenesis: Thermal
and rheologic dependence of crustal deformation. In Rheology and deformation of the lithosphere
at continental margins., pages 166–222. Columbia University Press, 2003.
[575] M. Wolstencroft and J.H. Davies. Influence of the Ringwoodite-Perovskite transition on mantle
convection in spherical geometry as a function of Clapeyron slope and Rayleigh number. Solid
Earth, 2:315–326, 2011.
[576] M. Wolstencroft, J.H. Davies, and D.R. Davies. NusseltRayleigh number scaling for spherical shell
Earth mantle simulation up to a Rayleigh number of 109.Phys. Earth. Planet. Inter., 176:132–141,
2009.
[577] G. Wu, L.L. Lavier, and E. Choi. Modes of continental extension in a crustal wedge.
Earth Planet. Sci. Lett., 421:89–97, 2015.
[578] H. Xing, W. Yu, and J. Zhang. In Advances in Geocomputing, Lecture Notes in Earth Sciences.
Springer-Verlag, Berlin Heidelberg, 2009.
[579] P. Yamato, P. Agard, E. Burov, L. Le Pourhiet, L. Jolivet, and C. Tiberi. Burial and exhumation
in a subduction wedge: Mutual constraints from thermomechanical modeling and natural P-T-t
data (Schistes Lustres, western Alps). J. Geophys. Res., 112(B07410):doi:10.1029/2006JB004441,
2007.
[580] P. Yamato, E. Burov, P. Agard, L. Le Pourhiet, and L. Jolivet. HP-UHP exhumation during slow
continental subduction: Self-consistent thermodynamically and thermomechanically coupled model
with application to the Western Alps. Earth Planet. Sci. Lett., 271:63–74, 2008.
[581] P. Yamato, L. Husson, T.W. Becker, and K. Pedoja. Passive margins getting squeezed in the mantle
convection vice. Tectonics, 2013.
293
[582] P. Yamato, L. Husson, J. Braun, C. Loiselet, and C. Thieulot. Influence of surrounding plates on
3D subduction dynamics. Geophys. Res. Lett., 36(L07303), 2009.
[583] P. Yamato, R. Tartese, T. Duretz, and D.A. May. Numerical modelling of magma transport in
dykes . Tectonophysics, 526-529:97–109, 2012.
[584] Ph. Yamato, B.J.P. Kaus, F. Mouthereau, and S. Castelltort. Dynamic constraints on the crustal-
scale rheology of the Zagros fold belt, Iran. Geology, 39(9):815–818, 2011.
[585] S. YANG and Y. SHI. Three-dimensional numerical simulation of glacial trough forming process.
Science China: Earth Sciences, pages 10.1007/s11430–015–5120–8, 2015.
[586] T. Yang, L. Moresi, M. Gurnis, S. Liu, D. Sandiford, S. Williams, and F.A. Capitanio. Contrasted
East Asia and South America tectonics driven by deep mantle flow. Earth Planet. Sci. Lett.,
517:106–116, 2019.
[587] C. Yao, F. Deschamps, J.P. Lowman, C. Sanchez-Valle, and P.J. Tackley. Stagnant lid convection in
bottom-heated thin 3-D spherical shells: Influence of curvature and implications for dwarf planets
and icy moons. J. Geophys. Res., 119:1895–1913, 2014.
[588] M. Yoshida. The role of harzburgite layers in the morphology of subducting plates and the behavior
of oceanic crustal layers. Geophys. Res. Lett., 40:5387–5392, 2013.
[589] M. Yoshida, F. Tajima, S. Honda, and M. Morishige. The 3D numerical modeling of subduction
dynamics: Plate stagnation and segmentation, and crustal advection in the wet mantle transition
zone. J. Geophys. Res., 117(B04104), 2012.
[590] X. Yu and F. Tin-Loi. A simple mixed finite element for static limit analysis. Computers and
Structures, 84:1906–1917, 2006.
[591] Z. Xu Z. Li and T.V. Gerya. Numerical Geodynamic Modeling of Continental Convergent Margins,
Earth Sciences. In Dr. Imran Ahmad Dar, editor, Earth Sciences. InTech, 2012.
[592] N. Zhang and Z-X Li. Formation of mantle ‘‘lone plumes’’ in the global downwelling zone – a case
for subduction-controlled plume generation beneath the south china sea. Tectonophysics, 2017.
[593] N. Zhang, S. Zhong, W. Leng, , and Z.X. Li. A model for the evolution of the Earths mantle
structure since the Early Paleozoic. J. Geophys. Res., 115(B06401), 2010.
[594] N. Zhang, S. Zhong, and A.K. McNarmara. Supercontinent formation from stochastic collision and
mantle convection models. Gondwana Research, 15:267–275, 2009.
[595] S. Zhang and C. O’Neill. The early geodynamic evolution of mars-type planets. Icarus, 265:187–208,
2016.
[596] Y. Zhao, J. de Vries, A.P. van den Berg, M.H.G. Jacobs, and W. van Westrenen. The participation
of ilmenite-bearing cumulates in lunar mantle overturn. Earth Planet. Sci. Lett., 511:1–11, 2019.
[597] S. Zhong, M. Gurnis, and G. Hulbert. Accurate determination of surface normal stress in viscous
flow from a consistent boundary flux method. Phys. Earth. Planet. Inter., 78:1–8, 1993.
[598] S. Zhong, M. Gurnis, and L. Moresi. Role of faults, nonlinear rheology, and viscosity structure in
generating plates from instantaneous mantle flow models. J. Geophys. Res., 103(B7):15,255–15,268,
1998.
[599] S. Zhong, A. McNamara, E. Tan, L. Moresi, and M. Gurnis. A benchmark study on mantle
convection in a 3-D spherical shell using CitcomS. Geochem. Geophys. Geosyst., 9(10), 2008.
[600] S. Zhong, N. Zhang, Z.-X. Li, and J.H. Roberts. Supercontinent cycles, true polar wander, and
very long-wavelength mantle convection. Earth Planet. Sci. Lett., 261:551–564, 2007.
294
[601] S. Zhong, M.T. Zuber, L.N. Moresi, and M. Gurnis. The role of temperature-dependent viscosity
and surface plates in spherical shell models of mantle convection. J. Geophys. Res., 105(B5):11,063–
11,082, 2000.
[602] Shijie Zhong. Analytic solutions for Stokes flow with lateral variations in viscosity. Geophys. J.
Int., 124(1):18–28, 1996.
[603] S.J. Zhong, D.A. Yuen, L.N. Moresi, and M.G. Knepley. 7.05 - numerical methods for mantle
convection. In Gerald Schubert, editor, Treatise on Geophysics (Second Edition), pages 197 – 222.
Elsevier, Oxford, second edition edition, 2015.
[604] G. Zhu, T. Gerya, D.A. Yuen, S. Honda, T. Yoshida, and T. Connolly. Three-dimensional dynamics
of hydrous thermal-chemical plumes in oceanic subduction zones. Geochem. Geophys. Geosyst.,
10:doi:10.1029/2009GC002625, 2009.
[605] G. Zhu, T.V. Gerya, P.J. Tackley, and E. Kissling. Four-dimensional numerical modeling of crustal
growth at active continental margins. J. Geophys. Res., 118:4682–4698, 2013.
[606] T. Zhu. Tomography-based mantle flow beneath Mongolia-Baikal area. Phys. Earth. Planet. Inter.,
237:40–50, 2014.
[607] O. Zienkiewicz and S. Nakazawa. The penalty function method and its application to the numerical
solution of boundary value problems. The American Society of Mechanical Engineers, 51, 1982.
[608] O.C. Zienkiewicz, M. Huang, and M. Pastor. Localization problems in plasticity using finite ele-
ments with adaptive remeshing. International Journal for Numerical and Analytical Methods in
Geomechanics, 19:127–148, 1995.
[609] O.C. Zienkiewicz, C. Humpheson, and R.W. Lewis. Associated and non-associated visco-plasticity
and plasticity in soil mechanics . G´eotechnique, 25(4):671–689, 1975.
[610] O.C. Zienkiewicz, J.P. Vilotte, and S. Toyoshima. Iterative method for constrained and mixed
approximation. An inexpensive improvement of FEM performance. Computer Methods in Applied
Mechanics and Engineering, 51:3–29, 1985.
[611] F. Zwaan, G. Scheurs, J. Naliboff, and S.J.H. Buiter. Insights into the effects of oblique extension
on continental rift interaction from 3D analogue and numerical models. Tectonophysics, 2016.
295
Index
H1norm, 113
H1semi-norm, 113
H1(Ω) space, 113
L1norm, 113
L2norm, 113
P1, 34, 36
P2, 34
P3, 35
Pm×Pn, 24
Pm×P−n, 24
Q1×P0, 51, 131, 137, 139, 145, 152, 156, 161, 163,
181, 188, 200, 202, 206, 221, 222
Q1, 25, 29
Q+
1×Q1, 53
Q2×P0, 53
Q2×Q1, 24, 164, 169
Q2, 25, 31, 37
Q(8)
2, 32
Q3×Q2, 172
Q3, 26, 33
Qm×P−n, 24
Qm×Qn, 24
Qm×Q−n, 24
, 253
Advection-Diffusion, 45
analytical solution, 131, 139, 156, 161, 169, 172,
175, 181, 188, 206, 222
angular momentum, 126
angular velocity, 126
arithmetic mean, 153
Augmented Lagrangian, 99
basis functions, 29
Boussinesq, 14
bubble function, 24
bulk modulus, 15, 183
bulk viscosity, 13
buoyancy-driven flow, 133
CBF, 206
CG, 95
checkerboard, 89
cohesion, 88
Compressed Sparse Column, 78
Compressed Sparse Row, 78
compressibility, 183
compressible flow, 188
conforming element, 24
conjugate gradient, 95
connectivity array, 81
convex polygon, 81
CSC, 78
CSR, 78
Dirichlet boundary condition, 17
divergence free, 50
Drucker-Prager, 88
dynamic viscosity, 13
Essential Boundary Conditions, 120
Extrapolation, 114
FANTOM, 253
FLUIDITY, 253
Gauss quadrature, 22
geometric mean, 153
harmonic mean, 153
Heun’s emthod, 108
hyperbolic PDE, 104
IFISS, 253
incompressible flow, 139, 145, 152, 156, 161, 163,
169, 172, 175, 181, 200, 202, 206, 221, 222
isoparametric, 105
isothermal, 131, 137, 139, 145, 152, 156, 161, 163,
169, 172, 175, 181, 200, 202, 206, 222
isoviscous, 131, 137, 156, 161, 169, 172, 181, 188,
206, 221
Lam´e parameter, 15
LBB, 50
Legendre polynomial, 22
Level Set, 122
method of manufactured solutions, 66
midpoint method, 108
midpoint rule, 21
mixed formulation, 156, 161, 163, 169, 172, 175,
181, 188, 200, 202, 206, 221
MMS, 66
moment of inertia, 126
Natural Boundary Conditions, 120
Neumann boundary condition, 17
Newton’s method, 111
Newton-Cotes, 22
non-conforming element, 24
non-isoviscous, 139, 145, 152, 163, 175, 222
nonconforming Q1×P0, 175
nonlinear, 129, 202
nonlinear rheology, 145
nullspace, 92
numerical benchmark, 200
open boundary conditions, 221
296
optimal rate, 50, 114
Particle in Cell, 122
particle-in-cell, 152
penalty formulation, 53, 131, 133, 137, 139, 145,
152, 222
Picard iterations, 129
piecewise, 24
Poiseuille flow, 70
Poisson ratio, 15
preconditioned conjugate gradient, 98
pressure normalisation, 165
pressure nullspace, 72
pressure scaling, 91
pressure smoothing, 89, 156, 175, 181, 188, 206
quadrature, 22
rectangle rule, 21
relaxation, 129
Rens Elbertsen, 207, 228
Richardson iterations, 94
RK2, 108
RK3, 108
RK4, 108
RK45, 108
Runge-Kutta-Fehlberg method, 108
Schur complement, 94
Schur complement approach, 161, 163
second viscosity, 13
Shear Heating, 70
shear modulus, 15
solenoidal field, 50
SPD, 94
spin tensor, 11
static condensation, 123
Stokes sphere, 133, 163
strain rate, 11
strain tensor, 15
strong form, 50
structured grid, 81
Symmetric Positive Definite, 255
Taylor-Hood, 50
tensor invariant, 87
thermal expansion, 183
trapezoidal rule, 21
unstructured grid, 81
velocity gradient, 11
Viscosity Rescaling Method, 88
von Mises, 88
VRM, 88
weak form, 50, 55
work against gravity, 186
Young’s modulus, 15
297
Notes
ofinish. not happy with definition. Look at literature . . . . . . . . . . . . . . . . . . . . . . . . 18
oderive formula for Earth size R1 and R2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
ocheck aspect manual The 2D cylindrical shell benchmarks by Davies et al. 5.4.12 . . . . . . . . 19
oinsertherefigure ............................................ 21
oinsertherefigure ............................................ 21
ocitationneeded ............................................. 31
overifythose ............................................... 33
overifythose ............................................... 36
oNOThappywiththisstatement!!................................... 38
oaddsourceterm!!............................................ 48
othere’s got to be a prettier way to arrive at this ... . . . . . . . . . . . . . . . . . . . . . . . . . 49
ofindliterature.............................................. 50
olist codes which use this approach . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
oreducedintegration........................................... 56
owriteabout3Dto2D ......................................... 56
oinsert here link(s) to manual and literature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
osortoutmesswrtEq26ofbusa13 .................................. 69
ogo through my papers and add relevant ones here . . . . . . . . . . . . . . . . . . . . . . . . . . 74
oproduce drawing of node numbering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
oinsert here the rederivation 2.1.1 of spmw16 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
oproducefiguretoexplainthis ..................................... 90
olinktoprotopaper .......................................... 90
olink to least square and nodal derivatives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90
ocheck this, and report page number . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
oaddbiblio................................................ 96
ohow to compute MfortheSchurcomplement?........................... 99
ofinish GMRES algo description. not sure what to do, hard to explain, not easy to code. . . . . 100
owhy does array contain only T?? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102
ofinish................................................... 102
owrite about case when element is rectangle/cuboid . . . . . . . . . . . . . . . . . . . . . . . . . 112
otofinish................................................. 116
otofinish................................................. 116
oBSc: create mckenzie slab temperature setup . . . . . . . . . . . . . . . . . . . . . . . . . . . . 119
orefs! ................................................... 121
otietofieldstone12 ........................................... 121
omake a distinction between particle-in-cell and marker-and-cell . . . . . . . . . . . . . . . . . . 122
ocheck................................................... 123
oimplementandreport ......................................... 124
omissingpicture ............................................. 125
oexplain why our eqs are nonlinear . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129
owriteaboutnonlinearresidual..................................... 129
obuild S and have python compute its smallest and largest eigenvalues as a function of resolution?161
ofinish structure of C matrix for q1q1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 178
ocompare my rates with original paper! . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179
oexplainhowMedgeisarrivedat! ................................... 205
ocomparewithASPECT??! ...................................... 205
ogauss-lobattointegration?....................................... 205
opressure average on surface instead of volume ? . . . . . . . . . . . . . . . . . . . . . . . . . . . 205
ocrosscheckwithCIGdatabase .................................... 252
298