2002-07-29 19:01:38 +00:00
|
|
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
|
|
|
|
"http://www.w3.org/TR/1999/REC-html401-19991224/loose.dtd">
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<title>Accounting and Result Validation</title>
|
|
|
|
<meta name="generator" content="BBEdit 6.1.2">
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<h2>Accounting and Result Validation</h2>
|
2002-04-30 22:22:54 +00:00
|
|
|
<p>
|
2002-07-29 19:01:38 +00:00
|
|
|
Participants are given <b>credit</b> for the computations performed
|
|
|
|
by their hosts. These credits are used to generate "leaderboards" of
|
|
|
|
individuals, teams, and categories (countries, CPU types, etc.). It is
|
|
|
|
to be expected that users will explore ways of "cheating", i.e. getting
|
|
|
|
undeserved credit.
|
|
|
|
</p>
|
2002-04-30 22:22:54 +00:00
|
|
|
<p>
|
2002-07-29 19:01:38 +00:00
|
|
|
In principles credit should reflect network transfers and disk
|
|
|
|
storage as well as computation. However, it's hard to verify these
|
|
|
|
activities, so they aren't included in credit.
|
|
|
|
</p>
|
2002-04-30 22:22:54 +00:00
|
|
|
<p>
|
2002-07-29 19:01:38 +00:00
|
|
|
The core client assigns credit for a completed work unit as a
|
|
|
|
function of the CPU time used, and the performance metrics of the CPU
|
|
|
|
(discussed later). This is sent back to the scheduling server; of
|
|
|
|
course, the number can't be trusted in general.
|
|
|
|
</p>
|
2002-04-30 22:22:54 +00:00
|
|
|
<p>
|
2002-07-29 19:01:38 +00:00
|
|
|
Output files may be wrong. This can happen because of hardware
|
|
|
|
failures, or because of tampering.
|
|
|
|
</p>
|
2002-04-30 22:22:54 +00:00
|
|
|
<p>
|
2002-07-29 19:01:38 +00:00
|
|
|
Both problems - credit-cheating and wrong result - can be addressed
|
|
|
|
by <b>redundant computing</b> and <b>result validation</b>. This means
|
|
|
|
that each workunit is processed at least twice. The project back end
|
|
|
|
waits until a minimum number of results have been returned, then
|
|
|
|
compares the results and decides which are "correct". The notion of
|
|
|
|
"equality" of results, and the policy for deciding which are correct,
|
|
|
|
are project-specific.
|
|
|
|
</p>
|
2002-04-30 22:22:54 +00:00
|
|
|
<p>
|
2002-07-29 19:01:38 +00:00
|
|
|
The back end then marks correct results as "validated", finds the
|
|
|
|
minimum reported credit for the correct results of a given workunit, and
|
|
|
|
assigns this amount of credit to all the correct results. This ensures
|
|
|
|
that as long as a reasonable majority of participants don't falsify
|
|
|
|
credit, almost all credit accounting will be correct.
|
|
|
|
</p>
|
2002-04-30 22:22:54 +00:00
|
|
|
<p>
|
2002-07-29 19:01:38 +00:00
|
|
|
<b>To do</b>: database keeps track of two types of credit: validated
|
|
|
|
and unvalidated. Users can see the workunits that didn't pass
|
|
|
|
validation, or that were given reduced credit.
|
|
|
|
</p>
|
|
|
|
</body>
|
|
|
|
</html>
|