1 | #!/bin/bash |
---|
2 | set -u |
---|
3 | #set -xv |
---|
4 | |
---|
5 | resolution=${1:?"you must provide the resolution: 1 025 or 12"} |
---|
6 | mincore=${2:-1} # minimum number of core to be tested |
---|
7 | maxcore=${3:-0} # maximum number of core to be tested |
---|
8 | |
---|
9 | machine=$( hostname | sed -e "s/[0-9]*//g" ) |
---|
10 | case $machine in |
---|
11 | "beaufixlogin") ncore_node=40 ;; |
---|
12 | "curie") ncore_node=16 ;; |
---|
13 | "irene") ncore_node=48 ;; |
---|
14 | *) echo "you must add your machine \"$machine\" with its number of cores per node" ; exit 1 ;; |
---|
15 | esac |
---|
16 | |
---|
17 | [ $mincore -eq 1 ] && targetnb=$ncore_node || targetnb=$mincore |
---|
18 | # |
---|
19 | # build the list of experiences: |
---|
20 | # must be a multiple of ncore_node and as close as possible of the targeted number of core |
---|
21 | # |
---|
22 | n1=0 |
---|
23 | list="" |
---|
24 | |
---|
25 | # Prepare gnuplot data file |
---|
26 | dateref=$( date "+%Y%m%d-%Hh%Mm%Ss" ) |
---|
27 | echo "# nb_proc jpi jpj" > gnuplot_tbc_${resolution}_${dateref}.dat |
---|
28 | nbl=$( cat best_jpni_jpnj_eorca${resolution} | wc -l ) |
---|
29 | for ll in $( seq 1 $nbl ) |
---|
30 | do |
---|
31 | line=$( sed -n ${ll}p best_jpni_jpnj_eorca${resolution} ) # for each line |
---|
32 | nn=$( echo $line | sed -e "s/.*nb_cores \([0-9]*\).*/\1/" ) # get the number of core |
---|
33 | [ $maxcore -gt 1 -a $nn -gt $maxcore ] && break # if below $maxcore (if specified) |
---|
34 | if [ $(( $nn % $ncore_node )) -eq 0 ] # if it is a multiple of $ncore_node |
---|
35 | then |
---|
36 | if [ $nn -lt $targetnb ] |
---|
37 | then |
---|
38 | n1=$nn # store the number of core |
---|
39 | line1=$line # store the line |
---|
40 | else |
---|
41 | [ $(( $targetnb - $n1 )) -le $(( $nn -$targetnb )) ] && line=$line1 # keep the previous line |
---|
42 | echo $line |
---|
43 | nb=$( echo $line | sed -e "s/[^(]*( \([0-9]*\) x \([0-9]*\) .*/\1*\2/" ) # get jpni*jpnj |
---|
44 | list="${list} ${nb}" |
---|
45 | targetnb=$(( $targetnb * 2 )) |
---|
46 | subsize=$( echo $line | awk {'printf "%d %d", $11, $13'}) |
---|
47 | corenb=$( echo $line | awk {'printf "%d", $2'}) |
---|
48 | echo "$corenb $subsize" >> gnuplot_tbc_${resolution}.dat |
---|
49 | fi |
---|
50 | fi |
---|
51 | done |
---|
52 | echo $list |
---|
53 | |
---|
54 | for cores in $list |
---|
55 | do |
---|
56 | ./submit_bench $cores $ncore_node ${resolution} ${dateref} |
---|
57 | done |
---|
58 | |
---|