Skip to content

Commit

Permalink
Revised some functions and sub-routines in numutils.f90 for improved …
Browse files Browse the repository at this point in the history
…numerical stability

and approaches.

Merge branch 'mainline' into mpaiao-pr-quadratic
  • Loading branch information
mpaiao committed Dec 31, 2024
2 parents ee2bd4f + f5acf6d commit cd53bad
Show file tree
Hide file tree
Showing 250 changed files with 23,059 additions and 11,666 deletions.
62 changes: 21 additions & 41 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -1,71 +1,51 @@
name: CI

on: [push, pull_request]
on:
push:
branches:
- master
- main

pull_request:

jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- uses: actions/checkout@v4
- name: Install dependencies
run: sudo apt-get install -y --no-install-recommends gfortran libhdf5-openmpi-dev libopenmpi-dev
- name: Install ED2
run: |
cd ED/build
./install.sh -g -p travisci -k A
- name: Upload compiled ED2 binary
uses: actions/upload-artifact@v1
uses: actions/upload-artifact@v4
with:
name: ed2-binary
path: ED/build/ed_2.2-dbg

test-umbs-bg:
needs: build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- name: Retrieve compiled binary
uses: actions/download-artifact@v1
with:
name: ed2-binary
- name: Install dependencies
run: sudo apt-get install -y --no-install-recommends gfortran libhdf5-openmpi-dev libopenmpi-dev
- name: Run ED2
working-directory: ./EDTS/
run: |
chmod +x "$GITHUB_WORKSPACE"/ed2-binary/ed_2.2-dbg
./run-test.sh umbs.bg "$GITHUB_WORKSPACE/ed2-binary/ed_2.2-dbg"
test-tonzi:
tests:
needs: build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- name: Retrieve compiled binary
uses: actions/download-artifact@v1
with:
name: ed2-binary
- name: Install dependencies
run: sudo apt-get install -y --no-install-recommends gfortran libhdf5-openmpi-dev libopenmpi-dev
- name: Run ED2
working-directory: ./EDTS/
run: |
chmod +x "$GITHUB_WORKSPACE"/ed2-binary/ed_2.2-dbg
./run-test.sh tonzi "$GITHUB_WORKSPACE/ed2-binary/ed_2.2-dbg"
strategy:
fail-fast: false
matrix:
name:
- umbs.bg
- tonzi
- tonzi.harvest

test-tonzi-harvest:
needs: build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- uses: actions/checkout@v4
- name: Retrieve compiled binary
uses: actions/download-artifact@v1
uses: actions/download-artifact@v4
with:
name: ed2-binary
- name: Install dependencies
run: sudo apt-get install -y --no-install-recommends gfortran libhdf5-openmpi-dev libopenmpi-dev
- name: Run ED2
working-directory: ./EDTS/
run: |
chmod +x "$GITHUB_WORKSPACE"/ed2-binary/ed_2.2-dbg
./run-test.sh tonzi.harvest "$GITHUB_WORKSPACE/ed2-binary/ed_2.2-dbg"
chmod +x "$GITHUB_WORKSPACE"/ed_2.2-dbg
./run-test.sh ${{ matrix.name }} "$GITHUB_WORKSPACE/ed_2.2-dbg"
220 changes: 166 additions & 54 deletions .github/workflows/docker.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
name: Docker

# This will run when:
# - when new code is pushed to master to push the tags latest.
# - when new code is pushed to master/main to push the tags latest.
# - when a pull request is created and updated to make sure the
# Dockerfile is still valid.

Expand All @@ -19,77 +19,189 @@ on:
push:
branches:
- master
- main

release:
types:
- published

pull_request:

# Certain actions will only run when this is the master repo.
# Certain actions will only run when this is the master/main repo.
env:
MASTER_REPO: EDModel/ED2
DOCKERHUB_ORG: pecan
MAIN_REPO: EDmodel/ED2
DOCKERHUB_ORG: edmodel

jobs:
docker:
runs-on: ubuntu-latest
permissions:
packages: write

strategy:
fail-fast: false
matrix:
include:
- name: gnu
PLATFORM: "linux/amd64,linux/arm64"
- name: intel
PLATFORM: "linux/amd64"

steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v4

# free up space
- name: Free Disk Space (Ubuntu)
uses: jlumbroso/free-disk-space@main
with:
tool-cache: true
android: true
dotnet: true
haskell: true
large-packages: true
docker-images: false
swap-storage: true

# calculate some variables that are used later
- name: github branch
- name: version information
run: |
BRANCH=${GITHUB_REF##*/}
if [ "$BRANCH" == "master" ]; then
TAGS="latest"
# find out what the BRANCH is, in case of a PR we will use the PR-<number>
if [ "${{ github.event.release.target_commitish }}" != "" ]; then
BRANCH="${{ github.event.release.target_commitish }}"
elif [[ $GITHUB_REF =~ pull ]]; then
BRANCH="$(echo $GITHUB_REF | sed 's#refs/pull/\([0-9]*\)/merge#PR-\1#')"
else
TAGS="$BRANCH"
BRANCH=${GITHUB_REF##*/}
fi
echo "TAGS=${TAGS}" >> $GITHUB_ENV
echo "GITHUB_BRANCH=${BRANCH}" >> $GITHUB_ENV
# build the docker image, this will always run to make sure
# the Dockerfile still works.
- name: Build image
uses: elgohr/[email protected]
env:
BRANCH: ${{ env.GITHUB_BRANCH }}
BUILDNUMBER: ${{ github.run_number }}
GITSHA1: ${{ github.sha }}
# calculate the version and all tags
if [ "$BRANCH" == "main" -o "$BRANCH" == "master" ]; then
VERSION="latest"
tags="${{ matrix.name }}"
if [ "${{ matrix.name }}" == "intel" ]; then
tags="${tags} latest"
fi
else
VERSION="${{ matrix.name }}-$BRANCH"
tags="${{ matrix.name }}-$BRANCH"
fi
# should we push to dockerhub, and is there a README
DOCKERHUB_PUSH="false"
DOCKERHUB_README="false"
if [ "${{ github.repository }}" == "${{ env.MAIN_REPO }}" ]; then
if [ "${{ secrets.DOCKERHUB_USERNAME }}" != "" -a "${{ secrets.DOCKERHUB_PASSWORD }}" != "" ]; then
DOCKERHUB_PUSH="true"
if [ -e "README.md" ]; then
DOCKERHUB_README="true"
fi
fi
fi
# create a list of all images to be pushed
REPO="${{ github.repository_owner }}"
REPO="${REPO,,}"
IMAGE="${{ github.event.repository.name }}"
IMAGE="${IMAGE,,}"
DEV_IMAGES=""
IMAGES=""
for tag in ${tags}; do
if [ "$DOCKERHUB_PUSH" == "true" ]; then
DEV_IMAGES="${DEV_IMAGES}${{ env.DOCKERHUB_ORG }}/${IMAGE}-dev:${tag},"
IMAGES="${IMAGES}${{ env.DOCKERHUB_ORG }}/${IMAGE}:${tag},"
fi
DEV_IMAGES="${DEV_IMAGES}ghcr.io/${REPO}/${IMAGE}-dev:${tag},"
IMAGES="${IMAGES}ghcr.io/${REPO}/${IMAGE}:${tag},"
done
IMAGES="${IMAGES%,*}"
# save the results in env
echo "BRANCH=${BRANCH}"
echo "VERSION=${VERSION}"
echo "DOCKERHUB_README=${DOCKERHUB_README}"
echo "DOCKERHUB_PUSH=${DOCKERHUB_PUSH}"
echo "IMAGES=${IMAGES}"
echo "BRANCH=${BRANCH}" >> $GITHUB_ENV
echo "VERSION=${VERSION}" >> $GITHUB_ENV
echo "DOCKERHUB_README=${DOCKERHUB_README}" >> $GITHUB_ENV
echo "DOCKERHUB_PUSH=${DOCKERHUB_PUSH}" >> $GITHUB_ENV
echo "DEV_IMAGES=${DEV_IMAGES}" >> $GITHUB_ENV
echo "IMAGES=${IMAGES}" >> $GITHUB_ENV
# setup docker build
- name: Set up QEMU
uses: docker/setup-qemu-action@v3

- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v3

- name: Inspect Builder
run: |
echo "Name: ${{ steps.buildx.outputs.name }}"
echo "Endpoint: ${{ steps.buildx.outputs.endpoint }}"
echo "Status: ${{ steps.buildx.outputs.status }}"
echo "Flags: ${{ steps.buildx.outputs.flags }}"
echo "Platforms: ${{ steps.buildx.outputs.platforms }}"
# login to registries
- name: Login to DockerHub
if: env.DOCKERHUB_PUSH == 'true'
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_PASSWORD }}

- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: docker.pkg.github.com
name: ${{ github.repository_owner }}/${{ github.event.repository.name }}/ed
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
tags: "${{ env.TAGS }}"
buildargs: BRANCH,BUILDNUMBER,GITSHA1
no_push: true

# this will publish to github container registry
- name: Publish to GitHub
if: github.event_name == 'push' && github.repository == env.MASTER_REPO
uses: elgohr/[email protected]
env:
BRANCH: ${{ env.GITHUB_BRANCH }}
BUILDNUMBER: ${{ github.run_number }}
GITSHA1: ${{ github.sha }}

- name: DF
run: df -h .

# build the dev docker images
- name: Build and push docker
uses: docker/build-push-action@v6
with:
registry: ghcr.io
name: ${{ github.repository_owner }}/ed
username: ${{ secrets.GHCR_USERNAME }}
password: ${{ secrets.GHCR_PASSWORD }}
tags: "${{ env.TAGS }}"
buildargs: BRANCH,BUILDNUMBER,GITSHA1

# this will publish to the pecan dockerhub repo
- name: Publish to Docker Hub
if: github.event_name == 'push' && github.repository == env.MASTER_REPO
uses: elgohr/[email protected]
env:
BRANCH: ${{ env.GITHUB_BRANCH }}
BUILDNUMBER: ${{ github.run_number }}
GITSHA1: ${{ github.sha }}
push: true
platforms: ${{ matrix.PLATFORM }}
file: Dockerfile.${{ matrix.name }}
target: build
cache-from: type=gha,scope=ed-${{ matrix.name }}-build
cache-to: type=gha,scope=ed-${{ matrix.name }}-build,mode=max
tags: ${{ env.DEV_IMAGES }}
build-args: |
BRANCH: ${{ env.BRANCH }}
VERSION=${{ env.VERSION }}
BUILDNUMBER=${{ github.run_number }}
GITSHA1=${{ github.sha }}
# build the docker images
- name: Build and push docker
uses: docker/build-push-action@v6
with:
name: ${{ env.DOCKERHUB_ORG }}/ed
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_PASSWORD }}
tags: "${{ env.TAGS }}"
buildargs: BRANCH,BUILDNUMBER,GITSHA1
push: true
platforms: ${{ matrix.PLATFORM }}
file: Dockerfile.${{ matrix.name }}
cache-from: type=gha,scope=ed-${{ matrix.name }}-build
cache-to: type=gha,scope=ed-${{ matrix.name }}-build,mode=max
tags: ${{ env.IMAGES }}
build-args: |
BRANCH: ${{ env.BRANCH }}
VERSION=${{ env.VERSION }}
BUILDNUMBER=${{ github.run_number }}
GITSHA1=${{ github.sha }}
# this will update the README of the dockerhub repo
- name: Docker Hub Description
if: env.DOCKERHUB_README == 'true'
uses: peter-evans/dockerhub-description@v4
env:
DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }}
DOCKERHUB_PASSWORD: ${{ secrets.DOCKERHUB_PASSWORD }}
DOCKERHUB_REPOSITORY: ${{ env.DOCKERHUB_ORG }}/${{ github.event.repository.name }}
README_FILEPATH: README.md
Loading

0 comments on commit cd53bad

Please sign in to comment.