From d38a87b482e71dfc9bcc4bed39e1c211a3184fca Mon Sep 17 00:00:00 2001 From: Aaron Ho Date: Tue, 19 Nov 2024 17:27:13 -0500 Subject: [PATCH] Added build and instructions for Pixi environment manager (#414) * Added platform file for general Pixi Conda build * Added environment and exec files for pixi * Fix instructions to include OpenBLAS with OpenMP * Split PIXI build into mpich and openmpi versions * Enable oversubscribe in PIXI_OPENMP build --- platform/build/make.inc.PIXI_MPICH | 73 +++++++++++++++++++++++++++++ platform/build/make.inc.PIXI_OPENMP | 73 +++++++++++++++++++++++++++++ platform/env/env.PIXI_MPICH | 2 + platform/env/env.PIXI_OPENMP | 2 + platform/exec/exec.PIXI_MPICH | 19 ++++++++ platform/exec/exec.PIXI_OPENMP | 19 ++++++++ 6 files changed, 188 insertions(+) create mode 100644 platform/build/make.inc.PIXI_MPICH create mode 100644 platform/build/make.inc.PIXI_OPENMP create mode 100644 platform/env/env.PIXI_MPICH create mode 100644 platform/env/env.PIXI_OPENMP create mode 100755 platform/exec/exec.PIXI_MPICH create mode 100755 platform/exec/exec.PIXI_OPENMP diff --git a/platform/build/make.inc.PIXI_MPICH b/platform/build/make.inc.PIXI_MPICH new file mode 100644 index 000000000..e16106e2c --- /dev/null +++ b/platform/build/make.inc.PIXI_MPICH @@ -0,0 +1,73 @@ +#--------------------------------------------------- +# OSX, Linux mpich using pixi +# +# 1. Install Pixi +# curl -fsSL https://pixi.sh/install.sh | bash +# +# 2. Restart shell / terminal / console for Pixi to be recognized +# +# 3. Create Pixi environment +# pixi init +# +# 4. Setup Pixi environment +# cd +# git clone git@github.com:gafusion/gacode.git +# pixi add "python~=3.12,<3.13" +# pixi add git +# pixi add mpich +# pixi add gfortran +# pixi add openblas +# pixi add "libopenblas=*=*openmp*" +# pixi add liblapack +# pixi add fftw +# pixi add hdf5 +# pixi add netcdf-fortran +# +# 5. Enter and configure Pixi environment (must be repeated every entry) +# pixi shell +# export GACODE_ROOT=${PIXI_PROJECT_ROOT}/gacode +# export GACODE_PLATFORM=PIXI_MPICH +# source ${GACODE_ROOT}/shared/bin/gacode_setup +# +# 6. Build GACODE +# cd gacode +# make +# cd .. +# +# 7. Run regression tests +# neo -r +# tglf -r +# cgyro -r -n 4 -nomp 2 +# tgyro -r -n 4 +# +#--------------------------------------------------- + +MAKE = make +PREFIX = ${CONDA_PREFIX} +NETCDF_PATH = ${PREFIX} +MF90 = mpif90 + +# Compilers and flags + +FC = ${MF90} -std=f2008 -fall-intrinsics -I$(GACODE_ROOT)/modules -J$(GACODE_ROOT)/modules -g -I${PREFIX}/include +F77 = ${MF90} -g + +FMATH = -fdefault-real-8 -fdefault-double-8 +FOPT = -O3 -m64 -fallow-argument-mismatch +FDEBUG = -Wall -fcheck=all -fbacktrace -fbounds-check -O0 -Wextra -finit-real=nan -Wunderflow -ffpe-trap=invalid,zero,overflow +FBOUND = -Wall -fbounds-check +FOMP = -fopenmp + +# System math libraries + +LMATH = -L${PREFIX}/lib -lfftw3 -llapack -lblas + +# Optional netCDF libraries + +NETCDF = -L${PREFIX}/lib -lnetcdff -lnetcdf +NETCDF_INC = ${PREFIX}/include + +# Archive + +ARCH = ar cr + diff --git a/platform/build/make.inc.PIXI_OPENMP b/platform/build/make.inc.PIXI_OPENMP new file mode 100644 index 000000000..093574949 --- /dev/null +++ b/platform/build/make.inc.PIXI_OPENMP @@ -0,0 +1,73 @@ +#--------------------------------------------------- +# OSX, Linux mpich using pixi +# +# 1. Install Pixi +# curl -fsSL https://pixi.sh/install.sh | bash +# +# 2. Restart shell / terminal / console for Pixi to be recognized +# +# 3. Create Pixi environment +# pixi init +# +# 4. Setup Pixi environment +# cd +# git clone git@github.com:gafusion/gacode.git +# pixi add "python~=3.12,<3.13" +# pixi add git +# pixi add openmpi-mpifort +# pixi add gfortran +# pixi add openblas +# pixi add "libopenblas=*=*openmp*" +# pixi add liblapack +# pixi add fftw +# pixi add hdf5 +# pixi add netcdf-fortran +# +# 5. Enter and configure Pixi environment (must be repeated every entry) +# pixi shell +# export GACODE_ROOT=${PIXI_PROJECT_ROOT}/gacode +# export GACODE_PLATFORM=PIXI_OPENMPI +# source ${GACODE_ROOT}/shared/bin/gacode_setup +# +# 6. Build GACODE +# cd gacode +# make +# cd .. +# +# 7. Run regression tests +# neo -r +# tglf -r +# cgyro -r -n 4 -nomp 2 +# tgyro -r -n 4 +# +#--------------------------------------------------- + +MAKE = make +PREFIX = ${CONDA_PREFIX} +NETCDF_PATH = ${PREFIX} +MF90 = mpif90 + +# Compilers and flags + +FC = ${MF90} -std=f2008 -fall-intrinsics -I$(GACODE_ROOT)/modules -J$(GACODE_ROOT)/modules -g -I${PREFIX}/include +F77 = ${MF90} -g + +FMATH = -fdefault-real-8 -fdefault-double-8 +FOPT = -O3 -m64 -fallow-argument-mismatch +FDEBUG = -Wall -fcheck=all -fbacktrace -fbounds-check -O0 -Wextra -finit-real=nan -Wunderflow -ffpe-trap=invalid,zero,overflow +FBOUND = -Wall -fbounds-check +FOMP = -fopenmp + +# System math libraries + +LMATH = -L${PREFIX}/lib -lfftw3 -llapack -lblas + +# Optional netCDF libraries + +NETCDF = -L${PREFIX}/lib -lnetcdff -lnetcdf +NETCDF_INC = ${PREFIX}/include + +# Archive + +ARCH = ar cr + diff --git a/platform/env/env.PIXI_MPICH b/platform/env/env.PIXI_MPICH new file mode 100644 index 000000000..a424ba80b --- /dev/null +++ b/platform/env/env.PIXI_MPICH @@ -0,0 +1,2 @@ +# The PIXI platform assumes that you have installed pixi and run the +# appropriate commands to have the virtual environment set up well. diff --git a/platform/env/env.PIXI_OPENMP b/platform/env/env.PIXI_OPENMP new file mode 100644 index 000000000..a424ba80b --- /dev/null +++ b/platform/env/env.PIXI_OPENMP @@ -0,0 +1,2 @@ +# The PIXI platform assumes that you have installed pixi and run the +# appropriate commands to have the virtual environment set up well. diff --git a/platform/exec/exec.PIXI_MPICH b/platform/exec/exec.PIXI_MPICH new file mode 100755 index 000000000..d0010ad46 --- /dev/null +++ b/platform/exec/exec.PIXI_MPICH @@ -0,0 +1,19 @@ +#!/bin/sh +# GACODE Parallel execution script (PIXI) +# +# NOTES: +# Used mpich2-1.0.1, so use mpirun rather than mpiexec + +simdir=${1} +nmpi=${2} +exec=${3} +nomp=${4} +numa=${5} +mpinuma=${6} + +echo $simdir + +cd $simdir + +mpirun -env OMP_NUM_THREADS $nomp -np $nmpi $exec + diff --git a/platform/exec/exec.PIXI_OPENMP b/platform/exec/exec.PIXI_OPENMP new file mode 100755 index 000000000..f4f1798b1 --- /dev/null +++ b/platform/exec/exec.PIXI_OPENMP @@ -0,0 +1,19 @@ +#!/bin/sh +# GACODE Parallel execution script (PIXI_OPENMP) +# +# NOTES: +# Used openmpi-5.0.1 + +simdir=${1} +nmpi=${2} +exec=${3} +nomp=${4} +numa=${5} +mpinuma=${6} + +echo $simdir + +cd $simdir + +mpirun -x OMP_NUM_THREADS=$nomp -np $nmpi --oversubscribe $exec +