OGS
elastic_push_pull_two_fractures.prj
<OpenGeoSysProject>
  <mesh>five_element_two_fractures.vtu</mesh>
  <geometry>five_element_two_fractures.gml</geometry>
  <processes>
    <process>
      <name>SD</name>
      <type>SMALL_DEFORMATION_WITH_LIE</type>
      <integration_order>2</integration_order>
      <dimension>2</dimension>
      <process_variables>
        <process_variable>displacement</process_variable>
        <process_variable>displacement_jump1</process_variable>
        <process_variable>displacement_jump2</process_variable>
      </process_variables>
      <constitutive_relation>
        <type>LinearElasticIsotropic</type>
        <youngs_modulus>E</youngs_modulus>
        <poissons_ratio>nu</poissons_ratio>
      </constitutive_relation>
      <fracture_model>
        <type>LinearElasticIsotropic</type>
        <normal_stiffness>Kn</normal_stiffness>
        <shear_stiffness>Ks</shear_stiffness>
        <penalty_aperture_cutoff>1e-5</penalty_aperture_cutoff>
        <tension_cutoff>0</tension_cutoff>
      </fracture_model>
      <fracture_properties>
        <material_id>0</material_id>
        <initial_aperture>aperture0</initial_aperture>
      </fracture_properties>
      <fracture_properties>
        <material_id>1</material_id>
        <initial_aperture>aperture0</initial_aperture>
      </fracture_properties>
      <secondary_variables>
        <secondary_variable internal_name="sigma_xx" output_name="sigma_xx" />
        <secondary_variable internal_name="sigma_yy" output_name="sigma_yy" />
        <secondary_variable internal_name="sigma_xy" output_name="sigma_xy" />
      </secondary_variables>
    </process>
  </processes>
  <time_loop>
    <processes>
      <process ref="SD">
        <nonlinear_solver>basic_newton</nonlinear_solver>
        <convergence_criterion>
          <type>DeltaX</type>
          <norm_type>NORM2</norm_type>
          <abstol>1e-14</abstol>
        </convergence_criterion>
        <time_discretization>
          <type>BackwardEuler</type>
        </time_discretization>
        <time_stepping>
          <type>FixedTimeStepping</type>
          <t_initial>0</t_initial>
          <t_end>10</t_end>
          <timesteps>
            <pair>
              <repeat>6</repeat>
              <delta_t>0.5</delta_t>
            </pair>
          </timesteps>
        </time_stepping>
      </process>
    </processes>
    <output>
      <type>VTK</type>
      <prefix>elastic_push_pull_two_fractures</prefix>
      <suffix>t{:gtime}</suffix>
      <timesteps>
        <pair>
          <repeat>100</repeat>
          <each_steps>1</each_steps>
        </pair>
      </timesteps>
      <variables>
        <variable>displacement</variable>
        <variable>displacement_jump1</variable>
        <variable>displacement_jump2</variable>
        <variable>sigma_xx</variable>
        <variable>sigma_yy</variable>
        <variable>sigma_xy</variable>
      </variables>
    </output>
  </time_loop>
  <parameters>
    <parameter>
      <name>E</name>
      <type>Constant</type>
      <value>200e9</value>
    </parameter>
    <parameter>
      <name>nu</name>
      <type>Constant</type>
      <value>0</value>
    </parameter>
    <parameter>
      <name>Kn</name>
      <type>Constant</type>
      <value>20e9</value>
    </parameter>
    <parameter>
      <name>Ks</name>
      <type>Constant</type>
      <value>20e9</value>
    </parameter>
    <parameter>
      <name>friction_angle</name>
      <type>Constant</type>
      <value>22</value>
    </parameter>
    <parameter>
      <name>dilatancy_angle</name>
      <type>Constant</type>
      <value>10</value>
    </parameter>
    <parameter>
      <name>cohesion</name>
      <type>Constant</type>
      <value>1e3</value>
    </parameter>
    <parameter>
      <name>displacement0</name>
      <type>Constant</type>
      <values>0 0</values>
    </parameter>
    <parameter>
      <name>aperture0</name>
      <type>Constant</type>
      <value>1e-5</value>
    </parameter>
    <parameter>
      <name>force</name>
      <type>Constant</type>
      <value>1e5</value>
    </parameter>
    <parameter>
      <name>push_pull_right</name>
      <type>CurveScaled</type>
      <curve>time_ramp_right</curve>
      <parameter>force</parameter>
    </parameter>
    <parameter>
      <name>push_pull_top</name>
      <type>CurveScaled</type>
      <curve>time_ramp_top</curve>
      <parameter>force</parameter>
    </parameter>
    <parameter>
      <name>zero_u</name>
      <type>Constant</type>
      <value>0</value>
    </parameter>
  </parameters>
  <curves>
    <curve>
      <name>time_ramp_right</name>
      <coords>0 1 3 4 5 7 8 9 10</coords>
      <values>0 1 -1 0 0 0 0 1 0</values>
    </curve>
    <curve>
      <name>time_ramp_top</name>
      <coords>0 1 3 4 5 7 8 9 10</coords>
      <values>0 0 0 0 1 -1 0 1 0</values>
    </curve>
  </curves>
  <process_variables>
    <process_variable>
      <name>displacement</name>
      <components>2</components>
      <order>1</order>
      <initial_condition>displacement0</initial_condition>
      <boundary_conditions>
        <boundary_condition>
          <geometrical_set>five_element_two_fractures</geometrical_set>
          <geometry>PLY_LEFT</geometry>
          <type>Dirichlet</type>
          <component>0</component>
          <parameter>zero_u</parameter>
        </boundary_condition>
        <boundary_condition>
          <geometrical_set>five_element_two_fractures</geometrical_set>
          <geometry>PLY_BOTTOM</geometry>
          <type>Dirichlet</type>
          <component>1</component>
          <parameter>zero_u</parameter>
        </boundary_condition>
        <boundary_condition>
          <geometrical_set>five_element_two_fractures</geometrical_set>
          <geometry>PLY_RIGHT</geometry>
          <type>Neumann</type>
          <component>0</component>
          <parameter>push_pull_right</parameter>
        </boundary_condition>
        <boundary_condition>
          <geometrical_set>five_element_two_fractures</geometrical_set>
          <geometry>PLY_TOP</geometry>
          <type>Neumann</type>
          <component>1</component>
          <parameter>push_pull_top</parameter>
        </boundary_condition>
      </boundary_conditions>
    </process_variable>
    <process_variable>
      <name>displacement_jump1</name>
      <components>2</components>
      <order>1</order>
      <initial_condition>displacement0</initial_condition>
      <boundary_conditions>
        <boundary_condition>
          <geometrical_set>five_element_two_fractures</geometrical_set>
          <geometry>FRACTURE1_LEFT</geometry>
          <type>Dirichlet</type>
          <component>0</component>
          <parameter>zero_u</parameter>
        </boundary_condition>
      </boundary_conditions>
    </process_variable>
    <process_variable>
      <name>displacement_jump2</name>
      <components>2</components>
      <order>1</order>
      <initial_condition>displacement0</initial_condition>
      <boundary_conditions>
        <boundary_condition>
          <geometrical_set>five_element_two_fractures</geometrical_set>
          <geometry>FRACTURE2_LEFT</geometry>
          <type>Dirichlet</type>
          <component>0</component>
          <parameter>zero_u</parameter>
        </boundary_condition>
      </boundary_conditions>
    </process_variable>
  </process_variables>
  <nonlinear_solvers>
    <nonlinear_solver>
      <name>basic_newton</name>
      <type>Newton</type>
      <max_iter>25</max_iter>
      <linear_solver>general_linear_solver</linear_solver>
    </nonlinear_solver>
  </nonlinear_solvers>
  <linear_solvers>
    <linear_solver>
      <name>general_linear_solver</name>
      <eigen>
        <solver_type>SparseLU</solver_type>
        <scaling>1</scaling>
      </eigen>
    </linear_solver>
  </linear_solvers>
  <test_definition>
    <vtkdiff>
      <regex>elastic_push_pull_two_fractures_t_.*.vtu</regex>
      <field>displacement</field>
      <absolute_tolerance>1e-16</absolute_tolerance>
      <relative_tolerance>0</relative_tolerance>
    </vtkdiff>
    <vtkdiff>
      <regex>elastic_push_pull_two_fractures_t_.*.vtu</regex>
      <field>displacement_jump1</field>
      <absolute_tolerance>1e-16</absolute_tolerance>
      <relative_tolerance>0</relative_tolerance>
    </vtkdiff>
    <vtkdiff>
      <regex>elastic_push_pull_two_fractures_t_.*.vtu</regex>
      <field>displacement_jump2</field>
      <absolute_tolerance>1e-16</absolute_tolerance>
      <relative_tolerance>0</relative_tolerance>
    </vtkdiff>
    <vtkdiff>
      <regex>elastic_push_pull_two_fractures_t_.*.vtu</regex>
      <field>sigma_xx</field>
      <absolute_tolerance>5e-10</absolute_tolerance>
      <relative_tolerance>0</relative_tolerance>
    </vtkdiff>
    <vtkdiff>
      <regex>elastic_push_pull_two_fractures_t_.*.vtu</regex>
      <field>sigma_yy</field>
      <absolute_tolerance>5e-11</absolute_tolerance>
      <relative_tolerance>0</relative_tolerance>
    </vtkdiff>
    <vtkdiff>
      <regex>elastic_push_pull_two_fractures_t_.*.vtu</regex>
      <field>sigma_xy</field>
      <absolute_tolerance>1e-10</absolute_tolerance>
      <relative_tolerance>0</relative_tolerance>
    </vtkdiff>
    <vtkdiff>
      <regex>elastic_push_pull_two_fractures_t_.*.vtu</regex>
      <field>f_stress_n</field>
      <absolute_tolerance>1e-16</absolute_tolerance>
      <relative_tolerance>0</relative_tolerance>
    </vtkdiff>
    <vtkdiff>
      <regex>elastic_push_pull_two_fractures_t_.*.vtu</regex>
      <field>f_stress_s</field>
      <absolute_tolerance>1e-11</absolute_tolerance>
      <relative_tolerance>0</relative_tolerance>
    </vtkdiff>
  </test_definition>
</OpenGeoSysProject>