1. How do I get help?

  2. How can I contribute to or update the online documentation?

  3. How do I resolve installation issues?

  4. How do I make any sense of the screen output, in particular Newton iteration convergence?

  5. How do I create datasets and are there examples?

  6. Why does PFLOTRAN crash when printing provenance information to HDF5 formatted output?

  7. Does PFLOTRAN run on a machine with GPUs?

  8. What is the difference between MAPPED, GLOBAL, CELL_INDEXED, GRIDDED and ASCII datasets?

  9. How can I troubleshoot multi-phase flow problems in GENERAL mode?


How do I get help?

The PFLOTRAN developers and community can provide limited volunteer support for PFLOTRAN. Please send an email to the appropriate PFLOTRAN mailing lists.

Questions regarding PFLOTRAN installation (i.e. not answered by documentation below), bug reports: pflotran-dev at googlegroups dot com

Questions regarding running PFLOTRAN: pflotran-users at googlegroups dot com

Just saying “PFLOTRAN doesn’t work” doesn’t give us enough information to actually help you and often requires a lot of additional back and forth that delays the process.

Please provide the following information:

  1. Which Git revision of PFLOTRAN you are using:

    git log -1
    
  2. Whether you have modified PFLOTRAN:

    git status
    
  3. If you have modified PFLOTRAN? How? Is your version public for us to see?

  4. Which version of PETSc you are using:

    cd ${PETSC_DIR}
    git log -1 HEAD
    
  5. Do the regression tests pass? If not, attach the test log.

    cd ${PFLOTRAN_DIR}/src/pflotran
    make test
    
  6. Attach the input file you are trying to run.

  7. Attach the screen output or output files showing the error message and context:

    ./pflotran -input_prefix my-problem &> my-problem.stdout.txt
    

How can I contribute to or update the online documentation?

Fork Option (Beginner)

  1. Create a fork of the documentation repository on Bitbucket.

  2. Clone the forked repository to your local machine.

  3. Make additions and changes in existing or new .rst files. (Note that Google is your best friend for learning reStructuredText.)

  4. Commit the changes.

  5. Push the changes to the forked repository.

  6. Submit a pull request to the main PFLOTRAN repository.

Branch Option (Advanced)

Note: This option requires push privileges for the main PFLOTRAN repository on Bitbucket. If you do not know what that means, use the Fork Option.

  1. Clone the documentation repository.

  2. Create a development branch in which the changes will be made. (Please follow the instuctions below.)

  3. Make additions and changes in existing or new .rst files. Google is your best friend for learning reStructuredText.

  4. Test the changes using Sphinx on your local machine.

  5. Commit the changes to the development branch.

  6. Push the changes to the main PFLOTRAN repository.

  7. Submit a pull request.

Common Bitbucket and Git Questions

How to fork a repository?

How to clone a repository?

git clone git@bitbucket.org:pflotran/pflotran-documentation.git

How to create a development branch?

git checkout -b username/brief-description

e.g. git checkout -b glenn/added-faq-on-contributing-documentation

How to test using Sphinx?

  1. Navigate to the repository.

  2. Compile the documentation.

make html

  1. Open _build/html/index.html and inspect the changes.

How to commit changes?

git commit -i <filename> -m 'a short message describing the changes'

e.g. git commit -i faq.rst -m 'added an FAQ on adding/modifying PFLOTRAN documentation'

How to push the modified branch back to the original repository?

git push

How to submit a pull request?


How do I resolve installation issues?

No such file /conf/variables

Problem: When I run “make pflotran” I get the message:

$ make pflotran
"makefile:150: /conf/variables: No such file or directory"
"makefile:151: /conf/rules: No such file or directory"
"make: *** No rule to make target `/conf/rules'. Stop"

Solution: You have not set your PETSC_DIR and PETSC_ARCH environment variables.

In tcsh:

setenv PETSC_DIR /path/to/petsc
setenv PETSC_ARCH whatever_arch_was_installed

In bash:

export PETSC_DIR=/path/to/petsc
export PETSC_ARCH=whatever_arch_was_installed

To avoid having to type these commands in every shell, they should be added to your .cshrc (tcsh) or .bashrc (bash) files.

PFLOTRAN doesn’t compile when I type make pflotran.

Many times when PFLOTRAN doesn’t compile correctly (e.g. make pflotran does not complete due to errors), it is due to incorrect PETSc configuration. PFLOTRAN uses a snapshot of the PETSc ‘maint’ (release) branch, obtained by specifically checking out a changeset-id after cloning PETSc. The changeset-id that PFLOTRAN uses changes occasionally. If PFLOTRAN does not compile, try reconfiguring PETSc, making sure you check out the correct changeset-id. Details are provided on the installation pages: Installing PFLOTRAN. An example is shown below. The changeset-id shown below is not be the most current. Please use the changeset-id provided on the installation pages: Installing PFLOTRAN.

git clone https://gitlab.com/petsc/petsc petsc
cd petsc
git checkout 987thisisnotthecorrectchangesetid1234567

How do I make any sense of the screen output, in particular Newton iteration convergence?

Standard Flow

== GENERAL FLOW ================================================================
  1 2r: 4.13E-13 2x: 1.30E+08 2u: 4.47E-01 ir: 4.42E-14 iu: 2.44E-02 rsn:   0
  2 2r: 6.06E-13 2x: 1.30E+08 2u: 5.63E-01 ir: 5.65E-14 iu: 5.23E-02 rsn:   0
  3 2r: 2.21E-13 2x: 1.30E+08 2u: 3.67E-01 ir: 1.90E-14 iu: 3.05E-02 rsn:   0
  4 2r: 2.45E-13 2x: 1.30E+08 2u: 3.33E-01 ir: 2.20E-14 iu: 2.42E-02 rsn: itol_post_check

 Step   5498 Time=  9.89040E+03 Dt=  1.04142E+01 [y] snes_conv_reason:   12
  newton =   4 [   31891] linear =    75 [    645652] cuts =  0 [ 915]
  --> SNES Linear/Non-Linear Iterations =           75  /            4
  --> SNES Residual:   2.452466E-13  2.335682E-16  2.200252E-14
  --> max chng: dpl=   2.7064E-03 dpg=   1.1357E-01 dpa=   1.1357E-01
                dxa=   1.3283E-11  dt=   0.0000E+00 dsg=   2.9327E-08
  • 2r: 2-norm of residual

  • 2x: 2-norm of current solution

  • 2u: 2-norm of update

  • ir: inf-norm of residual

  • iu: inf-norm of update

  • rsn: converged reason (corresponding integer in brackets)

  • 0: iterating (not converged)

  • atol[2]: 2r < ATOL

  • rtol[3]: 2r < RTOL * 2r_initial

  • stol[4]: 2u < STOL * 2x

  • itol_res[10]: ir < ITOL_RES

  • itol_upd[11]: iu < ITOL_UPDATE

  • itol_post_check[12]: mode-specific convergence criteria defined in XXXCheckUpdatePost()

  • Time: current simulation time

  • Dt: time step size

  • snes_conv_reason: integer value for ‘rsn’

  • newton: number of Newton iterations for time step [simulation total in brackets]

  • linear: number of linear iterations for time step [simulation total in brackets]

  • cuts: number of time step cuts for time step [simulation total in brackets]

  • SNES Linear/Non-Linear Iterations: self explanatory

  • SNES Residual: 2r 2r/#cell ir

  • max chng: maximum change in a primary dependent variable

  • dpl: liquid pressure [Pa]

  • dpg: gas pressure [Pa]

  • dpa: air pressure [Pa]

  • dxa: air mole fraction in liquid phase [-]

  • dt: temperature [C]

  • dsg: gas saturation [-]

GENERAL mode compiled with debug_gen=2

The following information is printed for every Newton iteration when PFLOTRAN is run with the GENERAL flow mode and the code is compiled with ‘debug_gen=2’ on the command line.

2 2r: 1.78E-13 2x: 1.80E+07 2u: 6.26E+01 ir: 1.20E-13 iu: 3.13E+01 rsn:   0
  -+  dpl:  2.9148E+00  dxa:  9.5553E-10  dt:  1.8149E-10
  -+  dpg:  0.0000E+00  dpa:  0.0000E+00  dt:  0.0000E+00
  -+  dpg:  4.2500E+00  dsg:  8.4871E-07  dt:  1.8331E-10
  -+ rupl:  5.6408E-07 ruxa:  5.3914E-02 rut:  6.7219E-12
  -+ rupg:  0.0000E+00 rupa:  0.0000E+00 rut:  0.0000E+00
  -+ rupg:  7.0889E-07 rusg:  9.1508E-06 rut:  6.7894E-12
  -+  srl:  4.8899E-06  srg:  6.5988E-10 sre:  2.0326E-07
  -+  srl:  0.0000E+00  srg:  0.0000E+00 sre:  0.0000E+00
  -+  srl:  4.9007E-06  srg:  1.6427E-07 sre:  1.7585E-07
  -+ ru1 icell:      6  st:  3  X:  5.995E+06  dX: -4.250E+00  R: -5.672E-14
  -+ ru2 icell:      7  st:  1  X:  1.772E-08  dX: -9.555E-10  R: -7.638E-18
  -+ ru3 icell:      1  st:  3  X:  2.700E+01  dX:  1.833E-10  R: -9.295E-16
  -+ sr1 icell:      6  st:  3  X:  5.995E+06  dX: -4.250E+00  R: -5.672E-14
  -+ sr2 icell:      6  st:  3  X:  9.275E-02  dX: -8.487E-07  R:  1.901E-15
  -+ sr3 icell:      7  st:  1  X:  2.700E+01  dX:  1.788E-10  R:  1.200E-13

Data is organized in rows of three corresonding to either the states of the system (1-single phase liquid, 2-single phase gas, 3-two phase) or the governing equation (1-liquid component [water] mass, 2-gas component [air] mass, 3-energy).

The first set of three (i.e. three rows) prints the maximum change of each of the three primary dependent variables (column) for each state (row: 1-liquid, 2-gas, 3-two-phase). Only cells possessing a primary dependent variable for a given state considered in each calculation:

-+  dpl:  2.9148E+00  dxa:  9.5553E-10  dt:  1.8149E-10
-+  dpg:  0.0000E+00  dpa:  0.0000E+00  dt:  0.0000E+00
-+  dpg:  4.2500E+00  dsg:  8.4871E-07  dt:  1.8331E-10
  • d: - delta [X_(p+1) - X_p]

  • dpl: liquid pressure

  • dxa: air mole fraction in liquid phase

  • dt: temperature

  • dpg: gas pressure

  • dpa: air pressure

  • dsg: gas saturation

Rows 4-6 print the infinity norm of the relative update (dX/X) for each of the three primary dependent variables for each state:

-+ rupl:  5.6408E-07 ruxa:  5.3914E-02 rut:  6.7219E-12
-+ rupg:  0.0000E+00 rupa:  0.0000E+00 rut:  0.0000E+00
-+ rupg:  7.0889E-07 rusg:  9.1508E-06 rut:  6.7894E-12
  • ru - relative update of X [dX/X]

  • rupl: liquid perssure

  • ruxa: air mole fraction in liquid phase

  • rut: temperature

  • rupg: gas pressure

  • rupa: air pressure

  • rusg: gas saturation

Rows 7-9 print the infinity norm of the scaled residual (R / A) for each of the three governing equations for each state. Here A is the fixed portion of the accumulation time (portion of time derivative at time t as opposed to t + dt):

-+  srl:  4.8899E-06  srg:  6.5988E-10 sre:  2.0326E-07
-+  srl:  0.0000E+00  srg:  0.0000E+00 sre:  0.0000E+00
-+  srl:  4.9007E-06  srg:  1.6427E-07 sre:  1.7585E-07
  • sr - scaled residual [R/A]

  • srl: liquid (water) equation

  • srg: gas (air) equation

  • sre: energy equation

Rows 10-12 print the cell id, state (st), value (X), update (dX), and residual (R) for primary dependent variable with the largest relative update (dX/X) for each governing equation:

-+ ru1 icell:      6  st:  3  X:  5.995E+06  dX: -4.250E+00  R: -5.672E-14
-+ ru2 icell:      7  st:  1  X:  1.772E-08  dX: -9.555E-10  R: -7.638E-18
-+ ru3 icell:      1  st:  3  X:  2.700E+01  dX:  1.833E-10  R: -9.295E-16
  • ru - relative update

  • ru1: liquid equation

  • ru2: gas equation

  • ru3: energy equation

Rows 13-15 print the cell id, state (st), value (X), update (dX), and residual (R) for primary dependent variable with the largest scaled residual (R/A) for each governing equation:

-+ sr1 icell:      6  st:  3  X:  5.995E+06  dX: -4.250E+00  R: -5.672E-14
-+ sr2 icell:      6  st:  3  X:  9.275E-02  dX: -8.487E-07  R:  1.901E-15
-+ sr3 icell:      7  st:  1  X:  2.700E+01  dX:  1.788E-10  R:  1.200E-13
  • sr - scaled residual

  • sr1: liquid equation

  • sr2: gas equation

  • sr3: energy equation

How do I create datasets and are there examples?

It is highly recommended that you download and install HDFView, which greatly facilitates understanding/managing HDF5 files with PFLOTRAN.

Permeability and/or Porosity

Permeability and porosity datasets are cell-indexed HDF5 datasets, but they differ slightly from all other datasets in that they are not placed in a group and they must be named “Permeability” and “Porosity”. This will change in the future, but for now, they must use those names. See the DATASET card.

Useful python scripts:

PFLOTRAN_DIR/src/python/conceptual_model/DataLoader.py

Useful examples:

PFLOTRAN_DIR/regression_tests/default/543/543_hanford_srfcplx_param.in PFLOTRAN_DIR/regression_tests/default/infiltrometer/16m.in PFLOTRAN_DIR/regression_tests/shortcourse/regional_doublet/stochastic_regional_doublet_small.in

Material IDs

Material IDs must be defined for all grid cells in a single HDF5 file under an HDF5 Group named “Materials”. The STRATA card provides an example of how to set up a Material ID dataset.

Useful python scripts:

PFLOTRAN_DIR/src/python/conceptual_model/material_and_region_loader.py

Useful examples:

PFLOTRAN_DIR/regression_tests/default/543/543_flow.in

Regions

Regions are located in an HDF5 file under an HDF5 Group named “Regions”. Within the Regions group, one creates Groups whose names match the regions in the PFLOTRAN input file. Each of these groups provides a list of “Cell Ids” and “Face Ids”. Face ids are not required for regions not associated with boundary conditions.

Useful python scripts:

PFLOTRAN_DIR/src/python/conceptual_model/material_and_region_loader.py

Useful examples:

PFLOTRAN_DIR/regression_tests/default/543/543_flow.in

Other Cell-Indexed Datasets

Other cell-indexed HDF5 datasets can have arbitrary names. These datasets are used to define pressure, temperature, concentration, mineral volume fractions, etc. over all grid cells in the domain.

Useful python scripts:

PFLOTRAN_DIR/src/python/cell_indexed_dataset_loader.py

Useful examples:

PFLOTRAN_DIR/regression_tests/default/543/543_hanford_srfcplx_param.in PFLOTRAN_DIR/regression_tests/default/543/543_flow.in (initializing pressure field from a file)

Gridded Datasets

Gridded HDF5 datasets are defined on a uniform Cartesian grid and interpolated to the PFLOTRAN structured or unstructured grid internally. These grids are particularly useful for setting up nonlinear boundary or initial conditions.

Useful python scripts:

PFLOTRAN_DIR/src/python/gridded_dataset_loader.py

Useful examples:

PFLOTRAN_DIR/regression_tests/default/condition/datum_dataset.in PFLOTRAN_DIR/regression_tests/default/condition/543_datum_dataset.in

ASCII Datasets

ASCII dataset are used to define scalar or vector quantities over time (e.g. a datum, gradient, or pressure associated with a FLOW_CONDITION that varies over time).

Useful python scripts:

Currently don’t have a script.

Useful examples:

PFLOTRAN_DIR/regression_tests/default/condition/543_timeseries.in PFLOTRAN_DIR/regression_tests/shortcourse/regional_doublet/regional_doublet_small.in (see “river” FLOW_CONDITION)

Why does PFLOTRAN crash when printing provenance information to HDF5 formatted output?

Ensure that there is a carriage return character on the last line of your input file. This should resolve the issue.

Does PFLOTRAN run on a machine with GPUs?

PFLOTRAN will run on a machine with GPUs, but it will not leverage any GPU (or any other accelerator) capability. The code is not currently written to utilize the GPUs on such machines, but only the CPU.

Note: Before you make a significant investment in codes that claim to use GPUs, research the codes’ scalability on GPUs (or perform your own scalability study) to ensure that your investment is worthwhile. Codes that solve implicit systems of equations (as does PFLOTRAN) have demonstrated only minimal speedup on GPUs (e.g. 4x). At this point in time, I (Glenn) consider a large investment in GPU capability to be ineffective since one can employ 4 times as many cores to get the same speedup.

What is the difference between MAPPED, GLOBAL, CELL_INDEXED, GRIDDED and ASCII datasets?

ASCII: Text-based datasets entered in the input file are stored internally within PFLOTRAN in ASCII datasets.

CELL_INDEXED: A dataset that prescribes a value for each grid cell in a list of cells. The user must define a list of cells IDs aligned with the values. Theoretically, the user could provide a list of cells that is a subset of the global domain, but this has not been tested. The list of cells is usually aligned with the global grid, and thus, this dataset is usually aligned with the GLOBAL dataset.

GLOBAL: A dataset that prescribes a value for each grid cell in the (global) domain.

GRIDDED: A 1D, 2D, or 3D uniformly-spaced grid of values from which values can be interpolated given a point in space.

MAPPED: A dataset that maps few distinct data values on multiple grid cells. e.g. A simulation for a 3D domain (NX x NY x NZ) in which a vertical profile (NZ) of transpiration sink is applied homogeneously for each horizontal layer. At a z-th level, all grid cells in x- and y-direction are prescribed z-th transpiration dataset.

How can I troubleshoot multi-phase flow problems in GENERAL mode?

Example: Simulation is failing to converge

-> Cut time step: snes= -3 icut= 16[372] t=  6.88420E+00 dt=  6.64673E-06
Newton solver reason: SNES_DIVERGED_LINEAR_SOLVE
Linear solver reason: KSP_DIVERGED_PCSETUP_FAILED
  0 2r: 3.15E-06 2x: 0.00E+00 2u: 0.00E+00 ir: 2.05E-06 iu: 0.00E+00 rsn:   0
  Stopping: Time step cut criteria exceeded.
     icut = 17, max_time_step_cuts= 16
--> write tecplot output file: flow_cut_to_failure.tec
      0.02 Seconds to write to Tecplot file(s)

FLOW TS BE steps =   1601 newton =     5774 linear =       5774 cuts =    356
FLOW TS BE Wasted Linear Iterations = 2848
FLOW TS BE SNES time = 12.9 seconds

 Wall Clock Time:  1.3692E+01 [sec]   2.2821E-01 [min]   3.8034E-03 [hr]

Try: Adding USE_INFINITY_NORM_CONVERGENCE to the NEWTON_SOLVER block. This will: Impose infinity norm convergence criteria to declare simulation convergence instead of the default Euclidean norm convergence criteria.

Fixed Example:

== GENERAL MULTIPHASE FLOW =====================================================
0 2r: 8.16E-07 2x: 0.00E+00 2u: 0.00E+00 ir: 4.37E-07 iu: 0.00E+00 rsn:   0
1 2r: 1.75E-06 2x: 7.97E+06 2u: 5.65E+03 ir: 8.76E-07 iu: 1.05E+03 rsn:   0
2 2r: 2.35E-09 2x: 7.97E+06 2u: 4.02E+03 ir: 1.13E-09 iu: 1.68E+03 rsn:   0
3 2r: 3.24E-10 2x: 7.97E+06 2u: 2.52E+03 ir: 1.34E-10 iu: 1.68E+03 rsn:   0
4 2r: 7.96E-10 2x: 7.97E+06 2u: 1.30E+01 ir: 4.53E-10 iu: 3.36E+00 rsn:   0
5 2r: 1.35E-16 2x: 7.97E+06 2u: 3.92E-01 ir: 7.74E-17 iu: 2.70E-01 rsn: 999

Step    650 Time=  5.00000E+01 Dt=  2.33233E-01 [y] snes_conv_reason:  999
newton =   5 [    2637] linear =     5 [      2637] cuts =  0 [ 111]
--> SNES Linear/Non-Linear Iterations =            5  /            5
--> SNES Residual:   1.346474E-16  8.917046E-19  7.743109E-17
--> max chng: dpl=   1.0783E+03 dpg=   1.0564E+03 dpa=   3.7402E+01
              dxa=   3.1919E-09  dt=   4.9887E-02 dsg=   2.1620E-02

Dt limited by Unknown: Val=-9.990E+02, Gov=-9.990E+02, Scale=0.33

--> write tecplot output file: gas_bubble-004.tec
     0.00 Seconds to write to Tecplot file(s)
FLOW TS BE steps =    650 newton =     2637 linear =       2637 cuts =    111
FLOW TS BE Wasted Linear Iterations = 888
FLOW TS BE SNES time = 6.9 seconds

 Wall Clock Time:  7.3313E+00 [sec]   1.2219E-01 [min]   2.0365E-03 [hr]

Example: Simulation output indicates that the same grid cells are frequently changing state back and forth (e.g. from Liquid –> Two-Phase and then from Two-Phase –> Liquid) within Newton iterations

== GENERAL MULTIPHASE FLOW =====================================================
 0 2r: 2.45E-05 2x: 0.00E+00 2u: 0.00E+00 ir: 2.44E-05 iu: 0.00E+00 rsn:   0
(0): State Transition: Liquid -> 2 Phase at Cell       50
(0): State Transition: Liquid -> 2 Phase at Cell       52
 1 2r: 1.53E-04 2x: 1.01E+07 2u: 2.22E+03 ir: 8.27E-05 iu: 3.80E+02 rsn:   0
(0): State Transition: 2 Phase -> Liquid at Cell       50
(0): State Transition: 2 Phase -> Liquid at Cell       52
 2 2r: 1.47E-04 2x: 1.01E+07 2u: 3.08E+03 ir: 7.72E-05 iu: 9.78E+02 rsn:   0
(0): State Transition: Liquid -> 2 Phase at Cell       50
(0): State Transition: Liquid -> 2 Phase at Cell       52
 3 2r: 1.53E-04 2x: 1.01E+07 2u: 3.02E+03 ir: 8.28E-05 iu: 9.92E+02 rsn:   0
(0): State Transition: 2 Phase -> Liquid at Cell       50
(0): State Transition: 2 Phase -> Liquid at Cell       52
 4 2r: 1.47E-04 2x: 1.01E+07 2u: 3.02E+03 ir: 7.72E-05 iu: 9.92E+02 rsn:   0
(0): State Transition: Liquid -> 2 Phase at Cell       50
(0): State Transition: Liquid -> 2 Phase at Cell       52
 5 2r: 1.53E-04 2x: 1.01E+07 2u: 3.02E+03 ir: 8.28E-05 iu: 9.92E+02 rsn:   0
(0): State Transition: 2 Phase -> Liquid at Cell       50
(0): State Transition: 2 Phase -> Liquid at Cell       52

Try: Adding RESTRICT_STATE_CHANGE to the GENERAL mode OPTIONS block This will: Only allow grid cells to change state once during a Newton iteration. If convergence is not achieved, time step is cut.

Fixed Example:

== GENERAL MULTIPHASE FLOW =====================================================
0 2r: 3.56E-05 2x: 0.00E+00 2u: 0.00E+00 ir: 3.55E-05 iu: 0.00E+00 rsn:   0
1 2r: 7.62E-06 2x: 1.02E+07 2u: 7.08E+03 ir: 6.20E-06 iu: 1.21E+03 rsn:   0
(0): State Transition: Liquid -> 2 Phase at Cell       50
(0): State Transition: Liquid -> 2 Phase at Cell       52
2 2r: 1.55E-04 2x: 1.01E+07 2u: 2.34E+04 ir: 8.37E-05 iu: 4.22E+03 rsn:   0
3 2r: 1.24E-06 2x: 1.01E+07 2u: 5.40E+03 ir: 1.01E-06 iu: 2.23E+03 rsn:   0
4 2r: 1.63E-04 2x: 1.01E+07 2u: 1.39E+03 ir: 8.89E-05 iu: 2.39E+02 rsn:   0
5 2r: 1.02E-04 2x: 1.01E+07 2u: 9.52E+02 ir: 5.56E-05 iu: 4.34E+02 rsn:   0
6 2r: 1.15E-04 2x: 1.01E+07 2u: 1.09E+03 ir: 6.20E-05 iu: 1.89E+02 rsn:   0
7 2r: 1.21E-04 2x: 1.01E+07 2u: 5.93E+02 ir: 6.54E-05 iu: 1.54E+02 rsn:   0
8 2r: 1.22E-04 2x: 1.01E+07 2u: 5.88E+01 ir: 6.59E-05 iu: 1.92E+01 rsn:   0
9 2r: 1.22E-04 2x: 1.01E+07 2u: 8.76E-01 ir: 6.60E-05 iu: 5.17E-01 rsn:   0
10 2r: 1.22E-04 2x: 1.01E+07 2u: 2.50E-02 ir: 6.60E-05 iu: 8.71E-03 rsn: stol

Step     11 Time=  4.15114E-02 Dt=  1.92877E-02 [y] snes_conv_reason:    4
newton =  10 [      38] linear =    10 [        38] cuts =  0 [   0]
--> SNES Linear/Non-Linear Iterations =           10  /           10
--> SNES Residual:   1.218560E-04  1.206495E-06  6.595118E-05
--> max chng: dpl=   4.5172E+03 dpg=   4.1440E+03 dpa=   4.4460E+03
              dxa=   1.3069E-05  dt=   3.7803E-02 dsg=   1.0277E-01

Example: Simulation has trouble when grid cells dry out (cells transition from Two-Phase State –> Gas State), and Dt is limited by pressure

== GENERAL MULTIPHASE FLOW =====================================================
0 2r: 2.25E-07 2x: 0.00E+00 2u: 0.00E+00 ir: 1.58E-07 iu: 0.00E+00 rsn:   0
1 2r: 9.16E-10 2x: 1.01E+07 2u: 6.27E-06 ir: 7.46E-10 iu: 5.08E-06 rsn: 999

Step   1103 Time=  2.21028E+00 Dt=  7.56911E-10 [y] snes_conv_reason:  999
newton =   1 [    1288] linear =     1 [      1288] cuts =  0 [  21]
--> SNES Linear/Non-Linear Iterations =            1  /            1
--> SNES Residual:   9.160734E-10  9.070034E-12  7.457545E-10
--> max chng: dpl=   4.3140E+05 dpg=   5.0805E-06 dpa=   8.0816E-06
              dxa=   1.0919E-15  dt=   4.8880E-10 dsg=   2.3017E-11

Dt limited by Pressure: Val=4.314E+05, Gov=5.000E+05, Scale=1.08

Try: Adding CHECK_MAX_DPL_LIQ_STATE_ONLY to the GENERAL mode OPTIONS block. This will: Only impose limits on liquid pressure changes when capillary pressure gets high, since small saturation changes at high gas saturation are associated with large capillary pressure changes.

Fixed Example:

== GENERAL MULTIPHASE FLOW =====================================================
0 2r: 3.43E-07 2x: 0.00E+00 2u: 0.00E+00 ir: 3.40E-07 iu: 0.00E+00 rsn:   0
1 2r: 1.22E-10 2x: 1.01E+07 2u: 2.67E+00 ir: 1.00E-10 iu: 6.75E-01 rsn: 999

Step     95 Time=  2.21183E+00 Dt=  7.66981E-03 [y] snes_conv_reason:  999
newton =   1 [     377] linear =     1 [       377] cuts =  0 [  33]
--> SNES Linear/Non-Linear Iterations =            1  /            1
--> SNES Residual:   1.215836E-10  1.203798E-12  1.003631E-10
--> max chng: dpl=   0.0000E+00 dpg=   6.7487E-01 dpa=   8.2037E+01
              dxa=   1.1083E-08  dt=   3.7412E-03 dsg=   4.7712E-04

Example: Simulation shows spurious spikes in output variables.

Try: With USE_INFINITY_NORM_CONVERGENCE in the NEWTON_SOLVER block, try tightening convergence tolerances by setting values for RESIDUAL_INF_TOL and REL_UPDATE_INF_TOL This will: Force stricter convergence criteria on the simulation and potentially prevent nonlinearities from causing spurious solution behavior.

Advanced:

Example: Simulation is taking very small timesteps despite the fact that it is converging well.

== GENERAL MULTIPHASE FLOW =====================================================
0 2r: 2.23E-07 2x: 0.00E+00 2u: 0.00E+00 ir: 1.56E-07 iu: 0.00E+00 rsn:   0
1 2r: 3.00E-11 2x: 1.01E+07 2u: 2.47E-03 ir: 2.44E-11 iu: 5.15E-04 rsn: 999

Step   5734 Time=  1.97179E+00 Dt=  1.01105E-05 [y] snes_conv_reason:  999
newton =   1 [   22032] linear =     1 [     22032] cuts =  0 [1936]
--> SNES Linear/Non-Linear Iterations =            1  /            1
--> SNES Residual:   2.995478E-11  2.965819E-13  2.439427E-11
--> max chng: dpl=   0.0000E+00 dpg=   5.1500E-04 dpa=   1.1667E-01
              dxa=   1.5748E-11  dt=   5.3204E-06 dsg=   3.0582E-07
Try: Loosening individual tolerances. Tolerances can be set on:
  1. <primary variable here>_ABS_UPDATE_INF_TOL : Absolute solution update within a Newton-Raphson search loop: one for each primary variable from the set {Pl, Pg, Xag,Sg,T}

  2. <primary variable here>_REL_UPDATE_INF_TOL : Relative solution update within a Newton-Raphson search loop: (xn-xn-1)/xn-1

  3. <conservation equation here>_RESIDUAL_ABS_INF_TOL : Absolute value of residuals for water mass, air mass, and energy

  4. <conservation equation here>_RESIDUAL_SCALED_INF_TOL : Scaled value of residuals (residual value divided by accumulation term) for water mass, air mass, and energy.

This will: Impose user-specified convergence criteria upon any of the metrics used to declare convergence. Any metrics that are not user-specified will revert to defaults.

Fixed Example:

== GENERAL MULTIPHASE FLOW =====================================================
0 2r: 4.29E-07 2x: 0.00E+00 2u: 0.00E+00 ir: 2.61E-07 iu: 0.00E+00 rsn:   0
1 2r: 1.60E-06 2x: 1.01E+07 2u: 5.00E+01 ir: 1.30E-06 iu: 1.06E+01 rsn:   0
2 2r: 5.10E-07 2x: 1.01E+07 2u: 5.11E+00 ir: 4.15E-07 iu: 8.40E-01 rsn:   0
3 2r: 1.42E-05 2x: 1.01E+07 2u: 4.78E+00 ir: 1.15E-05 iu: 2.29E+00 rsn:   0
4 2r: 4.31E-06 2x: 1.01E+07 2u: 2.88E+00 ir: 3.51E-06 iu: 1.67E+00 rsn:   0
5 2r: 4.34E-07 2x: 1.01E+07 2u: 1.71E+00 ir: 3.53E-07 iu: 7.78E-01 rsn:   0
6 2r: 1.42E-05 2x: 1.01E+07 2u: 4.06E+00 ir: 1.15E-05 iu: 1.91E+00 rsn:   0
7 2r: 4.32E-06 2x: 1.01E+07 2u: 2.85E+00 ir: 3.52E-06 iu: 1.63E+00 rsn:   0
8 2r: 4.34E-07 2x: 1.01E+07 2u: 1.71E+00 ir: 3.53E-07 iu: 7.79E-01 rsn: -88
-> Cut time step: snes=-88 icut=  1[  8] t=  1.92038E+00 dt=  1.22717E-01
Newton solver reason: Unknown(-88).
0 2r: 4.29E-07 2x: 0.00E+00 2u: 0.00E+00 ir: 2.61E-07 iu: 0.00E+00 rsn:   0
1 2r: 5.51E-06 2x: 1.01E+07 2u: 2.70E+01 ir: 4.48E-06 iu: 5.72E+00 rsn:   0
2 2r: 2.04E-07 2x: 1.01E+07 2u: 2.71E+00 ir: 1.66E-07 iu: 4.59E-01 rsn: 999

Step     35 Time=  2.04309E+00 Dt=  1.22717E-01 [y] snes_conv_reason:  999
newton =  10 [     117] linear =    10 [       117] cuts =  1 [   8]
--> SNES Linear/Non-Linear Iterations =            2  /            2
--> SNES Residual:   2.041778E-07  2.021562E-09  1.662622E-07
--> max chng: dpl=   0.0000E+00 dpg=   6.1632E+00 dpa=   1.3859E+03
              dxa=   1.8704E-07  dt=   6.3217E-02 dsg=   3.7129E-03