[3684] | 1 | #!/bin/bash |
---|
| 2 | #################################################################### |
---|
| 3 | # Frederic Hourdin. 2015/09/07 |
---|
| 4 | # Script de calcl de moyennes saisonnieres sur une grille reduite |
---|
| 5 | # en utilisant cdo. Preparation des tracers d'atlas. |
---|
| 6 | #################################################################### |
---|
| 7 | |
---|
| 8 | login=`whoami` |
---|
| 9 | ulimit -s unlimited |
---|
| 10 | GR=VLR |
---|
| 11 | |
---|
| 12 | hostname=`hostname` |
---|
| 13 | if [ ${hostname:0:5} = cicla ] ; then |
---|
| 14 | DODSDIR=/prodigfs/ipslfs/dods |
---|
| 15 | fi |
---|
| 16 | if [ ${hostname:0:5} = camel ] ; then |
---|
| 17 | DODSDIR=/prodigfs/ipslfs/dods |
---|
| 18 | fi |
---|
| 19 | if [ ${hostname:0:5} = irene ] ; then |
---|
| 20 | DODSDIR= |
---|
| 21 | fi |
---|
| 22 | if [ ${hostname:0:5} = jean- ] ; then |
---|
| 23 | DODSDIR= |
---|
| 24 | fi |
---|
| 25 | |
---|
| 26 | MAINDIR=$DODSDIR/$login/lmdz |
---|
| 27 | |
---|
| 28 | force_create=0 |
---|
| 29 | |
---|
| 30 | #################################################################### |
---|
| 31 | # Interactive options |
---|
| 32 | #################################################################### |
---|
| 33 | |
---|
| 34 | COMP_D="" |
---|
| 35 | listeseas="JJA,YEAR" |
---|
| 36 | listeseas="JJA,YEAR,DJF" |
---|
| 37 | listesim="" |
---|
| 38 | listeseas="YEAR,DJF,JJA,JJAS" |
---|
| 39 | |
---|
| 40 | |
---|
| 41 | while (($# > 0)) |
---|
| 42 | do |
---|
| 43 | case $1 in |
---|
| 44 | "-h") cat <<........fin |
---|
| 45 | Usage : cmor.sh [ -s sim1,sim2... -seas DJF,YEAR -f] |
---|
| 46 | -f forces execution even if the output file already exists |
---|
| 47 | ........fin |
---|
| 48 | shift ; exit ;; |
---|
| 49 | "-s") listesim=`echo $2 | sed -e 's/,/ /g'` ; shift ; shift ;; |
---|
| 50 | "-f") force_create=1 ; shift ;; |
---|
| 51 | "-comp") COMP_D=/prodigfs/ipslfs/dods/fabric/lmdz/MultiSimu/$2 ; shift ; shift ;; |
---|
| 52 | "-seas") listeseas=$2 ; shift ; shift ;; |
---|
| 53 | *) ./cmor.sh -h ; shift ; exit ;; |
---|
| 54 | esac |
---|
| 55 | done |
---|
| 56 | |
---|
| 57 | i=1 |
---|
| 58 | while [ "`ps -ux | grep season.sh | grep bin | wc -l`" != "2" ] ; do |
---|
| 59 | echo Mise en attente de season.sh deja en cours d execution $i |
---|
| 60 | sleep 2 ; (( i = $i + 1 )) |
---|
| 61 | if [ "$i" = "3600" ] ; then exit ; fi |
---|
| 62 | done |
---|
| 63 | |
---|
| 64 | |
---|
| 65 | #################################################################### |
---|
| 66 | # About the grid |
---|
| 67 | #################################################################### |
---|
| 68 | case $GR in |
---|
| 69 | VLR) remapf="/home/hourdin/CMIP5/Anal/Feb21_2012_tsol_OBS_AVE_ANM.nc" ;; |
---|
| 70 | *) echo "grille $GR non prevue" ; exit |
---|
| 71 | esac |
---|
| 72 | mkdir -p $MAINDIR/$GR/GR |
---|
| 73 | if [ ! -f $MAINDIR/$GR/GR/LAT ] ; then |
---|
| 74 | ncks -v LAT $remapf | grep 'LAT\[' | sed -e '/LAT_bn/d' | cut -d= -f2 | awk ' { print $1 } ' >| $MAINDIR/$GR/GR/LAT |
---|
| 75 | fi |
---|
| 76 | if [ "$remapf" != "" ] ; then remap="-remapcon,$remapf" ; fi |
---|
| 77 | |
---|
| 78 | |
---|
| 79 | ################################################################################ |
---|
| 80 | # Loop on seasons |
---|
| 81 | for SEAS in `echo $listeseas | sed -e 's/,/ /g'` ; do |
---|
| 82 | ################################################################################ |
---|
| 83 | echo $SEAS |
---|
| 84 | |
---|
| 85 | case $SEAS in |
---|
| 86 | YEAR) months="" ;; |
---|
| 87 | DJF) months="-selmon,1,2,12" ;; |
---|
| 88 | JJA) months="-selmon,6,7,8" ;; |
---|
| 89 | JJAS) months="-selmon,6,7,8,9" ;; |
---|
| 90 | *) echo "Cas $cas non prevu" ; exit |
---|
| 91 | esac |
---|
| 92 | |
---|
| 93 | |
---|
| 94 | ################################################################################ |
---|
| 95 | # Boucle sur les simulations |
---|
| 96 | ################################################################################ |
---|
| 97 | |
---|
| 98 | cd $MAINDIR/SE/CMOR ; \rm ferret* |
---|
| 99 | |
---|
| 100 | if [ "$COMP_D" != "" ] ; then |
---|
| 101 | listesim=`awk ' { print $1"_"$2 } ' $COMP_D/def.txt` |
---|
| 102 | fi |
---|
| 103 | echo listesim $listesim |
---|
| 104 | |
---|
| 105 | |
---|
| 106 | if [ "$listesim" = "" ] ; then listesim=`ls` ; fi |
---|
| 107 | |
---|
| 108 | for sim in $listesim ; do |
---|
| 109 | |
---|
| 110 | IN_DIR=$MAINDIR/SE/CMOR/$sim |
---|
| 111 | echo $IN_DIR |
---|
| 112 | |
---|
| 113 | if [ -d $IN_DIR ] ; then |
---|
| 114 | |
---|
| 115 | echo seasons.sh : mise a jour pour $sim |
---|
| 116 | if [ $force_create = 1 ] ; then |
---|
| 117 | rm -rf $MAINDIR/$GR/$SEAS/$sim |
---|
| 118 | fi |
---|
| 119 | OUT_DIR=$MAINDIR/$GR/$SEAS/$sim/NC ; mkdir -p $OUT_DIR |
---|
| 120 | |
---|
| 121 | cd $IN_DIR |
---|
| 122 | # boucle sur les variables (chacune correspondant à un .nc) |
---|
| 123 | for f in *nc ; do |
---|
| 124 | var=`basename $f .nc` |
---|
| 125 | # Pour le 3D, on prend directement les moyennes zonales |
---|
| 126 | |
---|
| 127 | # facteurs mutliplicatifs si besoin |
---|
| 128 | mulc=1. |
---|
| 129 | case $var in |
---|
| 130 | pr) mulc=86400. ;; |
---|
| 131 | autre) mulc=achanger ;; |
---|
| 132 | dernier) mulc=bou |
---|
| 133 | esac |
---|
| 134 | |
---|
| 135 | # Moyenne saisonniere (et zonale pour les champs 3D) |
---|
| 136 | if [ ! -f $OUT_DIR/$f -a -f $IN_DIR/$f ] ; then |
---|
| 137 | echo cdo mulc,$mulc -timavg $months $remap $IN_DIR/$f $OUT_DIR/$f |
---|
| 138 | cdo mulc,$mulc -timavg $months $remap $IN_DIR/$f $OUT_DIR/$f |
---|
| 139 | else |
---|
| 140 | echo $OUT_DIR/$f : deja cree |
---|
| 141 | fi |
---|
| 142 | |
---|
| 143 | done |
---|
| 144 | |
---|
| 145 | |
---|
| 146 | ######################################################################## |
---|
| 147 | # Regroupement des variables 2D dans all.nc |
---|
| 148 | ######################################################################## |
---|
| 149 | cd $OUT_DIR |
---|
| 150 | liste3d="" |
---|
| 151 | listef="" |
---|
| 152 | if [ "`ls -rt *nc | tail -1`" != "all.nc" ] ; then |
---|
| 153 | for f in `ls *nc | sed -e 's/all.nc//'` ; do |
---|
| 154 | var=`basename $f .nc` |
---|
| 155 | case $var in |
---|
| 156 | ua|va|wap|ta|hus|hur) liste3d="$liste3d $f" ;; |
---|
| 157 | *) listef="$listef $f" |
---|
| 158 | esac |
---|
| 159 | done |
---|
| 160 | \rm -f all.nc |
---|
| 161 | echo cdo merge $listef all.nc |
---|
| 162 | cdo merge $listef all.nc |
---|
| 163 | fi |
---|
| 164 | |
---|
| 165 | else |
---|
| 166 | echo ERREUR: repertoire $IN_DIR absent |
---|
| 167 | fi # Boucle sur $sim |
---|
| 168 | done |
---|
| 169 | |
---|
| 170 | done |
---|