Skip to content

p-ortega/mf6rtm

Repository files navigation

MF6RTM: Reactive Transport Model via the MODFLOW 6 and PHREEQCRM APIs

Tests Tests Coverage Status PyPI License

PyPI Version PyPI Versions DOI

Benchmarks

Benchmark comparing model results against PHT3D are in benchmark/. Each folder contains a Jupyter notebook to write and execute an MF6RTM model via the MUP3D class. Additionally, PHT3D files are provided in the corresponding pht3d directory for each example.

Considerations

The current version is intended to work with structured grids (dis object in MF6), unstructured grids (disv) and one MF6 simulation that includes the flow and transport solutions. No support is currently provided for a 'flow then transport scheme,' meaning that advanced packages cannot be incorporated yet.

On the PHREEQC side, the following have been included:

  • Solution
  • Equilibrium phases
  • Cation Exchange
  • Surface Complexation
  • Kinetic Phases

Most options for each phreeqc block can be passed by adding list with options. However, not all options had been tested, so please create an issue if any option is not working or crashing the model.

Software requirements

All dependencies and executables are included in this repo. This package extensively uses modflowapi and phreeqcrm

Installation

Quick Start with pip

The package can be installed via pip:

pip install mf6rtm

Manual Installation with Conda/Mamba

If you prefer conda/mamba, create a dedicated environment:

mamba env create -f env.yml
mamba activate mf6rtm-dev

After activating the environment, install the MODFLOW6 executables:

pip install modflow-devtools
get-modflow --subset mf6,libmf6,gridgen :python

Once installed, the executables in envs/[env-name]/bin will be automatically invoked whenever mf6rtm runs within the environment.

Custom MODFLOW Versions

If you need custom or older versions of mf6 (e.g., for running PESTPP on an HPC cluster), place them in a separate directory and use the provided utility to bring them to the model working directory:

from mf6rtm import utils

utils.prep_bins(model_dir, src_path=path_to_bins)

Running the benchmark notebooks

We have provided some benchmarks in the form of Jupyter notebooks. We have also included the executables needed to run them out of the box. Nevertheless, they can also be run using the executables downloaded with modflow-devtools.

Developing

With Pixi (Recommended)

For development, we recommend using pixi for fast, reproducible environments:

# Fork and clone the repository
git clone https://github.com/YOUR-USERNAME/mf6rtm.git
cd mf6rtm

# Install development environment with all dependencies
pixi install

# Run tests
pixi run test

# Run tests with coverage
pixi run test-cov

# Run linting
pixi run lint

# Test with specific Python version
pixi run -e py311 test

With Conda/Mamba

Alternatively, use conda/mamba with the provided environment file:

# Install environment
conda env create -f env.yml
conda activate mf6rtm-dev

# Install development dependencies
pip install -r requirements_dev.txt

The development dependencies for testing are located in requirements_dev.txt. We have also provided dependencies with flopy and pyemu inside the repo but feel free to use your own distribution.

Funding

The developing of mf6rtm was kindly funded and supported by Intera, Inc.

Authors

Pablo Ortega (Portega)

About

A python package for reactive transport modeling via the MODFLOW 6 and PhreeqcRM APIs

Topics

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors