2013-04-25 02:15:06 +00:00
|
|
|
#! /usr/bin/env php
|
|
|
|
<?php
|
|
|
|
// This file is part of BOINC.
|
|
|
|
// http://boinc.berkeley.edu
|
|
|
|
// Copyright (C) 2013 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/>.
|
|
|
|
|
2014-02-20 17:43:46 +00:00
|
|
|
// size_census [--all_apps]
|
2013-04-25 02:15:06 +00:00
|
|
|
// for each multi-size app,
|
|
|
|
// find the N quantiles of its effective speed,
|
|
|
|
// and write them to a file.
|
|
|
|
// See http://boinc.berkeley.edu/trac/wiki/JobSizeMatching
|
2014-02-20 17:43:46 +00:00
|
|
|
//
|
|
|
|
// --all_apps: compute quantiles for all apps;
|
|
|
|
// use this during setup and testing.
|
2013-04-25 02:15:06 +00:00
|
|
|
|
|
|
|
error_reporting(E_ALL);
|
|
|
|
ini_set('display_errors', true);
|
|
|
|
ini_set('display_startup_errors', true);
|
|
|
|
|
2015-04-28 07:32:01 +00:00
|
|
|
require_once("../inc/util.inc");
|
2013-04-25 02:15:06 +00:00
|
|
|
|
|
|
|
function do_app($app) {
|
|
|
|
// enumerate the host_app_versions for this app,
|
|
|
|
// joined to the host
|
|
|
|
|
|
|
|
$db = BoincDb::get();
|
2014-03-07 05:23:02 +00:00
|
|
|
$query = "select et_avg, host.on_frac, host.active_frac, host.gpu_active_frac, app_version.plan_class " .
|
2014-02-20 17:43:46 +00:00
|
|
|
" from DBNAME.host_app_version, DBNAME.host, DBNAME.app_version " .
|
2013-04-25 02:15:06 +00:00
|
|
|
" where host_app_version.app_version_id = app_version.id " .
|
2014-02-20 17:43:46 +00:00
|
|
|
" and app_version.appid = $app->id " .
|
2015-04-28 07:32:01 +00:00
|
|
|
" and et_n > 0 and et_avg > 0 " .
|
2013-04-25 02:15:06 +00:00
|
|
|
" and host.id = host_app_version.host_id";
|
|
|
|
$result = $db->do_query($query);
|
|
|
|
$a = array();
|
2014-09-04 19:00:09 +00:00
|
|
|
while ($x = _mysql_fetch_object($result)) {
|
2014-03-07 05:23:02 +00:00
|
|
|
if (is_gpu($x->plan_class)) {
|
|
|
|
$av = $x->on_frac;
|
|
|
|
if ($x->gpu_active_frac) {
|
|
|
|
$av *= $x->gpu_active_frac;
|
|
|
|
} else {
|
|
|
|
$av *= $x->active_frac;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$av = $x->on_frac * $x->active_frac;
|
|
|
|
}
|
|
|
|
$a[] = (1/$x->et_avg) * $av;
|
2013-04-25 02:15:06 +00:00
|
|
|
}
|
2014-09-04 19:00:09 +00:00
|
|
|
_mysql_free_result($result);
|
2013-04-25 02:15:06 +00:00
|
|
|
sort($a);
|
|
|
|
$n = count($a);
|
|
|
|
$f = fopen("../../size_census_".$app->name, "w");
|
|
|
|
for ($i=1; $i<$app->n_size_classes; $i++) {
|
2013-04-25 07:27:35 +00:00
|
|
|
$k = (int)(($i*$n)/$app->n_size_classes);
|
|
|
|
fprintf($f, "%e\n", $a[$k]);
|
2013-04-25 02:15:06 +00:00
|
|
|
}
|
|
|
|
fclose($f);
|
|
|
|
}
|
|
|
|
|
2015-04-28 07:32:01 +00:00
|
|
|
echo "Starting: ", time_str(time()), "\n";
|
|
|
|
|
2014-02-20 17:43:46 +00:00
|
|
|
if ($argc == 2 && $argv[1]=="--all_apps") {
|
|
|
|
$apps = BoincApp::enum("deprecated=0");
|
|
|
|
} else {
|
|
|
|
$apps = BoincApp::enum("deprecated=0 and n_size_classes>1");
|
|
|
|
}
|
|
|
|
|
2013-04-25 02:15:06 +00:00
|
|
|
foreach ($apps as $app) {
|
|
|
|
do_app($app);
|
|
|
|
}
|
2015-04-28 07:32:01 +00:00
|
|
|
echo "Finished: ", time_str(time()), "\n";
|
2013-04-25 02:15:06 +00:00
|
|
|
|
|
|
|
?>
|