We are doing a case study : NWM run for Sipsey Fork,Black Warrior river
- We don’t want to run all of CONUS
- We want to run NextGen locally
- We want to have control over inputs / config.
- How can we do it? Answer: NextGen In A Box
This repository contains :
- Dockerfile for running NextGen Framework (docker/Dockerfile*)
- Terraform configuration files for provisioning infrastructure in AWS (terraform/README.md)
- Documentation of how to use the infrastructure and run the model. (README.md)
- Prerequisites:
- On *Windows*:
- [Install Docker Desktop on Windows](https://docs.docker.com/desktop/install/windows-install/#install-docker-desktop-on-windows)
- Once docker is installed, start Docker Destop.
- Open powershell -> right click and `Run as an Administrator`
- Type `docker ps -a` to make sure docker is working.
- On *Mac*:
- [Install docker on Mac](https://docs.docker.com/desktop/install/mac-install/)
- Once docker is installed, start Docker Desktop.
- Open terminal app
- Type `docker ps -a` to make sure docker is working.
- On *Linux*:
- [Install docker on Linux](https://docs.docker.com/desktop/install/linux-install/)
- Follow similar steps as *Mac* for starting Docker and verifying the installation
-
Open PowerShell as an administrator.
-
Run the following command to enable WSL feature:
wsl --install
-
Wait for the installation to complete. It may take some time as it will download and install the necessary components.
-
Once the installation is finished, you will be prompted to restart your computer. Type
Y
and press Enter to restart. -
After the computer restarts, open Microsoft Store.
-
Search for "WSL" or "Windows Subsystem for Linux" in the search bar.
-
Select the desired Linux distribution (e.g., Ubuntu, Debian, Fedora) from the search results.
-
Click on the distribution and then click the Install button.
-
Wait for the installation to complete. The installation process will download the Linux distribution package from the Microsoft Store.
-
Once the installation is finished, you can launch the Linux distribution from the Start menu or by running its command (e.g.,
ubuntu
). -
The first time you launch the Linux distribution, it will take some time to set up. Follow the on-screen instructions to create a username and password.
-
After the setup is complete, you can use the Linux distribution through WSL on your Windows system.
$ mkdir -p NextGen/ngen-data
$ cd NextGen/ngen-data
$ wget --no-parent https://ciroh-ua-ngen-data.s3.us-east-2.amazonaws.com/AWI-001/AWI_03W_113060_001.tar.gz
$ tar -xf AWI_03W_113060_001.tar.gz
$ cd AWI_03W_113060_001
Note: It is recommended to use WSL and follow instructions for Linux & Mac & WSL
$ mkdir NextGen
$ cd NextGen
$ mkdir ngen-data
$ cd ngen-data
$ Invoke-WebRequest -Uri "https://ciroh-ua-ngen-data.s3.us-east-2.amazonaws.com/AWI-001/AWI_03W_113060_001.tar.gz"
$ tar -xzf "\AWI_03W_113060_001.tar.gz"
$ cd AWI_03W_113060_001
Navigate to NextGen directory and clone the repo using below commands:
$ cd ../..
$ git clone https://github.com/CIROH-UA/NGIAB-CloudInfra.git
$ git checkout main
$ cd NGIAB-CloudInfra
Once you are in CloudInfra directory, you should see guide.sh
in it. Now, we are ready to run the model using that script.
Follow below steps to run guide.sh
script
$ ./guide.sh
What you will see when you run above
guide.sh
?
- The script prompts the user to enter the file path for the input data directory where the forcing and config files are stored.
Run the following command based on your OS and copy the path value:
Windows:
C:> cd ~\<path>\NextGen\ngen-data
c:> pwd
and copy the path
Linux/Mac:
$ cd ~/<path>/NextGen/ngen-data
$ pwd
and copy the path
where is the localtion of NextGen folder.
- The script sets the entered directory as the
HOST_DATA_PATH
variable and uses it to find all the catchment, nexus, and realization files using thefind
command. - Next, the user is asked whether to run NextGen or exit. If
run_NextGen
is selected, the script pulls the related image from the awiciroh Dockerhub, based on the local machine's architecture:
For Mac (arm architecture), it pulls awiciroh/ciroh-ngen-image:latest-arm.
For x86 machines, it pulls awiciroh/ciroh-ngen-image:latest-x86.
- The user is then prompted to select whether they want to run the model in parallel or serial mode.
- If the user selects parallel mode, the script uses the
mpirun
command to run the model and generates a partition file for the NGEN model. - If the user selects the catchment, nexus, and realization files they want to use.
Example NGEN run command for parallel mode:
mpirun -n 2 /dmod/bin/ngen-parallel
/ngen/ngen/data/config/catchments.geojson ""
/ngen/ngen/data/config/nexus.geojson ""
/ngen/ngen/data/config/awi_simplified_realization.json
/ngen/partitions_2.json
- If the user selects serial mode, the script runs the model directly.
Example NGEN run command for serial mode:
/dmod/bin/ngen-serial
/ngen/ngen/data/config/catchments.geojson ""
/ngen/ngen/data/config/nexus.geojson ""
/ngen/ngen/data/config/awi_simplified_realization.json
- After the model has finished running, the script prompts the user whether they want to continue.
- If the user selects 1, the script opens an interactive shell. If the user selects 2, then the script copies the output data from container to local machine.
- If the user selects 3, then the script exits.
The output files are copied to the outputs
folder in '/NextGen/ngen-data/AWI_03W_113060_001/' directory.