Each project gives you credit for the computations your computers perform for it. BOINC's unit of credit, the Cobblestone 1, is 1/100 day of CPU time on a reference computer that does Eventually, credit may reflect network transfer and disk storage as well as computation.

How credit is determined

When your computer completes a result, BOINC determines an amount of claimed credit in one of two ways:

Claimed credit is reported to a project when your computer communicates with its server. The granted credit that you receive may be different from the claimed credit, and there may be a delay of a few hours or days before it is granted. This is because some BOINC projects grant credit only after results have been validated.

Recent Average Credit

Projects maintain two counts of granted credit:

Both quantities (total and recent average) are maintained for each user, host and team.

Each time new credit is granted, the following function is used to update the recent average credit of the host, user and team:

",htmlspecialchars("
#define CREDIT_HALF_LIFE  (SECONDS_IN_DAY*7)

// Update an estimate of \"units per day\" of something (credit or CPU time).
// The estimate is exponentially averaged with a given half-life
// (i.e. if no new work is done, the average will decline by 50% in this time).
// This function can be called either with new work,
// or with zero work to decay an existing average.
//
void update_average(
    double now,                     // current time
    double work_start_time,       // when new work was started
                                    // (or zero if no new work)
    double work,                    // amount of new work
    double& avg,                    // average work per day (in and out)
    double& avg_time                // when average was last computed
) {
    if (avg_time) {
        double diff = now - avg_time;
        double diff_days = diff/SECONDS_PER_DAY;
        double weight = exp(-diff*M_LN2/CREDIT_HALF_LIFE);
        avg *= weight;
        avg += (1-weight)*(work/diff_days);
    } else {
        double dd = (now - work_start_time)/SECONDS_PER_DAY;
        avg = work/dd;
    }
    avg_time = now;
}

"),"

Computing the current value of Recent Average Credit

BOINC updates 'recent average credit' (RAC) only when new credit is granted. Interfaces that export RAC also export that time at which it was last updated. To obtain the current value of RAC, you must 'decay' it based on the time that has elapsed since it was updated:

", htmlspecialchars("
function decay_average(\$avg, \$avg_time, \$now = 0) {
   \$M_LN2 = 0.693147180559945309417;
   \$credit_half_life = 86400 * 7;
   if (\$now == 0) {
       \$now = time();
   }
   \$diff = \$now - \$avg_time;
   \$diff_days = \$diff/86400;
   \$weight = exp(-\$diff * \$M_LN2/\$credit_half_life);
   \$avg *= \$weight;
   return \$avg;
}
"), "

If you don't apply this decay, inactive entities will have incorrectly high RAC.

PHP code for the decay function can be found in html/inc/credit.inc and html/inc/host.inc.


1 Named after Jeff Cobb of SETI@home "; page_tail(); ?>