/[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.2 by edhill, Sat Dec 6 21:10:18 2003 UTC revision 1.63 by jmc, Fri Mar 19 16:06:37 2010 UTC
# Line 19  usage() Line 19  usage()
19      exit 1      exit 1
20  }  }
21    
22    export LC_ALL="en_US.UTF-8"
23    CURR_PER=`date +%Y`"_"`date +%m`
24  # defaults  # defaults
25  PERIOD=`date +%Y`"_"`date +%m`  PERIOD=$CURR_PER
26    
27  #  Parse options  #  Parse options
28  ac_prev=  ac_prev=
29  for ac_option ; do  for ac_option ; do
30            
31      # If the previous option needs an argument, assign it.      # If the previous option needs an argument, assign it.
32      if test -n "$ac_prev"; then      if test -n "$ac_prev"; then
33          eval "$ac_prev=\$ac_option"          eval "$ac_prev=\$ac_option"
34          ac_prev=          ac_prev=
35          continue          continue
36      fi      fi
37        
38      ac_optarg=`expr "x$ac_option" : 'x[^=]*=\(.*\)'`      ac_optarg=`expr "x$ac_option" : 'x[^=]*=\(.*\)'`
39        
40      case $ac_option in      case $ac_option in
41                    
42          -help | --help | -h | --h)          -help | --help | -h | --h)
# Line 44  for ac_option ; do Line 46  for ac_option ; do
46              ac_prev=PERIOD ;;              ac_prev=PERIOD ;;
47          --date=* | -date=*)          --date=* | -date=*)
48              PERIOD=$ac_optarg ;;              PERIOD=$ac_optarg ;;
49            
50          *)          *)
51              echo "Error: don't understand argument \"$ac_option\""              echo "Error: don't understand argument \"$ac_option\""
52              usage              usage
53              ;;              ;;
54            
55       esac       esac
56        
57  done  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"  INDIR="/u/u0/httpd/html/testing/results/$PERIOD"
62  OUTDIR="/u/u0/httpd/html/testing/summary"  OUTDIR="/u/u0/httpd/html/testing/summary"
 OUTFILE=$OUTDIR"/summary_"$PERIOD".html"  
   
   
 #  Create the summary file for $PERIOD  
 echo -n "Creating the summary file for the period \"$PERIOD\" ...  "  
 cat > $OUTFILE << EOF  
 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"  
     "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
   
 <html xmlns="http://www.w3.org/1999/xhtml">  
   <head>  
     <title>MITgcm testing summary</title>  
     <meta name="author" content="Ed Hill" />  
     <base href="http://mitgcm.org/testing/summary/" />  
   </head>  
   <body>  
     <table cellpadding="0" cellspacing="0" border="0" width="100%">  
   
 EOF  
   
 # all_files=`find $INDIR -name summary.txt`  
 all_files=`( cd $INDIR ; find . -name summary.txt )`  
   
 for f in $all_files ; do  
   
     file=$INDIR"/"${f/.\//}  
     grep "^fresults" $file > /dev/null 2>&1  
     RETVAL=$?  
     if test "x$RETVAL" != x0 ; then  
         continue  
     fi  
   
     url=`echo $file | sed -e 's|/u/edhill/www|http://mitgcm.org/~edhill|'`  
     url=`echo $url | sed -e 's|summary.txt||'`  
     MACH=  
     fresults=  
     color="#eeeeee"  
   
     source $file  
     echo $fresults | grep FAIL > /dev/null 2>&1  
     if test "x$?" = x0 ; then  
         color="#ff99ff"  
     fi  
     echo $fresults | grep pass > /dev/null 2>&1  
     if test "x$?" = x0 ; then  
         color="#99ffff"  
     fi  
   
     gm_state=`echo $file | sed -e 's/summary.txt/genmake_state/g'`  
     if test -r $gm_state ; then  
         grep '^OPTFILE=' $gm_state > ./tmp_state  
         source ./tmp_state  
     else  
         optfile="unknown"  
     fi  
     optfile=`echo $OPTFILE | awk -F '/' '{print $NF}'`  
   
     echo "<tr bgcolor=\"$color\">" >> $OUTFILE  
     echo "<td height=\"0\">$MACH</td>" >> $OUTFILE  
     echo "<td><a href=\"$url\">$DATE</a></td>" >> $OUTFILE  
     for i in $fresults ; do  
         if test "x$i" = xN ; then  
             echo -n "<td bgcolor=\"#ff6666\">$i</td>" >> $OUTFILE  
         else  
             echo -n "<td>$i</td>" >> $OUTFILE  
         fi  
     done  
     echo "<td>$optfile</td>" >> $OUTFILE  
     echo "</tr>" >> $OUTFILE  
   
 done  
   
 cat >> $OUTFILE << EOF  
   
     </table>  
   </body>  
 </html>  
   
 EOF  
   
 chmod a+r $OUTFILE  
 echo "done"  
63    
64    OUTFILE=$OUTDIR"/output_"$PERIOD".html"
65    res_url="http://mitgcm.org/testing/"
66    
67  #  Create the "latest" links  #  Create the links in $OUTFILE :
68  echo "Creating the \"latest\" file for each machine: "  echo "Creating the \"latest\" file for each machine: "
69  LATEST=$OUTDIR"/latest_"$PERIOD".html"  the_date=`date`
 cat > $LATEST << EOF  
 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"  
     "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
   
 <html xmlns="http://www.w3.org/1999/xhtml">  
   <head>  
     <title>MITgcm testing summary</title>  
     <meta name="author" content="Ed Hill" />  
   
     <!-- <base href="http://mitgcm.org/testing/summary/" /> -->  
   
     <!-- Hinting for menu generation -->  
     <meta name="add_name_0" content="Source Code" />  
     <meta name="add_name_1" content="Testing" />  
     <meta name="add_name_2" content="" />  
     <meta name="add_title" content="Testing" />  
     <!-- Hinting for menu generation -->  
   
   </head>  
   <body>  
     <p>To enhance and maintain portability, the MITgcm model is tested  
       (compiled and run) in an automated fashion on a varirety of  
       different machines.  The following is a summary of the MITgcm  
       testing/verification suite for the time period: <b>$PERIOD</b>.</p>  
   
     <p>The machine naming scheme is:<br /></p>  
     <table align="center" cellpadding="0" border="0">  
       <tr bgcolor="#00cccc"> <td><b>Machine Type</b></td> <td><b>"Nickname"</b></td>  
         <td><b>Notes</b></td> </tr>  
   
       <tr bgcolor="#bbffdd"> <td>Intel P4</td> <td>"faulks"</td>  
         <td>Red Hat 7.3 (the "original" testing machine)</td> </tr>  
       <tr bgcolor="#bbddff"> <td>Intel P4</td> <td>"shelley"</td>  
         <td>Red Hat 9</td> </tr>  
   
       <tr bgcolor="#bbffdd"> <td> Intel P3/P4 Beowulf </td> <td>"myrinet"</td>  
         <td><a href="http://mitgcm.org/projects/MITGCM_CLUSTER/">MITgcm cluster  
         facility </a></td> </tr>  
       <tr bgcolor="#bbddff"> <td>Alpha cluster</td> <td>"halem"</td>  
         <td><a href="http://webserv.gsfc.nasa.gov/SCB/NCCS/systems/high-end-computing.html">  
         NASA NCCS Halem</a></td> </tr>  
   
       <tr bgcolor="#bbffdd"> <td> SGI Origin 2000 </td> <td>"hopper"</td>  
         <td><a href="http://www.nas.nasa.gov/User/Systemsdocs/O2K/o2k.html">  
         NAS SGI Origin 2000 </a></td> </tr>  
       <tr bgcolor="#bbddff"> <td> SGI Origin 3000 </td> <td>"lomax"</td>  
         <td><a href="http://www.nas.nasa.gov/User/Systemsdocs/O3K/o3k.html">  
         NAS SGI Origin 3000 </a></td> </tr>  
   
       <tr bgcolor="#bbffdd"> <td> SGI Altix </td> <td>"orion"</td>  
         <td><a href="http://sc.jpl.nasa.gov/">JPL Supercomputing and  
         Visualization Facility</a></td> </tr>  
       <tr bgcolor="#bbddff"> <td> IBM POWER3 SP </td> <td>"bf"</td>  
         <td><a href="http://www.scd.ucar.edu/computers/blackforest/">NCAR Blackforest  
         </a></td> </tr>  
   
       <tr bgcolor="#bbffdd"> <td> IBM POWER4 SP </td> <td>"bs"</td>  
         <td><a href="http://www.scd.ucar.edu/computers/bluesky/">NCAR Bluesky  
         </a></td> </tr>  
   
       <!--  
       <tr bgcolor="#bbddff"> <td>  </td> <td>""</td>  
         <td></td> </tr>  
       -->  
   
     </table>  
70    
71      <p><br />  sed "s/_PERIOD/$PERIOD/" summary_head > $OUTFILE
72        The complete output for the testing/verification runs can be found in  cat <<EOF >>$OUTFILE
       <a href="http://mitgcm.org/testing/summary/">the summary pages</a>.  
       The latest reports are:</p>  
73      <table align="center" cellpadding="0" cellspacing="0" border="0" width="95%">      <table align="center" cellpadding="0" cellspacing="0" border="0" width="95%">
74  <tr bgcolor="#00cccc">  <tr bgcolor="#00cccc">
75    <td height="0"> <b>"Nickname"</b> </td>    <td height="0"> <b>Nickname</b> </td>
76    <td> <b>OPTFILE Name</b> </td>    <td> <b>OPTFILE Name</b> </td>
77    <td> <b>Date (YYYYMMDD)</b> </td>    <td> <b>Type</b> </td>
78      <td> <b>Date</b> </td>
79      <td> <b>Summary</b> </td>
80      <td> <b>Ratio</b> </td>
81  </tr>  </tr>
82    
83  EOF  EOF
84    
85  color="#bbffdd"  color="#bbffdd"
86  res_url="http://mitgcm.org/testing/"  ncolor="#bbddff"
   
 MACHINES="faulks shelley myrinet halem hopper lomax orion bf bs"  
87    
88  ( cd $INDIR ; ls -1 ) > ./dir_all  MACHINES="faulks meander lagoon aces dickens danton beagle harbor"
89    MACHINES="$MACHINES columbia pleiades iblade rays solssrv solasrv sx8"
90    MACHINES="$MACHINES trane dodongo dokdo bigred"
91    
92    ( cd $INDIR ; ls -1 -t */summary.txt | sed 's/\/summary.txt//' ) > ./dir_all
93    
94    MALL=`cat ./dir_all | sed -e 's|_| |g' | awk '{print $2}' | sort | uniq`
95    for madd in $MALL ; do
96        present=0
97        for m in $MACHINES ; do
98            echo $madd | grep $m > /dev/null 2>&1
99            RETVAL=$?
100            test $RETVAL = 0  &&  present=1
101            continue
102        done
103        test $present = 0  &&  MACHINES="$MACHINES $madd"
104    done
105    #MACHINES="faulks"
106    
107  for mname in $MACHINES ; do  for mname in $MACHINES ; do
108    
109      echo "  $mname"      echo "  $mname"
     if test "x$color" = x#bbffdd ; then  
         color="#bbddff"  
     else  
         color="#bbffdd"  
     fi  
110    
111      dir_list=`grep $mname ./dir_all`      dir_list=`grep $mname ./dir_all`
112      echo -n "" > ./mlist      echo -n "" > ./mlist
# Line 252  for mname in $MACHINES ; do Line 121  for mname in $MACHINES ; do
121              OPTFILE=${OPTFILE##*/}              OPTFILE=${OPTFILE##*/}
122          fi          fi
123          if test "x$OPTFILE" = x -a -r "$dir/genmake_state" ; then          if test "x$OPTFILE" = x -a -r "$dir/genmake_state" ; then
124              comm=`grep 'OPTFILE=' $dir/genmake_state`              comm=`grep 'OPTFILE=' $dir/genmake_state 2>/dev/null`
125              eval $comm              eval $comm
126              OPTFILE=${OPTFILE##*/}              OPTFILE=${OPTFILE##*/}
127          fi          fi
128          if test "x$OPTFILE" = x ; then          if test "x$OPTFILE" = x ; then
129              comm=`grep '^# OPTFILE=' $dir/*/Makefile 2>/dev/null | head -1 | sed -e 's|^# ||'`              comm=`grep '^# OPTFILE=' $dir/*/Makefile* 2>/dev/null | head -1`
130                comm=${comm##*#}
131              eval $comm              eval $comm
132              OPTFILE=${OPTFILE##*/}              OPTFILE=${OPTFILE##*/}
133          fi          fi
134          if test "x$OPTFILE" = x ; then          if test "x$OPTFILE" = x ; then
135              OPTFILE="not_explicitly_specified"              OPTFILE="not_explicitly_specified"
136          fi          fi
137    
138            ADJOINT=
139            RESTART=0
140            NOI3E=0
141            MTH=0
142            UR4=0
143            if test -r $dir/summary.txt ; then
144                comm=`grep 'ADJOINT=true' $dir/summary.txt 2>/dev/null`
145                eval $comm
146                RESTART=`grep -c 'test 2+2=4 summary' $dir/summary.txt`
147                NOI3E=`grep -c "^run: .*testreport.* '*-noieee'*" $dir/summary.txt`
148                MTH=`grep -c "^run: .*testreport.* -mth " $dir/summary.txt`
149                UR4=`grep -c "^run: .*testreport.* -use_r4 " $dir/summary.txt`
150                if test "x$UR4" = x0 ; then
151                   UR4=`grep -c "^run: .*testreport.* -ur4 " $dir/summary.txt`
152                fi
153            fi
154            if test "x$RESTART" = x0 ; then
155                kind="forward"
156                test "x$ADJOINT" = xtrue  &&  kind="adjoint"
157            else
158                kind="restart"
159            fi
160            if test "x$UR4" = x1 ; then
161                OPTFILE="${OPTFILE}.use_r4"
162            fi
163            if test "x$MTH" = x1 ; then
164                yy=`echo $OPTFILE | grep -c '+mth$'`
165                if test $yy = 0 ; then OPTFILE="${OPTFILE}+mth" ; fi
166            fi
167            if test "x$NOI3E" = x1 ; then
168                OPTFILE="${OPTFILE}.noieee"
169            fi
170    
171            t_pass="--"
172            t_tot="--"
173            if test -r $dir/summary.txt ; then
174                grep '^[YN] [YN] [YN] [YN]' $dir/summary.txt > ./all_tests 2>/dev/null
175                t_tot=`cat ./all_tests | wc -l | sed -e 's| ||g'`
176                t_pass=`grep '^Y Y Y Y' ./all_tests | grep 'pass ' | wc -l | sed -e 's| ||g'`
177            fi
178            rm -f ./all_tests
179            # echo "${dir##*/} : $t_pass out of $t_tot"
180    
181          tokens=`echo $i | sed -e 's|_| |g'`          tokens=`echo $i | sed -e 's|_| |g'`
182          echo "" > ./ms_tmp          echo "" > ./ms_tmp
183          for tok in $tokens ; do          for tok in $tokens ; do
184              echo $tok >> ./ms_tmp              echo $tok >> ./ms_tmp
185          done          done
186          DAY=`cat ./ms_tmp | awk '(length($1)==8 && substr($1,0,3)=="200")'`          DAY=`cat ./ms_tmp | awk '(length($1)==8 && substr($1,0,2)=="20")'`
187          rm -f ./ms_tmp          rm -f ./ms_tmp
188          echo "$OPTFILE $DAY $i" >> ./mlist  
189            echo "$OPTFILE$kind $DAY $OPTFILE $kind $i $t_pass:$t_tot" >> ./mlist
190    
191      done      done
192    
# Line 281  for mname in $MACHINES ; do Line 196  for mname in $MACHINES ; do
196      #  Do we have any data?  If so, create the latest pointer.      #  Do we have any data?  If so, create the latest pointer.
197      num=`wc -l ./mlist | awk '{print $1}'`      num=`wc -l ./mlist | awk '{print $1}'`
198      if test $num -gt 0 ; then      if test $num -gt 0 ; then
         optfiles=`cat ./mlist | cut -d " " -f 1 | sort | uniq`  
199    
200          for optf in $optfiles ; do          # swap colors
201              ldir=`grep "^$optf " ./mlist | sort -r | head -1 | cut -d " " -f 3`          ctmp=$color
202            color=$ncolor
203            ncolor=$ctmp
204    
205            keys=`cat ./mlist | cut -d " " -f 1 | sort | uniq`
206    
207            for key in $keys ; do
208                tline=`grep "^$key " ./mlist | head -1`
209                ratio=`echo $tline | cut -d " " -f 6`
210                ldir=`echo $tline | cut -d " " -f 5`
211                kind=`echo $tline | cut -d " " -f 4`
212                optf=`echo $tline | cut -d " " -f 3`
213                DAY=`echo $tline | cut -d " " -f 2`
214              URL="results/$PERIOD/$ldir"              URL="results/$PERIOD/$ldir"
215              cat <<EOF >>$LATEST              cat <<EOF >>$OUTFILE
216  <tr bgcolor="$color">  <tr bgcolor="$color">
217    <td height="0"><a href="$res_url$URL"> $mname </a></td>    <td height="0"> $mname </td>
218    <td> $optf </td>    <td> $optf </td>
219    <td> $DAY </td>    <td> $kind </td>
220      <td> <a href="$res_url$URL">$DAY</a> </td>
221      <td> <a href="$res_url$URL/summary.txt"> summary.txt </a> </td>
222      <td> $ratio </td>
223  </tr>  </tr>
224  EOF  EOF
225          done          done
# Line 298  EOF Line 227  EOF
227    
228  done  done
229    
230  cat >> $LATEST << EOF  cat >> $OUTFILE << EOF
231    <tr bgcolor="#00cccc">
232      <td height="0" colspan="6" align="center" >This table generated on: $the_date</td>
233    </tr>
234    
235      </table>      </table>
236    
237    <p>Examples of the scripts used for these testing runs can be obtained from: <a
238    href="http://mitgcm.org/viewvc/MITgcm/MITgcm/tools/example_scripts/">
239    MITgcm/tools/example_scripts</a>.</p>
240    
241    
242    </body>    </body>
243  </html>  </html>
244    
# Line 308  EOF Line 246  EOF
246    
247  rm -f ./dir_all ./mlist  rm -f ./dir_all ./mlist
248    
249  CURR_PER=`date +%Y`"_"`date +%m`  #- put the file in place
250    chgrp gcmpack $OUTFILE
251    chmod 664 $OUTFILE
252    LATEST=$OUTDIR"/latest_"$PERIOD".html"
253    mv -f $OUTFILE $LATEST
254    
255  if test "x$PERIOD" = "x$CURR_PER" ; then  if test "x$PERIOD" = "x$CURR_PER" ; then
256      cp $LATEST ./testing.xml      cp $LATEST ./testing.xml
257      (      (

Legend:
Removed from v.1.2  
changed lines
  Added in v.1.63

  ViewVC Help
Powered by ViewVC 1.1.22