/[MITgcm]/mitgcm.org/front_content/make_summary
ViewVC logotype

Diff of /mitgcm.org/front_content/make_summary

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph | View Patch Patch

revision 1.72 by jmc, Thu Aug 16 02:42:56 2012 UTC revision 1.84 by jmc, Mon Aug 19 16:02:07 2019 UTC
# Line 5  Line 5 
5  #  The purpose of this script is to create HTML summaries of the  #  The purpose of this script is to create HTML summaries of the
6  #  directories produced by the "parse_emails" script.  #  directories produced by the "parse_emails" script.
7    
   
8  usage()  usage()
9  {  {
10      echo      echo
# Line 30  for ac_option ; do Line 29  for ac_option ; do
29    
30      # If the previous option needs an argument, assign it.      # If the previous option needs an argument, assign it.
31      if test -n "$ac_prev"; then      if test -n "$ac_prev"; then
32          eval "$ac_prev=\$ac_option"          eval "$ac_prev=\$ac_option"
33          ac_prev=          ac_prev=
34          continue          continue
35      fi      fi
36    
37      ac_optarg=`expr "x$ac_option" : 'x[^=]*=\(.*\)'`      ac_optarg=`expr "x$ac_option" : 'x[^=]*=\(.*\)'`
# Line 64  OUTDIR="/u/u0/httpd/html/testing/summary Line 63  OUTDIR="/u/u0/httpd/html/testing/summary
63  OUTFILE=$OUTDIR"/output_"$PERIOD".html"  OUTFILE=$OUTDIR"/output_"$PERIOD".html"
64  res_url="http://mitgcm.org/testing/"  res_url="http://mitgcm.org/testing/"
65    
66    #TMP=./mksum_$$
67    #- try to put temporary files in system-local /tmp dir
68    TMP=/tmp/mksum_$$
69    touch $TMP ; retVal=$?
70    if [ $retVal -eq 0 ] ; then
71      if test ! -r $TMP ; then TMP=./mksum_$$ ; fi
72    else
73      TMP=./mksum_$$
74    fi
75    rm -f $TMP
76    # echo "temp files: $TMP"
77    
78  #  Create the links in $OUTFILE :  #  Create the links in $OUTFILE :
79  echo "Creating the \"latest\" file for each machine: "  echo "Creating the \"latest\" file for each machine: "
80  the_date=`date`  the_date=`date`
# Line 85  EOF Line 96  EOF
96  color="#bbffdd"  color="#bbffdd"
97  ncolor="#bbddff"  ncolor="#bbddff"
98    
99  MACHINES="faulks meander aces- acesgrid baudelaire dickens danton beagle harbor"  MACHINES="aces- acesgrid baudelaire engaging svante glacier uv100 ollie stan1"
100  MACHINES="$MACHINES pleiades iblade rays solasrv sx8"  MACHINES="$MACHINES pleiades archer stomp octopus saramago"
 MACHINES="$MACHINES trane dodongo dokdo stomp bigred"  
101    
102  ( cd $INDIR ; ls -1 -t */summary.txt | sed 's/\/summary.txt//' ) > ./dir_all  ( cd $INDIR ; ls -1 -t */summary.txt | sed 's/\/summary.txt//' ) > $TMP.dir_all
103    
104  MALL=`cat ./dir_all | sed -e 's|_| |g' | awk '{print $2}' | sort | uniq`  MALL=`cat $TMP.dir_all | sed -e 's|_| |g' | awk '{print $2}' | sort | uniq`
105  for madd in $MALL ; do  for madd in $MALL ; do
106      present=0      present=0
107      for m in $MACHINES ; do      for m in $MACHINES ; do
# Line 107  done Line 117  done
117  for mname in $MACHINES ; do  for mname in $MACHINES ; do
118    
119      echo "  $mname"      echo "  $mname"
     sname=`echo $mname | sed 's/-$//'`  
120    
121      dir_list=`grep $mname ./dir_all`      dir_list=`grep $mname $TMP.dir_all`
122      echo -n "" > ./mlist      echo -n "" > $TMP.mlist
123    
124      for i in $dir_list ; do      for i in $dir_list ; do
125    
# Line 136  for mname in $MACHINES ; do Line 145  for mname in $MACHINES ; do
145              OPTFILE="not_explicitly_specified"              OPTFILE="not_explicitly_specified"
146          fi          fi
147    
148          ADJOINT=          # EXTRA = non-standard list of experiment
149          TANGLIN=          ADJOINT=0
150            TANGLIN=0
151            OPENAD=0
152          RESTART=0          RESTART=0
153            EXTRA=
154          FAST=0          FAST=0
155          DVLP=0          DVLP=0
156          MPI=0          MPI=0
157          MTH=0          MTH=0
158          UR4=0          UR4=0
159          if test -r $dir/summary.txt ; then          if test -r $dir/summary.txt ; then
160              comm=`grep 'ADJOINT=true' $dir/summary.txt 2>/dev/null`              ADJOINT=`grep -c -i '^ADJOINT' $dir/summary.txt`
161              eval $comm              if test "x$ADJOINT" = x1 ; then
162              comm=`grep 'TANGLIN=true' $dir/summary.txt 2>/dev/null`                OPENAD=`grep -c '^Adjoint .* OpenAD' $dir/summary.txt`
163              eval $comm              fi
164                TANGLIN=`grep -c -i '^TANGLIN' $dir/summary.txt`
165                if test "x$TANGLIN" = x1 ; then
166                  OPENAD=`grep -c '^TangLin .* OpenAD' $dir/summary.txt`
167                fi
168              RESTART=`grep -c 'test 2+2=4 summary' $dir/summary.txt`              RESTART=`grep -c 'test 2+2=4 summary' $dir/summary.txt`
169              FAST=`grep -c "^run: .*testreport.* '*-fast'*" $dir/summary.txt`              comm=`grep '^run: .*testreport.* ' $dir/summary.txt`
170                EXTRA=`echo "$comm" | grep " -*-tdir\>" | sed -e "s/^.* -*-tdir\>//" -e "s/ -.*$//"`
171                if test "x$EXTRA" = x ; then
172                    EXTRA=`echo "$comm" | grep " -*-t\>" | sed -e "s/^.*-*-t\>//" -e "s/ -.*$//"`
173                fi
174                if test "x$EXTRA" = x ; then EXTRA=0 ; else
175                    #echo -n "EXTRA=$EXTRA"
176                    nn0=`echo $EXTRA | sed "s/ *' *//g" | wc -w`
177                    nn1=`echo $EXTRA | sed "s/ *' *//g" | tr ' ' '\n' | grep -c "\<monod_"`
178                    nn2=`echo $EXTRA | sed "s/ *' *//g" | tr ' ' '\n' | grep -c "\<darwin_"`
179                    EXTRA=1
180                    if [ $nn1 -ge 2 ] ; then EXTRA=2 ; fi
181                    if [ $nn2 -ge 2 ] ; then EXTRA=3 ; fi
182                    #echo " : nn0=$nn0 ; nn1=$nn1 ; nn2=$nn2"
183                fi
184                FAST=`echo "$comm" | grep -c " -*-fast\>"`
185              if test "x$FAST" = x0 ; then              if test "x$FAST" = x0 ; then
186                FAST=`grep -c "^run: .*testreport.* '*-noieee'*" $dir/summary.txt`                  FAST=`echo "$comm" | grep -c " '*-noieee'*"`
187              fi              fi
188              DVLP=`grep -c "^run: .*testreport.* '*-devel'*" $dir/summary.txt`              DVLP=`echo "$comm" | grep -c " -*-devel\>"`
189              MPI=`grep -c "^run: .*testreport.* -mpi " $dir/summary.txt`              MPI=`echo "$comm" | grep -c " -*-mpi\>"`
190              if test "x$MPI" = x0 ; then              if test "x$MPI" = x0 ; then
191                 MPI=`grep -c "^run: .*testreport.* -MPI " $dir/summary.txt`                  MPI=`echo "$comm" | grep -c " -*-MPI\>"`
192              fi              fi
193              MTH=`grep -c "^run: .*testreport.* -mth " $dir/summary.txt`              MTH=`echo "$comm" | grep -c " -*-mth\>"`
194              UR4=`grep -c "^run: .*testreport.* -use_r4 " $dir/summary.txt`              UR4=`echo "$comm" | grep -c " -*-use_r4\>"`
195              if test "x$UR4" = x0 ; then              if test "x$UR4" = x0 ; then
196                 UR4=`grep -c "^run: .*testreport.* -ur4 " $dir/summary.txt`                  UR4=`echo "$comm" | grep -c " -*-ur4\>"`
197              fi              fi
198          fi          fi
199          if test "x$ADJOINT" = xtrue ; then          if test "x$ADJOINT" = x1 ; then
200              kind="adjoint" ; order='000'              kind="adjoint-taf" ; order=0
201          elif test "x$TANGLIN" = xtrue ; then            if test "x$OPENAD" = x1 ; then
202              kind="tanglin" ; order='001'              kind="adjoint-oad" ; order=2
203              fi
204            elif test "x$TANGLIN" = x1 ; then
205                kind="tanglin-taf" ; order=1
206              if test "x$OPENAD" = x1 ; then
207                kind="tanglin-oad" ; order=3
208              fi
209          elif test "x$RESTART" = x0 ; then          elif test "x$RESTART" = x0 ; then
210              kind="forward" ; order='002'              kind="forward" ; order=4
211          else          else
212              kind="restart" ; order='003'              kind="restart" ; order=5
213          fi          fi
214          if test "x$UR4" = x1 ; then          if test "x$UR4" = x1 ; then
215              OPTFILE="${OPTFILE}.use_r4"              OPTFILE="${OPTFILE}.use_r4"
216          fi          fi
217          if test "x$MPI" = x1 ; then          if test "x$MPI" = x1 ; then
218              yy=`echo $OPTFILE | grep -c '+mpi'`              yy=`echo $OPTFILE | grep -c '+mpi'`
219              if test $yy = 0 ; then OPTFILE="${OPTFILE}+mpi" ; fi              if test $yy = 0 ; then yy=`echo $OPTFILE | grep -c '+impi'` ; fi
220                if test $yy = 0 ; then OPTFILE="${OPTFILE}+mpi"
221                                  else order=`expr $order + 200` ; fi
222          fi          fi
223          if test "x$MTH" = x1 ; then          if test "x$MTH" = x1 ; then
224              yy=`echo $OPTFILE | grep -c '+mth$'`              yy=`echo $OPTFILE | grep -c '+mth$'`
# Line 191  for mname in $MACHINES ; do Line 230  for mname in $MACHINES ; do
230          if test "x$DVLP" = x1 ; then          if test "x$DVLP" = x1 ; then
231              OPTFILE="${OPTFILE}.dvlp"              OPTFILE="${OPTFILE}.dvlp"
232          fi          fi
233            order=`expr $order + 10 \* $EXTRA`
234            order=`printf '%3.3i' $order`
235    
236          t_pass="--"          t_pass="--"
237          t_tot="--"          t_tot="--"
# Line 210  for mname in $MACHINES ; do Line 251  for mname in $MACHINES ; do
251          DAY=`cat ./ms_tmp | awk '(length($1)==8 && substr($1,0,2)=="20")'`          DAY=`cat ./ms_tmp | awk '(length($1)==8 && substr($1,0,2)=="20")'`
252          rm -f ./ms_tmp          rm -f ./ms_tmp
253    
254          echo "$OPTFILE$order $DAY $OPTFILE $kind $i $t_pass:$t_tot" >> ./mlist          echo "$OPTFILE$order $DAY $OPTFILE $kind $i $t_pass:$t_tot" >> $TMP.mlist
255    
256      done      done
257    
258      # helpful for debugging      # helpful for debugging
259      # cat ./mlist      # cat $TMP.mlist
260    
261      #  Do we have any data?  If so, create the latest pointer.      #  Do we have any data?  If so, create the latest pointer.
262      num=`wc -l ./mlist | awk '{print $1}'`      num=`wc -l $TMP.mlist | awk '{print $1}'`
263      if test $num -gt 0 ; then      if test $num -gt 0 ; then
264    
265          # swap colors          # swap colors
# Line 226  for mname in $MACHINES ; do Line 267  for mname in $MACHINES ; do
267          color=$ncolor          color=$ncolor
268          ncolor=$ctmp          ncolor=$ctmp
269    
270          keys=`cat ./mlist | cut -d " " -f 1 | sort | uniq`          keys=`cat $TMP.mlist | cut -d " " -f 1 | sort | uniq`
271    
272          for key in $keys ; do          for key in $keys ; do
273              tline=`grep "^$key " ./mlist | head -1`              tline=`grep "^$key " $TMP.mlist | head -1`
274              ratio=`echo $tline | cut -d " " -f 6`              ratio=`echo $tline | cut -d " " -f 6`
275              ldir=`echo $tline | cut -d " " -f 5`              ldir=`echo $tline | cut -d " " -f 5`
276              kind=`echo $tline | cut -d " " -f 4`              kind=`echo $tline | cut -d " " -f 4`
277              optf=`echo $tline | cut -d " " -f 3`              optf=`echo $tline | cut -d " " -f 3`
278              DAY=`echo $tline | cut -d " " -f 2`              DAY=`echo $tline | cut -d " " -f 2`
279              URL="results/$PERIOD/$ldir"              URL="results/$PERIOD/$ldir"
280                #-- machine name to print:
281                sname=`echo $mname | sed 's/-$//'`
282                alt=`echo $key | sed "s/$optf//"`
283               #if   [ $alt -ge 30 ] ; then sname="${sname}.darwin"
284               #elif [ $alt -ge 20 ] ; then sname="${sname}.monod" ; fi
285              cat <<EOF >>$OUTFILE              cat <<EOF >>$OUTFILE
286  <tr bgcolor="$color">  <tr bgcolor="$color">
287    <td height="0"> $sname </td>    <td height="0"> $sname </td>
# Line 259  cat >> $OUTFILE << EOF Line 305  cat >> $OUTFILE << EOF
305      </table>      </table>
306    
307  <p>Examples of the scripts used for these testing runs can be obtained from: <a  <p>Examples of the scripts used for these testing runs can be obtained from: <a
308  href="http://mitgcm.org/viewvc/MITgcm/MITgcm/tools/example_scripts/">  href="http://mitgcm.org/viewvc/MITgcm/MITgcm_contrib/test_scripts/">
309  MITgcm/tools/example_scripts</a>.</p>  MITgcm_contrib/test_scripts</a>.</p>
   
310    
311    </body>    </body>
312  </html>  </html>
313    
314  EOF  EOF
315    
316  rm -f ./dir_all ./mlist  rm -f $TMP.dir_all $TMP.mlist
317    
318  #- put the file in place  #- put the file in place
319  chgrp gcmpack $OUTFILE  chgrp gcmpack $OUTFILE

Legend:
Removed from v.1.72  
changed lines
  Added in v.1.84

  ViewVC Help
Powered by ViewVC 1.1.22