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

Contents of /mitgcm.org/front_content/make_summary

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


Revision 1.78 - (show annotations) (download)
Thu Aug 22 21:32:54 2013 UTC (11 years, 11 months ago) by jmc
Branch: MAIN
Changes since 1.77: +23 -11 lines
put temp-files to local /tmp disk

1 #! /usr/bin/env bash
2
3 # $Header: /u/gcmpack/mitgcm.org/front_content/make_summary,v 1.77 2013/04/05 21:15:06 jmc Exp $
4 #
5 # The purpose of this script is to create HTML summaries of the
6 # directories produced by the "parse_emails" script.
7
8
9 usage()
10 {
11 echo
12 echo "Usage: $0 [OPTIONS]"
13 echo
14 echo "where possible OPTIONS are:"
15 echo " (-help|-h) print usage"
16 echo " (-date |-d )PERIOD run for PERIOD=\"YYYY_MM\""
17 echo " [def=\"$PERIOD\"]"
18 echo
19 exit 1
20 }
21
22 export LC_ALL="en_US.UTF-8"
23 CURR_PER=`date +%Y`"_"`date +%m`
24 # defaults
25 PERIOD=$CURR_PER
26
27 # Parse options
28 ac_prev=
29 for ac_option ; do
30
31 # If the previous option needs an argument, assign it.
32 if test -n "$ac_prev"; then
33 eval "$ac_prev=\$ac_option"
34 ac_prev=
35 continue
36 fi
37
38 ac_optarg=`expr "x$ac_option" : 'x[^=]*=\(.*\)'`
39
40 case $ac_option in
41
42 -help | --help | -h | --h)
43 usage ;;
44
45 -date | --date | -d | --d)
46 ac_prev=PERIOD ;;
47 --date=* | -date=*)
48 PERIOD=$ac_optarg ;;
49
50 *)
51 echo "Error: don't understand argument \"$ac_option\""
52 usage
53 ;;
54
55 esac
56
57 done
58
59 #INDIR="/net/orwell/export/export-9/mitgcm-testing/results/$PERIOD"
60 #OUTDIR="/home/jmc/mitgcm/test_web/summary"
61 INDIR="/u/u0/httpd/html/testing/results/$PERIOD"
62 OUTDIR="/u/u0/httpd/html/testing/summary"
63
64 OUTFILE=$OUTDIR"/output_"$PERIOD".html"
65 res_url="http://mitgcm.org/testing/"
66
67 #TMP=./mksum_$$
68 #- try to put temporary files in system-local /tmp dir
69 TMP=/tmp/mksum_$$
70 touch $TMP ; retVal=$?
71 if [ $retVal -eq 0 ] ; then
72 if test ! -r $TMP ; then TMP=./mksum_$$ ; fi
73 else
74 TMP=./mksum_$$
75 fi
76 rm -f $TMP
77 # echo "temp files: $TMP"
78
79 # Create the links in $OUTFILE :
80 echo "Creating the \"latest\" file for each machine: "
81 the_date=`date`
82
83 sed "s/_PERIOD/$PERIOD/" summary_head > $OUTFILE
84 cat <<EOF >>$OUTFILE
85 <table align="center" cellpadding="0" cellspacing="0" border="0" width="95%">
86 <tr bgcolor="#00cccc">
87 <td height="0"> <b>Nickname</b> </td>
88 <td> <b>OPTFILE Name</b> </td>
89 <td> <b>Type</b> </td>
90 <td> <b>Date</b> </td>
91 <td> <b>Summary</b> </td>
92 <td> <b>Ratio</b> </td>
93 </tr>
94
95 EOF
96
97 color="#bbffdd"
98 ncolor="#bbddff"
99
100 MACHINES="aces- acesgrid baudelaire dickens danton beagle"
101 MACHINES="$MACHINES pleiades iblade sx8 uv100 solasrv stomp weber"
102
103 ( cd $INDIR ; ls -1 -t */summary.txt | sed 's/\/summary.txt//' ) > $TMP.dir_all
104
105 MALL=`cat $TMP.dir_all | sed -e 's|_| |g' | awk '{print $2}' | sort | uniq`
106 for madd in $MALL ; do
107 present=0
108 for m in $MACHINES ; do
109 echo $madd | grep $m > /dev/null 2>&1
110 RETVAL=$?
111 test $RETVAL = 0 && present=1
112 continue
113 done
114 test $present = 0 && MACHINES="$MACHINES $madd"
115 done
116 #MACHINES="baudelaire"
117
118 for mname in $MACHINES ; do
119
120 echo " $mname"
121
122 dir_list=`grep $mname $TMP.dir_all`
123 echo -n "" > $TMP.mlist
124
125 for i in $dir_list ; do
126
127 dir=$INDIR"/"$i
128 OPTFILE=
129 if test -r $dir/summary.txt ; then
130 comm=`grep 'OPTFILE=' $dir/summary.txt`
131 eval $comm
132 OPTFILE=${OPTFILE##*/}
133 fi
134 if test "x$OPTFILE" = x -a -r "$dir/genmake_state" ; then
135 comm=`grep 'OPTFILE=' $dir/genmake_state 2>/dev/null`
136 eval $comm
137 OPTFILE=${OPTFILE##*/}
138 fi
139 if test "x$OPTFILE" = x ; then
140 comm=`grep '^# OPTFILE=' $dir/*/Makefile* 2>/dev/null | head -1`
141 comm=${comm##*#}
142 eval $comm
143 OPTFILE=${OPTFILE##*/}
144 fi
145 if test "x$OPTFILE" = x ; then
146 OPTFILE="not_explicitly_specified"
147 fi
148
149 # EXTRA = non-standard list of experiment
150 ADJOINT=0
151 TANGLIN=0
152 OPENAD=0
153 RESTART=0
154 EXTRA=
155 FAST=0
156 DVLP=0
157 MPI=0
158 MTH=0
159 UR4=0
160 if test -r $dir/summary.txt ; then
161 ADJOINT=`grep -c -i '^ADJOINT' $dir/summary.txt`
162 if test "x$ADJOINT" = x1 ; then
163 OPENAD=`grep -c '^Adjoint .* OpenAD' $dir/summary.txt`
164 fi
165 TANGLIN=`grep -c -i '^TANGLIN' $dir/summary.txt`
166 if test "x$TANGLIN" = x1 ; then
167 OPENAD=`grep -c '^TangLin .* OpenAD' $dir/summary.txt`
168 fi
169 RESTART=`grep -c 'test 2+2=4 summary' $dir/summary.txt`
170 comm=`grep '^run: .*testreport.* ' $dir/summary.txt`
171 EXTRA=`echo "$comm" | grep " -*-tdir\>" | sed -e "s/^.* -*-tdir\>//" -e "s/ -.*$//"`
172 if test "x$EXTRA" = x ; then
173 EXTRA=`echo "$comm" | grep " -*-t\>" | sed -e "s/^.*-*-t\>//" -e "s/ -.*$//"`
174 fi
175 if test "x$EXTRA" = x ; then EXTRA=0 ; else
176 #echo -n "EXTRA=$EXTRA"
177 nn0=`echo $EXTRA | sed "s/ *' *//g" | wc -w`
178 nn1=`echo $EXTRA | sed "s/ *' *//g" | tr ' ' '\n' | grep -c "\<monod_"`
179 nn2=`echo $EXTRA | sed "s/ *' *//g" | tr ' ' '\n' | grep -c "\<darwin_"`
180 EXTRA=1
181 if [ $nn1 -ge 2 ] ; then EXTRA=2 ; fi
182 if [ $nn2 -ge 2 ] ; then EXTRA=3 ; fi
183 #echo " : nn0=$nn0 ; nn1=$nn1 ; nn2=$nn2"
184 fi
185 FAST=`echo "$comm" | grep -c " -*-fast\>"`
186 if test "x$FAST" = x0 ; then
187 FAST=`echo "$comm" | grep -c " '*-noieee'*"`
188 fi
189 DVLP=`echo "$comm" | grep -c " -*-devel\>"`
190 MPI=`echo "$comm" | grep -c " -*-mpi\>"`
191 if test "x$MPI" = x0 ; then
192 MPI=`echo "$comm" | grep -c " -*-MPI\>"`
193 fi
194 MTH=`echo "$comm" | grep -c " -*-mth\>"`
195 UR4=`echo "$comm" | grep -c " -*-use_r4\>"`
196 if test "x$UR4" = x0 ; then
197 UR4=`echo "$comm" | grep -c " -*-ur4\>"`
198 fi
199 fi
200 if test "x$ADJOINT" = x1 ; then
201 kind="adjoint-taf" ; order=0
202 if test "x$OPENAD" = x1 ; then
203 kind="adjoint-oad" ; order=2
204 fi
205 elif test "x$TANGLIN" = x1 ; then
206 kind="tanglin-taf" ; order=1
207 if test "x$OPENAD" = x1 ; then
208 kind="tanglin-oad" ; order=3
209 fi
210 elif test "x$RESTART" = x0 ; then
211 kind="forward" ; order=4
212 else
213 kind="restart" ; order=5
214 fi
215 order=`expr $order + 10 \* $EXTRA`
216 order=`printf '%3.3i' $order`
217 if test "x$UR4" = x1 ; then
218 OPTFILE="${OPTFILE}.use_r4"
219 fi
220 if test "x$MPI" = x1 ; then
221 yy=`echo $OPTFILE | grep -c '+mpi'`
222 if test $yy = 0 ; then OPTFILE="${OPTFILE}+mpi" ; fi
223 fi
224 if test "x$MTH" = x1 ; then
225 yy=`echo $OPTFILE | grep -c '+mth$'`
226 if test $yy = 0 ; then OPTFILE="${OPTFILE}+mth" ; fi
227 fi
228 if test "x$FAST" = x1 ; then
229 OPTFILE="${OPTFILE}.fast"
230 fi
231 if test "x$DVLP" = x1 ; then
232 OPTFILE="${OPTFILE}.dvlp"
233 fi
234
235 t_pass="--"
236 t_tot="--"
237 if test -r $dir/summary.txt ; then
238 grep '^[YN] [YN] [YN] [YN]' $dir/summary.txt > ./all_tests 2>/dev/null
239 t_tot=`cat ./all_tests | wc -l | sed -e 's| ||g'`
240 t_pass=`grep '^Y Y Y Y' ./all_tests | grep 'pass ' | wc -l | sed -e 's| ||g'`
241 fi
242 rm -f ./all_tests
243 # echo "${dir##*/} : $t_pass out of $t_tot"
244
245 tokens=`echo $i | sed -e 's|_| |g'`
246 echo "" > ./ms_tmp
247 for tok in $tokens ; do
248 echo $tok >> ./ms_tmp
249 done
250 DAY=`cat ./ms_tmp | awk '(length($1)==8 && substr($1,0,2)=="20")'`
251 rm -f ./ms_tmp
252
253 echo "$OPTFILE$order $DAY $OPTFILE $kind $i $t_pass:$t_tot" >> $TMP.mlist
254
255 done
256
257 # helpful for debugging
258 # cat $TMP.mlist
259
260 # Do we have any data? If so, create the latest pointer.
261 num=`wc -l $TMP.mlist | awk '{print $1}'`
262 if test $num -gt 0 ; then
263
264 # swap colors
265 ctmp=$color
266 color=$ncolor
267 ncolor=$ctmp
268
269 keys=`cat $TMP.mlist | cut -d " " -f 1 | sort | uniq`
270
271 for key in $keys ; do
272 tline=`grep "^$key " $TMP.mlist | head -1`
273 ratio=`echo $tline | cut -d " " -f 6`
274 ldir=`echo $tline | cut -d " " -f 5`
275 kind=`echo $tline | cut -d " " -f 4`
276 optf=`echo $tline | cut -d " " -f 3`
277 DAY=`echo $tline | cut -d " " -f 2`
278 URL="results/$PERIOD/$ldir"
279 #-- machine name to print:
280 sname=`echo $mname | sed 's/-$//'`
281 alt=`echo $key | sed "s/$optf//"`
282 #if [ $alt -ge 30 ] ; then sname="${sname}.darwin"
283 #elif [ $alt -ge 20 ] ; then sname="${sname}.monod" ; fi
284 cat <<EOF >>$OUTFILE
285 <tr bgcolor="$color">
286 <td height="0"> $sname </td>
287 <td> $optf </td>
288 <td> $kind </td>
289 <td> <a href="$res_url$URL">$DAY</a> </td>
290 <td> <a href="$res_url$URL/summary.txt"> summary.txt </a> </td>
291 <td> $ratio </td>
292 </tr>
293 EOF
294 done
295 fi
296
297 done
298
299 cat >> $OUTFILE << EOF
300 <tr bgcolor="#00cccc">
301 <td height="0" colspan="6" align="center" >This table generated on: $the_date</td>
302 </tr>
303
304 </table>
305
306 <p>Examples of the scripts used for these testing runs can be obtained from: <a
307 href="http://mitgcm.org/viewvc/MITgcm/MITgcm/tools/example_scripts/">
308 MITgcm/tools/example_scripts</a>.</p>
309
310
311 </body>
312 </html>
313
314 EOF
315
316 rm -f $TMP.dir_all $TMP.mlist
317
318 #- put the file in place
319 chgrp gcmpack $OUTFILE
320 chmod 664 $OUTFILE
321 LATEST=$OUTDIR"/latest_"$PERIOD".html"
322 mv -f $OUTFILE $LATEST
323
324 if test "x$PERIOD" = "x$CURR_PER" ; then
325 cp $LATEST ./testing.xml
326 (
327 cd $OUTDIR
328 rm -f latest.html
329 ln -s $LATEST latest.html
330 )
331 fi

  ViewVC Help
Powered by ViewVC 1.1.22