2009-08-11 15:17:37 +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/>.
|
|
|
|
|
2010-03-29 22:28:20 +00:00
|
|
|
#include <vector>
|
|
|
|
|
2009-08-11 15:17:37 +00:00
|
|
|
#include "boinc_db.h"
|
|
|
|
|
|
|
|
// Historical note: named after Jeff Cobb
|
|
|
|
//
|
|
|
|
#define COBBLESTONE_FACTOR 100.0
|
|
|
|
|
2010-03-29 22:28:20 +00:00
|
|
|
#define ERROR_RATE_INIT 0.1
|
|
|
|
// the initial error rate of a host or app version
|
|
|
|
|
2010-04-08 23:14:47 +00:00
|
|
|
#define MIN_HOST_SAMPLES 10
|
|
|
|
// use host scaling only if have this many samples for host
|
|
|
|
#define MIN_VERSION_SAMPLES 100
|
|
|
|
// update a version's scale only if it has this many samples
|
|
|
|
#define COBBLESTONE_SCALE 200/86400e9
|
|
|
|
// multiply normalized PFC by this to get Cobblestones
|
|
|
|
|
2009-08-11 15:17:37 +00:00
|
|
|
extern void compute_credit_rating(HOST&);
|
|
|
|
extern double credit_multiplier(int, time_t);
|
|
|
|
extern double fpops_to_credit(double fpops, double intops);
|
|
|
|
// credit that should be granted for a given number of
|
|
|
|
// floating-point and integer ops
|
2009-08-12 16:26:43 +00:00
|
|
|
extern int update_credit_per_cpu_sec(
|
|
|
|
double credit, double cpu_time, double& credit_per_cpu_sec
|
|
|
|
);
|
|
|
|
extern int grant_credit(
|
2009-08-13 03:35:26 +00:00
|
|
|
DB_HOST& host, double start_time, double cpu_time, double credit
|
2009-08-12 16:26:43 +00:00
|
|
|
);
|
2010-03-29 22:28:20 +00:00
|
|
|
|
|
|
|
extern int update_av_scales(struct SCHED_SHMEM*);
|
|
|
|
extern int assign_credit_set(
|
2010-04-05 18:59:16 +00:00
|
|
|
WORKUNIT&, std::vector<RESULT>&, DB_APP&, std::vector<DB_APP_VERSION>&,
|
2010-04-05 20:03:54 +00:00
|
|
|
double max_granted_credit, double& credit
|
2010-03-29 22:28:20 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
// if the result was anonymous platform,
|
|
|
|
// make a "pseudo ID" that combines the app ID and the resource type
|
|
|
|
//
|
|
|
|
inline int generalized_app_version_id(int avid, int appid) {
|
|
|
|
if (avid < 0) {
|
|
|
|
return appid*1000000 - avid;
|
|
|
|
}
|
|
|
|
return avid;
|
|
|
|
}
|
|
|
|
|
|
|
|
extern int host_scale_probation(
|
|
|
|
DB_HOST& host, int appid, int app_version_id, double latency_bound
|
|
|
|
);
|
|
|
|
|
2010-04-05 18:59:16 +00:00
|
|
|
extern int write_modified_app_versions(
|
|
|
|
std::vector<DB_APP_VERSION>& app_versions
|
|
|
|
);
|