OGS
surfing.prj
<
OpenGeoSysProject
>
<
meshes
>
<
mesh
>surfing_quad_1x2_NR_pf_ic.vtu</mesh>
<
mesh
>surfing_bottom.vtu</mesh>
<
mesh
>surfing_top.vtu</mesh>
<
mesh
>surfing_left.vtu</mesh>
<
mesh
>surfing_right.vtu</mesh>
<
mesh
>surfing_p_0.vtu</mesh>
<
mesh
>surfing_p_1.vtu</mesh>
<
mesh
>surfing_p_2.vtu</mesh>
<
mesh
>surfing_p_3.vtu</mesh>
</meshes>
<
python_script
>Surfing_python.py</python_script>
<
processes
>
<
process
>
<
name
>PhaseField</name>
<
type
>
PHASE_FIELD
</type>
<
phasefield_model
>AT1</phasefield_model>
<
coupling_scheme
>staggered</coupling_scheme>
<
energy_split_model
>VolumetricDeviatoric</energy_split_model>
<
integration_order
>2</integration_order>
<constitutive_relation>
<type>
LinearElasticIsotropic
</type>
<
youngs_modulus
>E</youngs_modulus>
<
poissons_ratio
>nu</poissons_ratio>
</constitutive_relation>
<
phasefield_parameters
>
<
residual_stiffness
>k</residual_stiffness>
<
crack_resistance
>gc</crack_resistance>
<
crack_length_scale
>ls</crack_length_scale>
</phasefield_parameters>
<
solid_density
>rho_sr</solid_density>
<
process_variables
>
<
phasefield
>phasefield</phasefield>
<
displacement
>displacement</displacement>
</process_variables>
<
secondary_variables
>
<
secondary_variable
internal_name
="sigma"
output_name
="sigma"
type
="static" />
<
secondary_variable
internal_name
="epsilon"
output_name
="epsilon"
type
="static" />
</secondary_variables>
<
specific_body_force
>0 0</specific_body_force>
</process>
</processes>
<
time_loop
>
<
global_process_coupling
>
<
max_iter
>1000</max_iter>
<
convergence_criteria
>
<
convergence_criterion
>
<type>
DeltaX
</type>
<norm_type>INFINITY_N</norm_type>
<abstol>1.e-1</abstol>
<reltol>1.e-1</reltol>
</convergence_criterion>
<
convergence_criterion
>
<type>
DeltaX
</type>
<norm_type>INFINITY_N</norm_type>
<abstol>1.e-4</abstol>
<reltol>1.e-10</reltol>
</convergence_criterion>
</convergence_criteria>
</global_process_coupling>
<
processes
>
<
process
ref
="PhaseField">
<
nonlinear_solver
>basic_newton_u</nonlinear_solver>
<
convergence_criterion
>
<
type
>
DeltaX
</type>
<
norm_type
>NORM2</norm_type>
<
reltol
>1.e-12</reltol>
</convergence_criterion>
<
time_discretization
>
<
type
>
BackwardEuler
</type>
</time_discretization>
<
time_stepping
>
<
type
>
FixedTimeStepping
</type>
<
t_initial
>0</t_initial>
<
t_end
>1.</t_end>
<
timesteps
>
<
pair
>
<
repeat
>1</repeat>
<
delta_t
>5.e-2</delta_t>
</pair>
</timesteps>
</time_stepping>
</process>
<
process
ref
="PhaseField">
<
nonlinear_solver
>petsc_snes</nonlinear_solver>
<
convergence_criterion
>
<
type
>
DeltaX
</type>
<
norm_type
>NORM2</norm_type>
<
reltol
>1.e-14</reltol>
</convergence_criterion>
<
time_discretization
>
<
type
>
BackwardEuler
</type>
</time_discretization>
<
time_stepping
>
<
type
>
FixedTimeStepping
</type>
<
t_initial
>0</t_initial>
<
t_end
>1.0</t_end>
<
timesteps
>
<
pair
>
<
repeat
>1</repeat>
<
delta_t
>5.e-2</delta_t>
</pair>
</timesteps>
</time_stepping>
</process>
</processes>
<
output
>
<
variables
/>
<
type
>
VTK
</type>
<
prefix
>surfing</prefix>
<
timesteps
>
<
pair
>
<
repeat
>10</repeat>
<
each_steps
>1</each_steps>
</pair>
<
pair
>
<
repeat
>10</repeat>
<
each_steps
>1</each_steps>
</pair>
</timesteps>
</output>
</time_loop>
<
parameters
>
<
parameter
>
<
name
>E</name>
<
type
>
Constant
</type>
<
value
>210.e3</value>
</parameter>
<
parameter
>
<
name
>nu</name>
<
type
>
Constant
</type>
<
value
>0.3</value>
</parameter>
<
parameter
>
<
name
>k</name>
<
type
>
Constant
</type>
<
value
>1e-8</value>
</parameter>
<
parameter
>
<
name
>gc</name>
<
type
>
Constant
</type>
<
value
>2.7</value>
</parameter>
<
parameter
>
<
name
>ls</name>
<
type
>
Constant
</type>
<
value
>0.1</value>
</parameter>
<
parameter
>
<
name
>H</name>
<
type
>
Constant
</type>
<
value
>0.0</value>
</parameter>
<
parameter
>
<
name
>rho_sr</name>
<
type
>
Constant
</type>
<
value
>0.0</value>
</parameter>
<
parameter
>
<
name
>displacement0</name>
<
type
>
Constant
</type>
<
values
>0 0</values>
</parameter>
<
parameter
>
<
name
>phasefield_ic</name>
<
type
>
MeshNode
</type>
<
field_name
>pf-ic</field_name>
</parameter>
<
parameter
>
<
name
>phasefield_bc</name>
<
type
>
Constant
</type>
<
value
>1</value>
</parameter>
<
parameter
>
<
name
>dirichlet0</name>
<
type
>
Constant
</type>
<
value
>0</value>
</parameter>
<
parameter
>
<
name
>Dirichlet_spatial</name>
<
type
>
Constant
</type>
<
value
>1</value>
</parameter>
<
parameter
>
<
name
>dirichlet_top_time</name>
<
type
>
CurveScaled
</type>
<
curve
>dirichlet_time</curve>
<
parameter
>dirichlet_top</parameter>
</parameter>
<
parameter
>
<
name
>dirichlet_top</name>
<
type
>
Constant
</type>
<
value
>1.0</value>
</parameter>
<
parameter
>
<
name
>M</name>
<
type
>
Constant
</type>
<
value
>0.0</value>
</parameter>
</parameters>
<
curves
>
<
curve
>
<
name
>dirichlet_time</name>
<coords>0 1.0</coords>
<values>0 1.0</values>
</curve>
</curves>
<
process_variables
>
<
process_variable
>
<
name
>phasefield</name>
<
components
>1</components>
<
order
>1</order>
<
initial_condition
>phasefield_ic</initial_condition>
<
boundary_conditions
>
<
boundary_condition
>
<
mesh
>surfing_right</mesh>
<
type
>
Dirichlet
</type>
<
component
>0</component>
<
parameter
>phasefield_bc</parameter>
</boundary_condition>
<
boundary_condition
>
<
mesh
>surfing_right</mesh>
<
type
>
PhaseFieldIrreversibleDamageOracleBoundaryCondition
</type>
<
component
>0</component>
</boundary_condition>
</boundary_conditions>
</process_variable>
<
process_variable
>
<
name
>displacement</name>
<
components
>2</components>
<
order
>1</order>
<
initial_condition
>displacement0</initial_condition>
<
boundary_conditions
>
<
boundary_condition
>
<
mesh
>surfing_right</mesh>
<
type
>
Python
</type>
<
component
>0</component>
<
bc_object
>bc_right_X</bc_object>
<
flush_stdout
>false</flush_stdout>
</boundary_condition>
<
boundary_condition
>
<
mesh
>surfing_left</mesh>
<
type
>
Python
</type>
<
component
>0</component>
<
bc_object
>bc_left_X</bc_object>
<
flush_stdout
>false</flush_stdout>
</boundary_condition>
<
boundary_condition
>
<
mesh
>surfing_bottom</mesh>
<
type
>
Python
</type>
<
component
>0</component>
<
bc_object
>bc_bottom_X</bc_object>
<
flush_stdout
>false</flush_stdout>
</boundary_condition>
<
boundary_condition
>
<
mesh
>surfing_top</mesh>
<
type
>
Python
</type>
<
component
>0</component>
<
bc_object
>bc_top_X</bc_object>
<
flush_stdout
>false</flush_stdout>
</boundary_condition>
<
boundary_condition
>
<
mesh
>surfing_right</mesh>
<
type
>
Python
</type>
<
component
>1</component>
<
bc_object
>bc_right_Y</bc_object>
<
flush_stdout
>false</flush_stdout>
</boundary_condition>
<
boundary_condition
>
<
mesh
>surfing_left</mesh>
<
type
>
Python
</type>
<
component
>1</component>
<
bc_object
>bc_left_Y</bc_object>
<
flush_stdout
>false</flush_stdout>
</boundary_condition>
<
boundary_condition
>
<
mesh
>surfing_bottom</mesh>
<
type
>
Python
</type>
<
component
>1</component>
<
bc_object
>bc_bottom_Y</bc_object>
<
flush_stdout
>false</flush_stdout>
</boundary_condition>
<
boundary_condition
>
<
mesh
>surfing_top</mesh>
<
type
>
Python
</type>
<
component
>1</component>
<
bc_object
>bc_top_Y</bc_object>
<
flush_stdout
>false</flush_stdout>
</boundary_condition>
</boundary_conditions>
</process_variable>
</process_variables>
<
nonlinear_solvers
>
<
nonlinear_solver
>
<
name
>petsc_snes</name>
<
type
>
PETScSNES
</type>
<
max_iter
>50</max_iter>
<
linear_solver
>linear_solver_d</linear_solver>
</nonlinear_solver>
<
nonlinear_solver
>
<
name
>basic_newton_u</name>
<
type
>
Newton
</type>
<
max_iter
>200</max_iter>
<
linear_solver
>linear_solver_u</linear_solver>
</nonlinear_solver>
</nonlinear_solvers>
<
linear_solvers
>
<
linear_solver
>
<
name
>linear_solver_d</name>
<
eigen
>
<
solver_type
>BiCGSTAB</solver_type>
<
precon_type
>ILUT</precon_type>
<
max_iteration_step
>10000</max_iteration_step>
<
error_tolerance
>1e-16</error_tolerance>
</eigen>
<
petsc
>
<
parameters
>-ksp_type cg -pc_type bjacobi -ksp_atol 1e-16 -ksp_rtol 1e-16 -snes_type vinewtonrsls -snes_linesearch_type l2 -snes_atol 1.e-8 -snes_rtol 1.e-8 -snes_max_it 1000 -snes_monitor</parameters>
</petsc>
</linear_solver>
<
linear_solver
>
<
name
>linear_solver_u</name>
<
petsc
>
<
prefix
>u</prefix>
<
parameters
>-u_ksp_type cg -u_pc_type jacobi -u_ksp_atol 1e-16 -u_ksp_rtol 1e-16</parameters>
</petsc>
</linear_solver>
</linear_solvers>
</OpenGeoSysProject>
OGS CTests—Project Files
PhaseField
surfing
Generated by
1.14.0