Skip to content

Commit

Permalink
Merge pull request NAG-DevOps#37 from carlos-encs/openFoam
Browse files Browse the repository at this point in the history
Openfoam example
  • Loading branch information
smokhov authored Feb 26, 2024
2 parents a423631 + d93f8e2 commit 08a0bc1
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 0 deletions.
16 changes: 16 additions & 0 deletions src/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ run certcain things.
- Detailed Examples
+ [efficientdet](#efficientdet)
* [Diviner Tools](#diviner-tools)
* [OpenFoam](#openfoam-multinode)
* [OpenISS-yolov3](#openiss-yolov3)
+ [Speed Login Configuration ](#speed-login-configuration)
+ [Speed Setup and Development Environment Preperation](#speed-setup-and-development-environment-preperation)
Expand Down Expand Up @@ -59,6 +60,7 @@ These are examples either trivial or some are more elaborate. Some are described
- `pytorch-multicpu.txt` -- using Pytorch with Python virtual environment to run on CPUs; with instructions and code ready to paste.
- `pytorch-multinode-multigpu.sh` -- using Pytorch with Python virtual environment to run on Multinodes and MultiGpus
- `lambdal-singularity.sh` -- an example use of the Singularity container to run LambdaLabs software stack on the GPU node. The container was built from the docker image as a [source](https://github.com/NAG-DevOps/lambda-stack-dockerfiles).
- `openfoam-multinode.sh` -- an example using OpenFoam, icoFoam solver to run on Multinodes-multicpus
- `openiss-reid-speed.sh` -- OpenISS computer vision exame for re-edentification, see [more](https://github.com/NAG-DevOps/speed-hpc/tree/master/src#openiss-reid-tfk) in its section
- `openiss-yolo-cpu.sh`, `openiss-yolo-gpu.sh`, and `openiss-yolo-interactive.sh` -- OpenISS examples with YOLO, related to `reid`, see [more](https://github.com/NAG-DevOps/speed-hpc/tree/master/src#openiss-yolov3) in the corresponding section

Expand Down Expand Up @@ -207,6 +209,20 @@ pip install git+https://github.com/cocodataset/cocoapi.git#subdirectory=PythonAP

- [Speed-related scripts](https://github.com/d-chante/diviner-tools/tree/development/jobs/speed)

<!-- TOC --><a name="openfoam-multinode"></a>
## OpenFoam-multinode

This example is taken from OpenFoam tutorials section: $FOAM_TUTORIALS/incompressible/icoFoam/cavity/cavity
1. Go to your speed-scratch directory: `cd /speed-scratch/$USER`
2. open a salloc session
3. Load OpenFoam module: `module load OpenFOAM/v2306/default`
4. Copy the cavity example to your speed-scratch space: `cp -r $FOAM_TUTORIALS/incompressible/icoFoam/cavity/cavity/ .`
5. Modify cavity/system/decomposeParDict:
Remove coeffs section and modify the following:
numberOfSubdomains 10;
method scotch;
6. Exit the salloc session, go to the cavity directory and run the script: `sbatch --mem=10Gb -pps --constraint=el9 openfoam-multinode.sh`

<!-- TOC --><a name="openiss-yolov3"></a>
## OpenISS-yolov3

Expand Down
16 changes: 16 additions & 0 deletions src/openfoam-multinode.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
#!/encs/bin/tcsh
#SBATCH --job-name=OpenFOAM-test
#SBATCH --nodes=4
#SBATCH --ntasks=10
#SBATCH --time=00:10:00

module load OpenFOAM/v2306/default
setenv PATH /encs/pkg/openmpi-4.1.6/root/bin\:$PATH
setenv LD_LIBRARY_PATH $LD_LIBRARY_PATH\:/encs/pkg/openmpi-4.1.6/root/lib64
setenv CORES $SLURM_NTASKS
setenv OMP_NUM_THREADS $CORES

blockMesh
mpirun -np $CORES redistributePar -decompose -overwrite -parallel
mpirun -np $CORES icoFoam -parallel
mpirun -np $CORES redistributePar -reconstruct -overwrite -parallel

0 comments on commit 08a0bc1

Please sign in to comment.