source: BOL/script_install_amaury/test_convergence.sh @ 5170

Last change on this file since 5170 was 5156, checked in by abarral, 6 months ago

Add 1D and iso bench
Better svn branch detection for lmdz
Add script to test convergence locally
Lint check_version.sh

  • Property svn:executable set to *
File size: 2.7 KB
Line 
1#!/bin/bash
2
3set -eu
4
5dim="32x32x39"
6base_args="-name LMDZ -netcdf 0 -arch_dir /home/abarral/PycharmProjects/installLMDZ/script_install/arch_local -arch local-gfortran-parallel_ -d $dim"  # those don't appear in the folder name (except dim)
7file_to_check="LMDZ/modipsl/modeles/LMDZ/BENCH$dim/restart.nc"
8base_path="/tmp/comp_bench/"
9local=$(pwd)
10
11function do_bench() {
12  local rev=$1
13  local path=$2
14  local install_args=$3
15  if [[ -f "$path/$file_to_check" ]]; then return; fi
16
17  rm -rf "$path"
18  mkdir -p "$path" && cd "$path"
19
20  cp "$local/install_lmdz.sh" .
21
22  local logf="comp.log"
23  local install_cmd="./install_lmdz.sh $base_args $install_args -r $rev"
24  echo "Running <$install_cmd> [log: $(pwd)/$logf]"
25  $install_cmd &> $logf
26}
27
28function comp_bench() {
29  local rev1=$1
30  local rev2=$2
31  local install_args=$3
32  local path1="$base_path/r${rev1}_d${dim}_${install_args// /_}"
33  local path2="$base_path/r${rev2}_d${dim}_${install_args// /_}"
34
35  do_bench "$rev1" "$path1" "$install_args"
36  do_bench "$rev2" "$path2" "$install_args"
37
38  if cmp "$path1/$file_to_check" "$path2/$file_to_check" &>/dev/null; then
39    echo "All good ! for r$rev1/r$rev2=$install_args"
40  else
41    echo ":( nope for r$rev1/r$rev2=$install_args"
42  fi
43}
44
45function comp_full() {
46  local rev1=$1
47  local rev2=$2
48
49  # Check all combinations
50  for rad in "oldrad" "rrtm" "ecrad"; do
51  for veget in "none" "CMIP6"; do
52  for para in "none" "mpi_omp"; do
53    comp_bench "$rev1" "$rev2" "-rad $rad -parallel $para -veget $veget -compilephysiq lmd"
54  done; done; done
55
56  # Check some additional params on sparse configs
57  comp_bench "$rev1" "$rev2" "-xios -rad oldrad -parallel $para -veget none -compilephysiq lmd"  # xios
58  for para in "none" "mpi_omp"; do
59    comp_bench "$rev1" "$rev2" "-cosp v1 -rad oldrad -parallel $para -veget none -compilephysiq lmd"  # cosp v1 (no v2 because broken atm)
60    comp_bench "$rev1" "$rev2" "-debug -rad oldrad -parallel $para -veget none -compilephysiq lmd"  # debug
61  done
62
63  # 1D
64  dim="79"
65  file_to_check="LMDZ/modipsl/modeles/LMDZ/BENCH$dim/restartphy.nc"
66  comp_bench "$rev1" "$rev2" "-rad oldrad -parallel none -veget none -compilephysiq lmd -d $dim"
67
68  # Iso
69  dim="48x36x39"
70  file_to_check="LMDZ/modipsl/modeles/LMDZ/BENCH$dim/restart.nc"
71  for para in "none" "mpi_omp"; do
72    comp_bench "$rev1" "$rev2" "-rad oldrad -parallel $para -veget none -compilephysiq lmdiso -d $dim"
73  done
74}
75
76#comp_bench 4938 4946 "-rad oldrad -parallel mpi_omp -veget none -compilephysiq lmd"
77#comp_bench 4938 4946 "-rad ecrad -parallel mpi_omp -veget none -compilephysiq lmd"
78#comp_bench 4938 4946 "-rad ecrad -parallel none -veget none -compilephysiq lmd"
79#comp_bench 4950 4946 "-rad oldrad -parallel none -veget none -compilephysiq lmd"
80
81comp_full 5017 5155
82
83
84
85
86
87
Note: See TracBrowser for help on using the repository browser.