Skip to content
Snippets Groups Projects
Commit 3dfe856c authored by Dmitri Naumov's avatar Dmitri Naumov
Browse files

Merge branch 'thm_benchmarks' into 'master'

THM Benchmark by Vogel/Maßmann

See merge request ogs/ogs!3357
parents 8a0cf88a f40e3024
No related branches found
No related tags found
No related merge requests found
# ThermoHydroMechanics; Small deformation, linear poroelastic, homogeneous # ThermoHydroMechanics; Small deformation, linear poroelastic, homogeneous
if (NOT OGS_USE_MPI)
OgsTest(PROJECTFILE ThermoHydroMechanics/Linear/verification/thm2_1Dfixd/thm2_1Dfixd.prj RUNTIME 60)
endif()
AddTest( AddTest(
NAME ThermoHydroMechanics_square_1e0 NAME ThermoHydroMechanics_square_1e0
PATH ThermoHydroMechanics/Linear/Square_sealed_homogeneous PATH ThermoHydroMechanics/Linear/Square_sealed_homogeneous
......
<?xml version="1.0" encoding="utf-8"?>
<OpenGeoSysGLI>
<name>thm2_1Dfixed_geom</name>
<points>
<point id="0" x="0" y="1.0" z="0" name="POINT0"/>
<point id="1" x="0" y="0" z="0" name="POINT1"/>
<point id="2" x="0" y="0" z="1.0" name="POINT2"/>
<point id="3" x="0" y="1.0" z="1.0" name="POINT3"/>
<point id="4" x="10" y="1.0" z="0" name="POINT4"/>
<point id="5" x="10" y="0" z="0" name="POINT5"/>
<point id="6" x="10" y="0" z="1.0" name="POINT6"/>
<point id="7" x="10" y="1.0" z="1.0" name="POINT7"/>
</points>
<polylines>
<polyline id="0" name="POLYLINE1">
<pnt>0</pnt>
<pnt>1</pnt>
<pnt>2</pnt>
<pnt>3</pnt>
<pnt>0</pnt>
</polyline>
<polyline id="1" name="POLYLINE2">
<pnt>4</pnt>
<pnt>5</pnt>
<pnt>6</pnt>
<pnt>7</pnt>
<pnt>4</pnt>
</polyline>
<polyline id="2" name="POLYLINE3">
<pnt>1</pnt>
<pnt>5</pnt>
<pnt>6</pnt>
<pnt>2</pnt>
<pnt>1</pnt>
</polyline>
<polyline id="3" name="POLYLINE4">
<pnt>0</pnt>
<pnt>4</pnt>
<pnt>7</pnt>
<pnt>3</pnt>
<pnt>0</pnt>
</polyline>
<polyline id="4" name="POLYLINE5">
<pnt>1</pnt>
<pnt>5</pnt>
<pnt>4</pnt>
<pnt>0</pnt>
<pnt>1</pnt>
</polyline>
<polyline id="5" name="POLYLINE6">
<pnt>2</pnt>
<pnt>6</pnt>
<pnt>7</pnt>
<pnt>3</pnt>
<pnt>2</pnt>
</polyline>
<polyline id="6" name="POLYLINE7">
<pnt>1</pnt>
<pnt>0</pnt>
<pnt>3</pnt>
<pnt>2</pnt>
<pnt>1</pnt>
</polyline>
<polyline id="7" name="POLYLINE8">
<pnt>5</pnt>
<pnt>4</pnt>
<pnt>7</pnt>
<pnt>6</pnt>
<pnt>5</pnt>
</polyline>
</polylines>
<surfaces>
<surface id="0" name="SURF_X0">
<element p1="0" p2="2" p3="1"/>
<element p1="2" p2="0" p3="3"/>
</surface>
<surface id="1" name="SURF_X10">
<element p1="4" p2="6" p3="5"/>
<element p1="6" p2="4" p3="7"/>
</surface>
<surface id="2" name="SURF_Y0">
<element p1="1" p2="6" p3="5"/>
<element p1="6" p2="1" p3="2"/>
</surface>
<surface id="3" name="SURF_Y1">
<element p1="0" p2="7" p3="4"/>
<element p1="7" p2="0" p3="3"/>
</surface>
<surface id="4" name="SURF_Z0">
<element p1="1" p2="4" p3="5"/>
<element p1="4" p2="1" p3="0"/>
</surface>
<surface id="5" name="SURF_Z1">
<element p1="2" p2="7" p3="6"/>
<element p1="7" p2="2" p3="3"/>
</surface>
</surfaces>
</OpenGeoSysGLI>
<?xml version="1.0" encoding="ISO-8859-1"?>
<OpenGeoSysProject>
<mesh>thm2_1Dfixd.vtu</mesh>
<geometry>thm2_1Dfixd.gml</geometry>
<processes>
<process>
<name>THERMO_HYDRO_MECHANICS</name>
<type>THERMO_HYDRO_MECHANICS</type>
<integration_order>3</integration_order>
<dimension>3</dimension>
<constitutive_relation>
<type>LinearElasticIsotropic</type>
<youngs_modulus>E</youngs_modulus>
<poissons_ratio>nu</poissons_ratio>
</constitutive_relation>
<reference_temperature>temperature_ic</reference_temperature>
<process_variables>
<displacement>displacement</displacement>
<pressure>pressure</pressure>
<temperature>temperature</temperature>
</process_variables>
<secondary_variables>
<secondary_variable internal_name="sigma" output_name="sigma"/>
<secondary_variable internal_name="epsilon" output_name="epsilon"/>
</secondary_variables>
<specific_body_force>0 0 0</specific_body_force>
</process>
</processes>
<media>
<medium id="0">
<phases>
<phase>
<type>AqueousLiquid</type>
<properties>
<property>
<name>specific_heat_capacity</name>
<type>Constant</type>
<value>1100</value>
</property>
<property>
<name>thermal_conductivity</name>
<type>Constant</type>
<value>10</value>
</property>
<property>
<name>density</name>
<type>Constant</type>
<value>1e3</value>
</property>
<property>
<name>thermal_expansivity</name>
<type>Constant</type>
<value>0</value>
</property>
<property>
<name>viscosity</name>
<type>Constant</type>
<value>1.e-3</value>
</property>
</properties>
</phase>
<phase>
<type>Solid</type>
<properties>
<property>
<name>permeability</name>
<type>Constant</type>
<value>1.e-11 0 0 0 1.e-11 0 0 0 1.e-11</value>
</property>
<property>
<name>porosity</name>
<type>Constant</type>
<value>0.1</value>
</property>
<property>
<name>storage</name>
<type>Constant</type>
<value>0.0</value>
</property>
<property>
<name>density</name>
<type>Constant</type>
<value>2e3</value>
</property>
<property>
<name>thermal_conductivity</name>
<type>Constant</type>
<value>50</value>
</property>
<property>
<name>specific_heat_capacity</name>
<type>Constant</type>
<value>250</value>
</property>
<property>
<name>biot_coefficient</name>
<type>Constant</type>
<value>1.0</value>
</property>
<property>
<name>thermal_expansivity</name>
<type>Constant</type>
<value>1e-6</value>
</property>
</properties>
</phase>
</phases>
</medium>
</media>
<time_loop>
<processes>
<process ref="THERMO_HYDRO_MECHANICS">
<nonlinear_solver>basic_newton</nonlinear_solver>
<convergence_criterion>
<type>PerComponentDeltaX</type>
<norm_type>NORM2</norm_type>
<reltols>1e-15 5e-15 1e-14 1e-0 1e-0</reltols>
</convergence_criterion>
<time_discretization>
<type>BackwardEuler</type>
</time_discretization>
<time_stepping>
<type>FixedTimeStepping</type>
<t_initial>0</t_initial>
<t_end>2e4</t_end>
<timesteps>
<pair><repeat>8</repeat><delta_t>25</delta_t></pair>
<pair><repeat>8</repeat><delta_t>100</delta_t></pair>
<pair><repeat>80</repeat><delta_t>250</delta_t></pair>
</timesteps>
</time_stepping>
</process>
</processes>
<output>
<type>VTK</type>
<prefix>thm2_1Dfixd</prefix>
<timesteps>
<pair><repeat>1</repeat><each_steps>52</each_steps></pair>
<pair><repeat>1</repeat><each_steps>40</each_steps></pair>
</timesteps>
<variables>
<variable>displacement</variable>
<variable>pressure</variable>
<variable>temperature</variable>
<variable>sigma</variable>
<variable>epsilon</variable>
</variables>
</output>
</time_loop>
<parameters>
<parameter>
<name>E</name>
<type>Constant</type>
<value>5.e9</value>
</parameter>
<parameter>
<name>nu</name>
<type>Constant</type>
<value>0.25</value>
</parameter>
<parameter>
<name>T0</name>
<type>Constant</type>
<value>273.15</value>
</parameter>
<parameter>
<name>displacement0</name>
<type>Constant</type>
<values>0 0 0</values>
</parameter>
<parameter>
<name>pressure_ic</name>
<type>Function</type>
<expression>1.0e4*(1.0e1-x)</expression>
</parameter>
<parameter>
<name>pressure_bc_outlet</name>
<type>Constant</type>
<values>0</values>
</parameter>
<parameter>
<name>pressure_bc_inlet</name>
<type>Constant</type>
<value>1.0e5</value>
</parameter>
<parameter>
<name>dirichlet0</name>
<type>Constant</type>
<value>0</value>
</parameter>
<parameter>
<name>temperature_ic</name>
<type>Constant</type>
<value>273.15</value>
</parameter>
<parameter>
<name>temperature_bc_inlet</name>
<type>Constant</type>
<value>263.15</value>
</parameter>
</parameters>
<process_variables>
<process_variable>
<name>displacement</name>
<components>3</components>
<order>2</order>
<initial_condition>displacement0</initial_condition>
<boundary_conditions>
<boundary_condition>
<geometrical_set>thm2_1Dfixed_geom</geometrical_set>
<geometry>SURF_X0</geometry>
<type>Dirichlet</type>
<component>0</component>
<parameter>dirichlet0</parameter>
</boundary_condition>
<boundary_condition>
<geometrical_set>thm2_1Dfixed_geom</geometrical_set>
<geometry>SURF_X10</geometry>
<type>Dirichlet</type>
<component>0</component>
<parameter>dirichlet0</parameter>
</boundary_condition>
<boundary_condition>
<geometrical_set>thm2_1Dfixed_geom</geometrical_set>
<geometry>SURF_Y0</geometry>
<type>Dirichlet</type>
<component>1</component>
<parameter>dirichlet0</parameter>
</boundary_condition>
<boundary_condition>
<geometrical_set>thm2_1Dfixed_geom</geometrical_set>
<geometry>SURF_Y1</geometry>
<type>Dirichlet</type>
<component>1</component>
<parameter>dirichlet0</parameter>
</boundary_condition>
<boundary_condition>
<geometrical_set>thm2_1Dfixed_geom</geometrical_set>
<geometry>SURF_Z0</geometry>
<type>Dirichlet</type>
<component>2</component>
<parameter>dirichlet0</parameter>
</boundary_condition>
<boundary_condition>
<geometrical_set>thm2_1Dfixed_geom</geometrical_set>
<geometry>SURF_Z1</geometry>
<type>Dirichlet</type>
<component>2</component>
<parameter>dirichlet0</parameter>
</boundary_condition>
</boundary_conditions>
</process_variable>
<process_variable>
<name>pressure</name>
<components>1</components>
<order>1</order>
<initial_condition>pressure_ic</initial_condition>
<boundary_conditions>
<boundary_condition>
<geometrical_set>thm2_1Dfixed_geom</geometrical_set>
<geometry>SURF_X0</geometry>
<type>Dirichlet</type>
<parameter>pressure_bc_inlet</parameter>
</boundary_condition>
<boundary_condition>
<geometrical_set>thm2_1Dfixed_geom</geometrical_set>
<geometry>SURF_X10</geometry>
<type>Dirichlet</type>
<parameter>pressure_bc_outlet</parameter>
</boundary_condition>
</boundary_conditions>
</process_variable>
<process_variable>
<name>temperature</name>
<components>1</components>
<order>1</order>
<initial_condition>temperature_ic</initial_condition>
<boundary_conditions>
<boundary_condition>
<geometrical_set>thm2_1Dfixed_geom</geometrical_set>
<geometry>SURF_X0</geometry>
<type>Dirichlet</type>
<parameter>temperature_bc_inlet</parameter>
</boundary_condition>
</boundary_conditions>
</process_variable>
</process_variables>
<nonlinear_solvers>
<nonlinear_solver>
<name>basic_newton</name>
<type>Newton</type>
<max_iter>50</max_iter>
<linear_solver>general_linear_solver</linear_solver>
</nonlinear_solver>
</nonlinear_solvers>
<linear_solvers>
<linear_solver>
<name>general_linear_solver</name>
<lis>-i bicgstab -p ilu -tol 1e-16 -maxiter 10000</lis>
<eigen>
<solver_type>BiCGSTAB</solver_type>
<precon_type>ILUT</precon_type>
<max_iteration_step>10000</max_iteration_step>
<error_tolerance>1e-20</error_tolerance>
</eigen>
<petsc>
<prefix>sd</prefix>
<parameters>-sd_ksp_type cg -sd_pc_type bjacobi -sd_ksp_rtol 1e-16 -sd_ksp_max_it 10000</parameters>
</petsc>
</linear_solver>
</linear_solvers>
<test_definition>
<vtkdiff>
<regex>thm2_1Dfixd_ts_.*.vtu</regex>
<field>displacement</field>
<absolute_tolerance>1e-14</absolute_tolerance>
<relative_tolerance>0</relative_tolerance>
</vtkdiff>
<vtkdiff>
<regex>thm2_1Dfixd_ts_.*.vtu</regex>
<field>sigma</field>
<absolute_tolerance>2e-8</absolute_tolerance>
<relative_tolerance>0</relative_tolerance>
</vtkdiff>
<vtkdiff>
<regex>thm2_1Dfixd_ts_.*.vtu</regex>
<field>epsilon</field>
<absolute_tolerance>1e-12</absolute_tolerance>
<relative_tolerance>0</relative_tolerance>
</vtkdiff>
<vtkdiff>
<regex>thm2_1Dfixd_ts_.*.vtu</regex>
<field>pressure</field>
<absolute_tolerance>1e-7</absolute_tolerance>
<relative_tolerance>0</relative_tolerance>
</vtkdiff>
<vtkdiff>
<regex>thm2_1Dfixd_ts_.*.vtu</regex>
<field>temperature</field>
<absolute_tolerance>1e-10</absolute_tolerance>
<relative_tolerance>0</relative_tolerance>
</vtkdiff>
</test_definition>
</OpenGeoSysProject>
+++
date = "2020-12-22T15:15:45+01:00"
title = "Thermohydromechanics: Verification examples by Vogel, Maßmann"
weight = 40
project = "ThermoHydroMechanics/Linear/verification/thm2_1Dfixed/thm2_1Dfixed.prj"
author = "Jan Thiedau"
[menu]
[menu.benchmarks]
parent = "thermo-hydro-mechanics"
+++
{{< data-link >}}
This is one of the benchmark examples with analytical solutions presented
by Vogel/Massmann to test the implementation of thermohydromechanics.
A detailed description about this benchmark can be found in section 10.1 of
the book
[Thermo-Hydro-Mechanical-Chemical Processes in Fractured Porous Media: Modelling and Benchmarking From Benchmarking to Tutoring](https://www.opengeosys.org/books/bmb-4/),
one of the ogs Benchmark books (see the reference list below).
<!--
These benchmark examples test the implementation of
thermohydromechanics process with analytical solutions
presented by Vogel/Massmann.
A detailed description can be found in the ogs Benchmark books.
The following table links the ogs problem descriptions with its corresponding
chapters in the benchmark books.
| Book/Chapter | Benchmark name |
|:--- | :--- |
|*Kolditz et al. 2015*||
|2.9.1 | thm1_3Dgravity|
|2.9.2 | thm2_1Dbeam|
| *Kolditz et al. 2018*||
| 10.1 | thm2_1Dfixd|
| 10.2 | thm2_1Dfixe|
| 10.3 | thm2_1Dfixf|
-->
## References
<!--{{< bib "kolditz:2015" >}}
{{< bib "kolditz:2016" >}}-->
{{< bib "kolditz:2018" >}}
\ No newline at end of file
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment