| 1 | #!/bin/bash |
|---|
| 2 | |
|---|
| 3 | \rm -f ModelParam.R |
|---|
| 4 | bad=0 |
|---|
| 5 | |
|---|
| 6 | if [ $# != 3 ] ; then |
|---|
| 7 | cat <<eod |
|---|
| 8 | Usage : param2R.sh LHCIZE NLHC parameter_file |
|---|
| 9 | eod |
|---|
| 10 | exit |
|---|
| 11 | fi |
|---|
| 12 | |
|---|
| 13 | LHCSIZE=$1 |
|---|
| 14 | NLHC=$2 |
|---|
| 15 | PARAM_FILE=$3 |
|---|
| 16 | |
|---|
| 17 | if [ ! -f $PARAM_FILE ] ; then echo fichier $PARAM_FILE inexistant ; exit ; fi |
|---|
| 18 | #if [ ! $NLHC -ge 3 ] ; then echo NLHC should be '>=' 3 ; exit ; fi |
|---|
| 19 | |
|---|
| 20 | (( NSCMS = LHCSIZE * NLHC )) |
|---|
| 21 | NPARA=`wc -l $PARAM_FILE |awk ' {print $1 }'` |
|---|
| 22 | |
|---|
| 23 | # A automatiser en regardant combien de LES* sont disponibles |
|---|
| 24 | # sur chaque cas. |
|---|
| 25 | |
|---|
| 26 | echo LHCSIZE=$LHCSIZE >> ModelParam.R |
|---|
| 27 | echo NLHC=$NLHC >> ModelParam.R |
|---|
| 28 | echo NSCMS=$NSCMS >> ModelParam.R |
|---|
| 29 | echo NPARA=$NPARA >> ModelParam.R |
|---|
| 30 | |
|---|
| 31 | names=( names lows highs defaults ) |
|---|
| 32 | |
|---|
| 33 | for col in 1 2 3 4 ; do |
|---|
| 34 | (( ii = $col -1 )) |
|---|
| 35 | liste='param.'${names[$ii]}='c(' |
|---|
| 36 | for val in `awk ' {print $'$col' } ' $PARAM_FILE` ; do |
|---|
| 37 | if [ $col == 1 ] ; then |
|---|
| 38 | liste=$liste'"'$val'",' |
|---|
| 39 | else |
|---|
| 40 | liste="$liste$val," |
|---|
| 41 | fi |
|---|
| 42 | done |
|---|
| 43 | echo $liste | sed -e 's/,$/)/' >> ModelParam.R |
|---|
| 44 | done |
|---|
| 45 | |
|---|
| 46 | |
|---|
| 47 | liste="which.logs<-c(" |
|---|
| 48 | ival=0 |
|---|
| 49 | ilog=0 |
|---|
| 50 | for val in `awk ' { print $5 } ' $PARAM_FILE` ; do |
|---|
| 51 | (( ival = $ival + 1 )) |
|---|
| 52 | if [ "$val" = "log" ] ; then |
|---|
| 53 | liste="$liste$ival," |
|---|
| 54 | ilog=1 |
|---|
| 55 | fi |
|---|
| 56 | done |
|---|
| 57 | if [ $ilog == 0 ]; then |
|---|
| 58 | echo $liste | sed -e 's/($/()/' >> ModelParam.R |
|---|
| 59 | else |
|---|
| 60 | echo $liste | sed -e 's/,$/)/' >> ModelParam.R |
|---|
| 61 | fi |
|---|
| 62 | |
|---|
| 63 | cat <<eod>> ModelParam.R |
|---|
| 64 | param.defaults <- param.defaults[1:NPARA] |
|---|
| 65 | param.highs <- param.highs[1:NPARA] |
|---|
| 66 | param.lows <- param.lows[1:NPARA] |
|---|
| 67 | param.names <- param.names[1:NPARA] |
|---|
| 68 | eod |
|---|
| 69 | |
|---|
| 70 | cat ModelParam.R |
|---|
| 71 | |
|---|
| 72 | echo '==================================================================' |
|---|
| 73 | echo "Generating $NSCMS samples" |
|---|
| 74 | echo '==================================================================' |
|---|
| 75 | Rscript htune_convertDesign.R |
|---|
| 76 | |
|---|
| 77 | #ls -lrt |
|---|
| 78 | |
|---|
| 79 | # On copie les infos de la wave 1 dans le repertoire WAVE1 (1ere vague de l'history matching) |
|---|
| 80 | |
|---|
| 81 | mkdir WAVE1 |
|---|
| 82 | # cf plus haut |
|---|
| 83 | mv ModelParam.R WAVE1/ |
|---|
| 84 | # Fichier ASCII simulation id - valeur des parametres |
|---|
| 85 | mv Par1D_Wave1.asc WAVE1/ |
|---|
| 86 | # Fichier R contenant les mêmes informations |
|---|
| 87 | mv Wave1.RData WAVE1/ |
|---|
| 88 | |
|---|