Skip to content

ZacharyWills/CloudInfra-1

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Welcome to NextGen Framework National Water Model Community Repo. (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:

  1. Install docker:

  2. Start docker: 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: Start Docker Desktop

  3. Download the input data in "ngen-data" folder :

     - Download input data from S3 bucket:
             $ cd ~/Documents/NextGen
             $ mkdir ngen-data
             $ cd ngen-data
    
         $ `wget --no-parent https://ciroh-ua-ngen-data.s3.us-east-2.amazonaws.com/AWI-001/AWI_03W_113060_001.tar.gz` 
         OR
         Use browser to download the data from https://ciroh-ua-ngen-data.s3.us-east-2.amazonaws.com/AWI-001/AWI_03W_113060_001.tar.gz
    
      - Untar:
         $ tar -xf AWI_03W_113060_001.tar.gz
    
      - Copy the path from below command:
         `$ cd AWI_03W_113060_001
         $ pwd
         Copy the path that will be used in the step #1 below while running guide.sh script.`
    

Clone the repo

Clone the repo using below commands:

$ cd ~/Documents
$ mkdir NextGen
$ cd NextGen
$ git clone https://github.com/AlabamaWaterInstitute/CloudInfra.git
$ cd CloudInfra

Run the script:

guide.sh - Bash script that is used to run the NGEN model.

Go to the cloned repo and 
$ cd CloudInfra
$ ./guide.sh
  1. The script first prompts for entering the Input data directory file path where forcings and config files are stored. (Prerequisites Step#2 - copied path)

  2. It sets the provided directory to HOST_DATA_PATH variable and use it. It then uses the find command to find all of the catchment, nexus, and realization files in the working directory.

  3. It will then ask for option to run_NextGen or exit. If run_NextGen is selected, then based on the local machine’s architecture, the script pulls the related image from awiciroh Dockerhub.

  • For Mac (arm architecture), it pulls awiciroh/ciroh-ngen-image:latest-arm
  • For x86 machines, it pulls awiciroh/ciroh-ngen-image:latest-x86
  1. It then prompts the user 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. The script generates a partition file for the NGEN model. It then prompts the user to select the catchment, nexus, and realization files that they want to use.

    e.g for parallel run: NGEN run command is 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 Your NGEN run command is 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

  2. If the user selects serial mode, the script runs the model directly.

    e.g for serial run: NGEN run command is /dmod/bin/ngen-serial /ngen/ngen/data/config/catchments.geojson "" /ngen/ngen/data/config/nexus.geojson "" /ngen/ngen/data/config/awi_simplified_realization.json

  3. After the model has run, the script prompts the user whether they want to continue. If the user selects yes, the script opens an interactive shell. If the user selects no, the script exits.

  4. The output files get copied to the “outputs” folder in HOST_DATA_PATH.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Dockerfile 61.2%
  • HCL 21.5%
  • Shell 17.3%