DAMASK_EICMD/.github/workflows/Fortran.yml

185 lines
6.4 KiB
YAML
Raw Normal View History

2021-09-05 13:53:42 +05:30
name: Grid and Mesh Solver
2021-09-04 22:14:24 +05:30
on: [push]
env:
2022-04-22 23:57:03 +05:30
PETSC_VERSION: '3.17.0'
2021-12-12 03:38:18 +05:30
HOMEBREW_NO_ANALYTICS: 'ON' # Make Homebrew installation a little quicker
HOMEBREW_NO_AUTO_UPDATE: 'ON'
HOMEBREW_NO_BOTTLE_SOURCE_FALLBACK: 'ON'
HOMEBREW_NO_GITHUB_API: 'ON'
HOMEBREW_NO_INSTALL_CLEANUP: 'ON'
2021-09-04 22:14:24 +05:30
jobs:
2021-09-05 13:53:42 +05:30
2021-09-04 22:14:24 +05:30
gcc:
2021-09-05 13:53:42 +05:30
2021-09-04 22:14:24 +05:30
runs-on: ${{ matrix.os }}
2021-09-05 13:53:42 +05:30
2021-09-04 22:14:24 +05:30
strategy:
matrix:
os: [ubuntu-latest, macos-latest]
2021-09-05 13:53:42 +05:30
gcc_v: [9, 10, 11] # Version of GCC compilers
2021-09-04 22:14:24 +05:30
env:
GCC_V: ${{ matrix.gcc_v }}
steps:
2021-09-05 13:53:42 +05:30
- uses: actions/checkout@v2
2021-09-04 22:14:24 +05:30
2021-09-05 20:16:09 +05:30
- name: GCC - Install (Linux)
2021-09-04 22:14:24 +05:30
if: contains( matrix.os, 'ubuntu')
run: |
sudo add-apt-repository ppa:ubuntu-toolchain-r/test
sudo apt-get update
sudo apt-get install -y gcc-${GCC_V} gfortran-${GCC_V} g++-${GCC_V}
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-${GCC_V} 100 \
--slave /usr/bin/gfortran gfortran /usr/bin/gfortran-${GCC_V} \
--slave /usr/bin/g++ g++ /usr/bin/g++-${GCC_V} \
--slave /usr/bin/gcov gcov /usr/bin/gcov-${GCC_V}
2021-09-05 20:16:09 +05:30
- name: GCC - Install (macOS)
2021-09-04 22:14:24 +05:30
if: contains( matrix.os, 'macos')
run: |
brew install gcc@${GCC_V} || brew upgrade gcc@${GCC_V} || true
brew link gcc@${GCC_V}
2021-09-05 20:16:09 +05:30
- name: PETSc - Cache download
id: petsc-download
uses: actions/cache@v2
with:
path: download
2021-12-12 03:38:18 +05:30
key: petsc-${{ env.PETSC_VERSION }}.tar.gz
2021-09-05 20:16:09 +05:30
- name: PETSc - Download
if: steps.petsc-download.outputs.cache-hit != 'true'
run: |
2021-12-12 03:38:18 +05:30
wget -q https://ftp.mcs.anl.gov/pub/petsc/release-snapshots/petsc-${PETSC_VERSION}.tar.gz -P download
2021-09-05 20:16:09 +05:30
- name: PETSc - Prepare
2021-09-04 22:14:24 +05:30
run: |
2021-12-12 03:38:18 +05:30
tar -xf download/petsc-${PETSC_VERSION}.tar.gz -C .
export PETSC_DIR=${PWD}/petsc-${PETSC_VERSION}
2021-09-04 22:14:24 +05:30
export PETSC_ARCH=gcc${GCC_V}
printenv >> $GITHUB_ENV
2021-09-05 20:16:09 +05:30
- name: PETSc - Cache installation
id: petsc-install
2021-09-04 22:14:24 +05:30
uses: actions/cache@v2
with:
2021-12-12 03:38:18 +05:30
path: petsc-${{ env.PETSC_VERSION }}
key: petsc-${{ env.PETSC_VERSION }}-${{ matrix.os }}-gcc${{ matrix.gcc_v }}-${{ hashFiles('**/petscversion.h') }}
2021-09-04 22:14:24 +05:30
2021-09-05 20:16:09 +05:30
- name: PETSc - Install (Linux)
2021-09-04 22:14:24 +05:30
if: contains( matrix.os, 'ubuntu')
run: |
2021-12-12 03:38:18 +05:30
cd petsc-${PETSC_VERSION}
2021-09-04 22:14:24 +05:30
./configure --with-fc=gfortran --with-cc=gcc --with-cxx=g++ \
2021-10-08 19:35:36 +05:30
--download-mpich --download-fftw --download-hdf5 --download-hdf5-fortran-bindings=1 --download-zlib \
2021-09-04 22:14:24 +05:30
--with-mpi-f90module-visibility=0
make all
2021-09-05 20:16:09 +05:30
- name: PETSc - Install (macOS)
2021-09-04 22:14:24 +05:30
if: contains( matrix.os, 'macos')
run: |
2021-12-12 03:38:18 +05:30
cd petsc-${PETSC_VERSION}
2021-09-04 22:14:24 +05:30
./configure --with-fc=gfortran-${GCC_V} --with-cc=gcc-${GCC_V} --with-cxx=g++-${GCC_V} \
2021-10-08 19:35:36 +05:30
--download-openmpi --download-fftw --download-hdf5 --download-hdf5-fortran-bindings=1 --download-zlib
2021-09-04 22:14:24 +05:30
make all
2021-09-05 20:16:09 +05:30
- name: DAMASK - Compile
2021-09-04 22:14:24 +05:30
run: |
cmake -B build/grid -DDAMASK_SOLVER=grid -DCMAKE_INSTALL_PREFIX=${PWD}
cmake --build build/grid --parallel
cmake --install build/grid
cmake -B build/mesh -DDAMASK_SOLVER=mesh -DCMAKE_INSTALL_PREFIX=${PWD}
cmake --build build/mesh --parallel
cmake --install build/mesh
2021-09-05 20:16:09 +05:30
- name: DAMASK - Run
2021-09-04 22:14:24 +05:30
run: |
./bin/DAMASK_grid -l tensionX.yaml -g 20grains16x16x16.vti -w examples/grid
intel:
2021-09-05 13:53:42 +05:30
2021-09-04 22:14:24 +05:30
runs-on: [ubuntu-latest]
2021-09-05 13:53:42 +05:30
2021-09-04 22:14:24 +05:30
strategy:
matrix:
2021-09-05 13:53:42 +05:30
intel_v: [classic, llvm] # Variant of Intel compilers
2021-09-04 22:14:24 +05:30
env:
INTEL_V: ${{ matrix.intel_v }}
steps:
2021-09-05 13:53:42 +05:30
- uses: actions/checkout@v2
2021-09-04 22:14:24 +05:30
2021-09-05 20:16:09 +05:30
- name: Intel - Install
2021-09-04 22:14:24 +05:30
run: |
wget -q https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS-2023.PUB
sudo apt-key add GPG-PUB-KEY-INTEL-SW-PRODUCTS-2023.PUB
rm GPG-PUB-KEY-INTEL-SW-PRODUCTS-2023.PUB
echo "deb https://apt.repos.intel.com/oneapi all main" | sudo tee /etc/apt/sources.list.d/oneAPI.list
sudo apt-get update
2021-09-05 20:16:09 +05:30
sudo apt-get install \
intel-basekit \
intel-oneapi-compiler-dpcpp-cpp-and-cpp-classic intel-oneapi-compiler-fortran \
intel-oneapi-openmp intel-oneapi-mkl-devel
2021-09-04 22:14:24 +05:30
source /opt/intel/oneapi/setvars.sh
printenv >> $GITHUB_ENV
2021-09-05 20:16:09 +05:30
- name: PETSc - Cache download
id: petsc-download
uses: actions/cache@v2
with:
path: download
2021-12-12 03:38:18 +05:30
key: petsc-${{ env.PETSC_VERSION }}.tar.gz
2021-09-05 20:16:09 +05:30
- name: PETSc - Download
if: steps.petsc-download.outputs.cache-hit != 'true'
run: |
2021-12-12 03:38:18 +05:30
wget -q https://ftp.mcs.anl.gov/pub/petsc/release-snapshots/petsc-${PETSC_VERSION}.tar.gz -P download
2021-09-05 20:16:09 +05:30
- name: PETSc - Prepare
2021-09-04 22:14:24 +05:30
run: |
2021-12-12 03:38:18 +05:30
tar -xf download/petsc-${PETSC_VERSION}.tar.gz -C .
export PETSC_DIR=${PWD}/petsc-${PETSC_VERSION}
2021-09-04 22:14:24 +05:30
export PETSC_ARCH=intel-${INTEL_V}
printenv >> $GITHUB_ENV
2021-09-05 20:16:09 +05:30
- name: PETSc - Cache installation
id: petsc-install
2021-09-04 22:14:24 +05:30
uses: actions/cache@v2
with:
2021-12-12 03:38:18 +05:30
path: petsc-${{ env.PETSC_VERSION }}
key: petsc-${{ env.PETSC_VERSION }}-intel-${{ matrix.intel_v }}-${{ hashFiles('**/petscversion.h') }}
2021-09-04 22:14:24 +05:30
2021-09-05 20:16:09 +05:30
- name: PETSc - Install (classic)
2021-09-04 22:14:24 +05:30
if: contains( matrix.intel_v, 'classic')
run: |
2021-12-12 03:38:18 +05:30
cd petsc-${PETSC_VERSION}
2021-09-04 22:14:24 +05:30
./configure --with-fc=mpiifort --with-cc=mpiicc --with-cxx=mpiicpc \
2021-10-08 19:35:36 +05:30
--download-fftw --download-hdf5 --download-hdf5-fortran-bindings=1 --download-zlib
2021-09-04 22:14:24 +05:30
make all
2021-09-05 20:16:09 +05:30
- name: PETSc - Install (LLVM)
2021-09-04 22:14:24 +05:30
if: contains( matrix.intel_v, 'llvm')
run: |
2021-12-12 03:38:18 +05:30
cd petsc-${PETSC_VERSION}
2021-09-04 22:14:24 +05:30
./configure --with-fc=mpiifort --with-cc="mpiicc -cc=icx" --with-cxx="mpiicpc -cxx=icpx" \
2021-10-08 19:35:36 +05:30
--download-fftw --download-hdf5 --download-hdf5-fortran-bindings=1 --download-zlib
2021-09-04 22:14:24 +05:30
make all
2021-09-05 20:16:09 +05:30
- name: DAMASK - Compile
2021-09-04 22:14:24 +05:30
run: |
cmake -B build/grid -DDAMASK_SOLVER=grid -DCMAKE_INSTALL_PREFIX=${PWD}
cmake --build build/grid --parallel
cmake --install build/grid
cmake -B build/mesh -DDAMASK_SOLVER=mesh -DCMAKE_INSTALL_PREFIX=${PWD}
cmake --build build/mesh --parallel
cmake --install build/mesh
2021-09-05 20:16:09 +05:30
- name: DAMASK - Run
2021-09-04 22:14:24 +05:30
run: |
./bin/DAMASK_grid -l tensionX.yaml -g 20grains16x16x16.vti -w examples/grid