]> matita.cs.unibo.it Git - helm.git/blob - helm/matita/scripts/public_html/bench.php
the web interface for the benchmarking system
[helm.git] / helm / matita / scripts / public_html / bench.php
1 <?php require("common.php"); 
2   
3 // syntax
4 //
5 // queries ::= query | query "###" queries
6 // query ::= name "@@@" sql
7 //
8   
9 $quey_all = urlencode("Whole content:@@@select * from bench;");
10 $query_fail = urlencode(
11   "Number of failures:@@@" .
12   "select mark, count(distinct test) as fail_no from bench where result = 'fail' group by mark order by mark;"
13   . "###" . 
14   "Tests failed:@@@" .
15   "select distinct mark, test, result from bench where result = 'fail';" 
16 );
17 $query_gc = urlencode(
18   "GC usage @@@" .
19   "select bench.mark, SEC_TO_TIME(SUM(TIME_TO_SEC(bench.time)) - SUM(TIME_TO_SEC(bench1.time))) as gc_hoverhead from bench, bench as bench1 where bench.mark = bench1.mark and bench.test = bench1.test and bench.options = 'gc-on' and bench1.options = 'gc-off' and bench.compilation = bench1.compilation group by mark;"
20   . "###" . 
21   "GC usage (opt)@@@" .
22   "select bench.mark, SEC_TO_TIME(SUM(TIME_TO_SEC(bench.time)) - SUM(TIME_TO_SEC(bench1.time))) as gc_hoverhead from bench, bench as bench1 where bench.mark = bench1.mark and bench.test = bench1.test and bench.options = 'gc-on' and bench1.options = 'gc-off' and bench.compilation = bench1.compilation and bench.compilation = 'opt' group by mark;"
23   . "###" . 
24   "GC usage (byte)@@@" .
25   "select bench.mark, SEC_TO_TIME(SUM(TIME_TO_SEC(bench.time)) - SUM(TIME_TO_SEC(bench1.time))) as gc_hoverhead from bench, bench as bench1 where bench.mark = bench1.mark and bench.test = bench1.test and bench.options = 'gc-on' and bench1.options = 'gc-off' and bench.compilation = bench1.compilation and bench.compilation = 'byte' group by mark;"
26   
27 );
28 $query_auto = urlencode(
29   "Auto (with GC):@@@select mark, SEC_TO_TIME(SUM(TIME_TO_SEC(bench.time))) as time from bench where test='tests/auto.ma' and options = 'gc-on' group by mark;"
30   . "###" . 
31   "Auto (without GC):@@@select mark, SEC_TO_TIME(SUM(TIME_TO_SEC(bench.time))) as time from bench where test='tests/auto.ma' and options = 'gc-off' group by mark;"
32   . "###" . 
33   "GC overhead@@@select bench.mark, SEC_TO_TIME(SUM(TIME_TO_SEC(bench.time)) - SUM(TIME_TO_SEC(bench1.time))) as gc_hoverhead from bench, bench as bench1 where bench.mark = bench1.mark and bench.test = bench1.test and bench.options = 'gc-on' and bench1.options = 'gc-off' and bench.compilation = bench1.compilation and bench.test = 'tests/auto.ma' group by mark;"
34 );
35
36 ?>
37
38 <html>
39   <head>
40   <link type="text/css" rel="stylesheet" href="style.css"/>
41   </head>
42   <body>
43     <h1>QUERY the benchmark system</h1>
44     <h2>Common Queries</h2>
45     <p>
46       <ul>
47       <li><a href="showquery.php?query=<? echo $query_fail; ?>">Broken tests</a></li>
48       <li><a href="showquery.php?query=<? echo $query_gc; ?>">Garbage collector killer</a></li>
49       <li><a href="showquery.php?query=<? echo $query_auto; ?>">Auto performances</a></li>
50       <li><a href="showquery.php?query=<? echo $quey_all; ?>">All table contents</a></li>
51       </ul>
52     </p>
53     <h2>Custom Query</h2>
54     <form action="composequery.php" method="get">
55     <table>
56   <tr><td>Marks:</td><td> 
57     <? array_to_combo("mark",query("select distinct mark from bench;")); ?></td></tr>
58   <tr><td>Compilations:</td><td> 
59     <? array_to_combo("compilation",query("select distinct compilation from bench;")); ?></td></tr>
60   <tr><td>Options:</td><td>  
61     <? array_to_combo("options",query("select distinct options from bench;")); ?></td></tr>
62   <tr><td>Tests:</td><td>    
63     <? array_to_combo("test",query("select distinct test from bench;")); ?></td></tr>
64   <tr><td>Test results:</td><td>
65     <? array_to_combo("result",query("select distinct result from bench;")); ?></td></tr>
66   <tr><td>Group By: </td><td>
67     <? array_to_combo("groupby",array(array("mark","options"))); ?></td></tr>
68     <tr><td><input type="submit" value="Submit"/></td></tr>
69     </table>
70     </form>
71   </body>
72 </html>