Skip to main content

A TOUGH2/Waiwera interface to PEST

Project description

goPEST

goPEST is a set of utilities used to interface PEST with Waiwera and (AU)TOUGH2 simulators.

Install

The easiest way to install goPEST is:

python -m pip install gopest

Input files

User needs to prepare a few files for goPEST to work:

  • goPESTconfig.toml, this file contains all settings/configurations related to the running of goPEST. It is written in TOML file format. The file should be placed in the project folder, where user runs gopest commands from. It is possible to let goPEST generate one with default values. The file tries to be self-explanatory with comments.

  • goPESTpar.list is where user specifies model parameters for PEST

  • goPESTobs.list is where user specifies model observations for PEST

  • goPESTuser.py is optional if user wish do perform customised setups when the simulation transit from one stage to the next stage in sequence of simulator runs (eg. usually ns and pr normally natural state then followed by production history).

Basic usage

The main CLI script gopest is to be followed by COMMAND and associated arguments:

gopest COMMAND [ARGUMENTS]

To get a list of supported COMMANDs, type gopest help.

The first step is to initialise the working directory:

gopest init

will setup the current folder. If all goes well, user can simply run the command:

gopest submit or gopest run

to start the PEST run. Command submit is for the NeSI cluster environment using SLURM. Job(s) will be submitted to the cluster queue. PEST master and agents will be launched automatically. On a local machine where user has full access gopest run is used.

How goPEST works

Several tasks were performed by the init command:

  • copy user's model files into what goPEST uses internally, these are the real_model_xxx.* files, in the current folder, which is also the master folder where PEST is expected to work on.

  • go through goPESTpar.list, extract and set up parameter data in the PEST control file (usually case.pst). The corresponding .tpl files etc required by PEST will be set up. Note the parameters used in the real model will be extracted and used as the initial parameters in the PEST.

  • go through goPESTobs.list, and set up observation data in the PEST control file. Corresponding PEST instruction file .ins will also be set up automatically.

Development notes

  • install an editable version of goPEST:

python -m pip install -e /path/to/repo/root

  • run tests at the root of the repo:

python -m pytest

  • generalised model sequence runner? now loads user goPESTuser.py, but internal needs to generalise to have more than two run sequence

  • in run_ns_pr, code shouldn't worry about nesi/cluster related things, maybe not running local vs nesi either

  • remove obsreref related things, use pest_hp now

  • I have checked a few PEST related Python libraries. I am looking for something small and pure for basic editing of PEST control file. But these are too big for my liking. I should reconsider about using them.

TODO

  • gopest run generate and use comm file _gopest.json now, update gopest submit to do so

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gopest-0.0.17.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gopest-0.0.17-py3-none-any.whl (85.0 kB view details)

Uploaded Python 3

File details

Details for the file gopest-0.0.17.tar.gz.

File metadata

  • Download URL: gopest-0.0.17.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for gopest-0.0.17.tar.gz
Algorithm Hash digest
SHA256 b809e019d663f5f1bd80b9c56e9cd1742142d68da1aa3ae2dacae46295cb83ae
MD5 cfc627ea5d03c07f4b570308253aefd9
BLAKE2b-256 98ae1dbe649cb17e0721e2ee65ff953e2161c44e88d179465aafb2311052a970

See more details on using hashes here.

File details

Details for the file gopest-0.0.17-py3-none-any.whl.

File metadata

  • Download URL: gopest-0.0.17-py3-none-any.whl
  • Upload date:
  • Size: 85.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for gopest-0.0.17-py3-none-any.whl
Algorithm Hash digest
SHA256 5e3bcb3c54e4f7047ffa235534a1ebd13198781c2ccf5d04d0125aa0dfb621c7
MD5 f8d1939735360fc1b0bb39e684d742da
BLAKE2b-256 09770659b3fd2bf01ee7d1654d8d9c06351ac377417a6836d6890ef1578088c2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page