2008-01-31 23:43:37 +00:00
|
|
|
<?php
|
2008-08-05 22:43:14 +00:00
|
|
|
// This file is part of BOINC.
|
|
|
|
// http://boinc.berkeley.edu
|
|
|
|
// Copyright (C) 2008 University of California
|
|
|
|
//
|
|
|
|
// BOINC is free software; you can redistribute it and/or modify it
|
|
|
|
// under the terms of the GNU Lesser General Public License
|
|
|
|
// as published by the Free Software Foundation,
|
|
|
|
// either version 3 of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// BOINC is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
// See the GNU Lesser General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
|
|
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
|
2008-01-31 23:43:37 +00:00
|
|
|
|
2008-06-20 21:33:02 +00:00
|
|
|
// actions:
|
2008-06-22 19:14:53 +00:00
|
|
|
// (none)
|
2008-06-20 21:33:02 +00:00
|
|
|
// form to choose select and xset; OK goes to:
|
|
|
|
// snap_form
|
|
|
|
// if have a snapshot, show its start/end times
|
|
|
|
// show form to get new snapshot
|
|
|
|
// snap_action
|
|
|
|
// make new snapshot
|
|
|
|
// compare(filter, breakdown)
|
|
|
|
// show comparison.
|
|
|
|
// show form to set or change filter or breakdown.
|
2008-06-19 20:56:36 +00:00
|
|
|
|
2008-11-01 03:07:44 +00:00
|
|
|
require_once("../inc/bolt_util_ops.inc");
|
2008-06-22 19:14:53 +00:00
|
|
|
require_once("../inc/bolt_db.inc");
|
2008-08-15 22:07:24 +00:00
|
|
|
require_once("../inc/bolt.inc");
|
2008-06-24 22:20:40 +00:00
|
|
|
require_once("../inc/bolt_cat.inc");
|
2008-10-30 22:58:33 +00:00
|
|
|
require_once("../inc/bolt_snap.inc");
|
2009-09-15 18:14:37 +00:00
|
|
|
require_once("../inc/util_ops.inc");
|
2008-06-22 19:14:53 +00:00
|
|
|
|
2008-11-01 03:07:44 +00:00
|
|
|
$filter = null;
|
|
|
|
$filter_cat = null;
|
|
|
|
$breakdown = null;
|
|
|
|
$breakdown_cat = null;
|
|
|
|
|
2008-06-24 22:20:40 +00:00
|
|
|
function compare_case(
|
2008-06-26 03:50:03 +00:00
|
|
|
$title, $select_unit, $snap, $filter, $filter_cat, $breakdown, $breakdown_cat
|
2008-06-24 22:20:40 +00:00
|
|
|
) {
|
2008-06-19 03:44:27 +00:00
|
|
|
|
2008-06-22 19:14:53 +00:00
|
|
|
// for each select alternative, build an array of xset scores
|
|
|
|
//
|
|
|
|
$a = array();
|
2008-06-23 19:51:07 +00:00
|
|
|
foreach ($snap->recs as $uid=>$x) {
|
2008-06-24 22:20:40 +00:00
|
|
|
if ($filter && $filter->categorize($x->user) != $filter_cat) {
|
|
|
|
//echo "<br>$uid rejected by filter ";
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if ($breakdown && $breakdown->categorize($x->user) != $breakdown_cat) {
|
|
|
|
//echo "<br>$uid rejected by breakdown ";
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$z = $x->sf->selected_unit;
|
|
|
|
$u = $x->sf->selected_unit;
|
|
|
|
$a[$u][] = $x->xr->score;
|
2008-06-22 19:14:53 +00:00
|
|
|
}
|
|
|
|
|
2008-06-26 03:50:03 +00:00
|
|
|
if ($title) {
|
|
|
|
echo "
|
|
|
|
<tr class=bolt_head2><td colspan=2><b>$title</b></td></tr>
|
|
|
|
";
|
|
|
|
}
|
2008-06-24 22:20:40 +00:00
|
|
|
foreach ($select_unit->units as $child) {
|
|
|
|
if (array_key_exists($child->name, $a)) {
|
|
|
|
$scores = $a[$child->name];
|
|
|
|
$n = count($scores);
|
|
|
|
if ($n < 2) {
|
2008-06-29 20:57:21 +00:00
|
|
|
$x = compare_bar_insuff($child->name, 600);
|
2008-06-24 22:20:40 +00:00
|
|
|
} else {
|
|
|
|
conf_int_90($scores, $lo, $hi);
|
2008-06-26 03:50:03 +00:00
|
|
|
//$x = "($lo, $hi) ($n results)";
|
2008-06-29 20:57:21 +00:00
|
|
|
$x = compare_bar($child->name, $n, 600, $lo, $hi);
|
2008-06-24 22:20:40 +00:00
|
|
|
}
|
|
|
|
} else {
|
2008-06-29 20:57:21 +00:00
|
|
|
$x = compare_bar_insuff($child->name, 600);
|
2008-06-24 22:20:40 +00:00
|
|
|
}
|
2008-06-26 03:50:03 +00:00
|
|
|
echo $x;
|
2008-06-22 19:14:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-06-24 22:20:40 +00:00
|
|
|
function compare_aux($select_name, $xset_name, $snap) {
|
2008-11-01 03:07:44 +00:00
|
|
|
global $top_unit, $course_id, $filter, $filter_cat;
|
|
|
|
global $breakdown, $breakdown_cat;
|
2008-06-24 22:20:40 +00:00
|
|
|
|
2008-11-01 03:07:44 +00:00
|
|
|
get_filters_from_form();
|
2008-06-24 22:20:40 +00:00
|
|
|
|
|
|
|
$select_unit = lookup_unit($top_unit, $select_name);
|
|
|
|
if (!$select_unit) error_page("no select unit");
|
|
|
|
|
2008-11-01 03:07:44 +00:00
|
|
|
admin_page_head("Unit comparison");
|
2008-06-24 22:20:40 +00:00
|
|
|
echo "
|
2008-10-24 22:28:34 +00:00
|
|
|
<link rel=\"stylesheet\" type=\"text/css\" href=\"".URL_BASE."bolt_admin.css\">
|
2008-06-26 03:50:03 +00:00
|
|
|
The following compares the alternatives of
|
|
|
|
<b>$select_name</b> with respect to <b>$xset_name</b>.
|
|
|
|
<p>
|
2008-06-24 22:20:40 +00:00
|
|
|
";
|
|
|
|
|
2008-06-26 03:50:03 +00:00
|
|
|
echo "<table class=\"bolt_box\">";
|
|
|
|
if ($breakdown) echo "<tr class=bolt_head1><td colspan=2>Total</td></tr>";
|
|
|
|
|
|
|
|
compare_case(null, $select_unit, $snap, $filter, $filter_cat, null, null);
|
2008-06-24 22:20:40 +00:00
|
|
|
if ($breakdown) {
|
2008-11-01 03:07:44 +00:00
|
|
|
echo "<tr class=bolt_head1><td colspan=2>Breakdown by ".$breakdown->name()."</td></tr>";
|
2008-06-24 22:20:40 +00:00
|
|
|
foreach ($breakdown->categories() as $c) {
|
2008-06-26 03:50:03 +00:00
|
|
|
compare_case($c, $select_unit, $snap, $filter, $filter_cat, $breakdown, $c);
|
|
|
|
echo "<p>";
|
2008-06-24 22:20:40 +00:00
|
|
|
}
|
|
|
|
}
|
2008-06-26 03:50:03 +00:00
|
|
|
echo "</table>";
|
2008-06-24 22:20:40 +00:00
|
|
|
|
|
|
|
echo "
|
|
|
|
<form action=bolt_compare.php>
|
|
|
|
<input type=hidden name=action value=compare>
|
|
|
|
<input type=hidden name=course_id value=$course_id>
|
|
|
|
<input type=hidden name=select_name value=\"$select_name\">
|
|
|
|
<input type=hidden name=xset_name value=\"$xset_name\">
|
2008-06-26 03:50:03 +00:00
|
|
|
<table width=600><tr><td>
|
2008-06-24 22:20:40 +00:00
|
|
|
";
|
2008-11-01 03:07:44 +00:00
|
|
|
filter_form($filter?$filter->name():"", $filter_cat);
|
2008-06-24 22:20:40 +00:00
|
|
|
echo "</td><td>";
|
2008-11-01 03:07:44 +00:00
|
|
|
breakdown_form($breakdown?$breakdown->name():"");
|
2008-06-24 22:20:40 +00:00
|
|
|
echo "
|
|
|
|
</td></tr></table>
|
|
|
|
<p>
|
2014-10-02 19:15:54 +00:00
|
|
|
<input class=\"btn btn-default\" type=submit value=OK>
|
2008-06-24 22:20:40 +00:00
|
|
|
</form>
|
|
|
|
";
|
2008-11-01 03:07:44 +00:00
|
|
|
admin_page_tail();
|
2008-06-24 22:20:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function show_compare() {
|
|
|
|
global $course_id;
|
|
|
|
$select_name = get_str('select_name');
|
|
|
|
$xset_name = get_str('xset_name');
|
|
|
|
$s = read_compare_snapshot($course_id, $select_name, $xset_name);
|
|
|
|
compare_aux($select_name, $xset_name, $s);
|
2008-06-19 03:44:27 +00:00
|
|
|
}
|
|
|
|
|
2008-06-22 19:14:53 +00:00
|
|
|
function show_snap_form($top_unit) {
|
|
|
|
global $course_id;
|
|
|
|
$select_name = get_str('select_name');
|
|
|
|
$xset_name = get_str('xset_name');
|
2008-11-01 03:07:44 +00:00
|
|
|
admin_page_head("Data snapshot");
|
2008-06-22 19:14:53 +00:00
|
|
|
$s = read_compare_snapshot($course_id, $select_name, $xset_name);
|
2008-06-23 19:51:07 +00:00
|
|
|
|
2008-06-22 19:14:53 +00:00
|
|
|
if ($s) {
|
2008-06-23 19:51:07 +00:00
|
|
|
$end = date_str($s->time);
|
2008-06-22 19:14:53 +00:00
|
|
|
echo "
|
2008-06-23 19:51:07 +00:00
|
|
|
A data snapshot exists for the $s->dur days prior to $end.
|
2008-06-22 19:14:53 +00:00
|
|
|
";
|
2008-06-24 22:20:40 +00:00
|
|
|
show_button(
|
|
|
|
"bolt_compare.php?action=compare&course_id=$course_id&select_name=$select_name&xset_name=$xset_name",
|
|
|
|
"Use this snapshot",
|
2008-06-22 19:14:53 +00:00
|
|
|
"Use this snapshot"
|
|
|
|
);
|
2008-06-23 19:51:07 +00:00
|
|
|
} else {
|
|
|
|
echo "There is currently no snapshot.";
|
2008-06-22 19:14:53 +00:00
|
|
|
}
|
|
|
|
echo "
|
|
|
|
<form action=bolt_compare.php>
|
2008-06-23 19:51:07 +00:00
|
|
|
<input type=hidden name=action value=snap_action>
|
|
|
|
<input type=hidden name=course_id value=$course_id>
|
|
|
|
<input type=hidden name=select_name value=\"$select_name\">
|
|
|
|
<input type=hidden name=xset_name value=\"$xset_name\">
|
2008-06-22 19:14:53 +00:00
|
|
|
Create a new snapshot using data from the last
|
2008-08-15 22:07:24 +00:00
|
|
|
<input name=dur value=7> days.
|
2014-10-02 19:15:54 +00:00
|
|
|
<input class=\"btn btn-default\" type=submit value=OK>
|
2008-06-22 19:14:53 +00:00
|
|
|
</form>
|
|
|
|
";
|
2008-11-01 03:07:44 +00:00
|
|
|
admin_page_tail();
|
2008-06-22 19:14:53 +00:00
|
|
|
}
|
|
|
|
|
2008-06-23 19:51:07 +00:00
|
|
|
function snap_action() {
|
|
|
|
global $course_id;
|
|
|
|
$select_name = get_str('select_name');
|
|
|
|
$xset_name = get_str('xset_name');
|
2008-06-22 19:14:53 +00:00
|
|
|
$dur = get_int('dur');
|
2008-06-23 19:51:07 +00:00
|
|
|
$s = write_compare_snapshot($course_id, $select_name, $xset_name, $dur);
|
2008-06-24 22:20:40 +00:00
|
|
|
compare_aux($select_name, $xset_name, $s);
|
2008-06-22 19:14:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function show_choice($top_unit) {
|
|
|
|
global $course_id;
|
2008-11-01 03:07:44 +00:00
|
|
|
admin_page_head("Unit comparison");
|
2008-06-22 19:14:53 +00:00
|
|
|
echo "
|
|
|
|
<form action=bolt_compare.php>
|
|
|
|
<input type=hidden name=course_id value=$course_id>
|
|
|
|
This tool lets you compare alternative lessons.
|
|
|
|
These lessons must be included in a 'select' unit,
|
|
|
|
typically with a random selection function.
|
|
|
|
This must be followed by an exercise set
|
|
|
|
that tests for the concepts in the lessons.
|
|
|
|
<p>
|
|
|
|
Please choose a select unit
|
|
|
|
";
|
|
|
|
choose_select($top_unit);
|
|
|
|
echo "
|
|
|
|
and an exercise set
|
|
|
|
";
|
|
|
|
choose_xset($top_unit);
|
|
|
|
echo "
|
|
|
|
<input type=hidden name=action value=snap_form>
|
|
|
|
<p>
|
2014-10-02 19:15:54 +00:00
|
|
|
<input class=\"btn btn-default\" type=submit value=OK>
|
2008-06-22 19:14:53 +00:00
|
|
|
";
|
2008-11-01 03:07:44 +00:00
|
|
|
admin_page_tail();
|
2008-06-22 19:14:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
$course_id = get_int('course_id');
|
|
|
|
$course = BoltCourse::lookup_id($course_id);
|
2008-08-14 15:46:30 +00:00
|
|
|
$top_unit = require_once($course->doc_file());
|
2008-06-22 19:14:53 +00:00
|
|
|
|
|
|
|
$action = get_str('action', true);
|
|
|
|
switch ($action) {
|
|
|
|
case "": show_choice($top_unit); break;
|
|
|
|
case "snap_form": show_snap_form($top_unit); break;
|
|
|
|
case "snap_action": snap_action(); break;
|
|
|
|
case "compare": show_compare(); break;
|
|
|
|
default: error_page("Unknown action $action");
|
|
|
|
}
|
2008-06-18 16:43:05 +00:00
|
|
|
|
2008-01-31 23:43:37 +00:00
|
|
|
?>
|