2003-12-24 00:50:51 +00:00
|
|
|
<?
|
|
|
|
require_once("docutil.php");
|
|
|
|
page_head("Validation");
|
|
|
|
echo "
|
2004-02-09 05:11:05 +00:00
|
|
|
<p>
|
2004-03-15 20:40:59 +00:00
|
|
|
<b>Validation</b> is the process of comparing redundant results
|
|
|
|
and deciding which is to be considered correct.
|
2004-02-09 05:11:05 +00:00
|
|
|
BOINC supplies a utility program <b>validate</b>
|
|
|
|
to perform validation and credit-granting.
|
2004-03-15 20:40:59 +00:00
|
|
|
You
|
|
|
|
This program must be linked with two application-specific functions:
|
|
|
|
<pre>",
|
|
|
|
htmlspecialchars("
|
2004-02-09 05:11:05 +00:00
|
|
|
int check_set(vector<RESULT> results, int& canonicalid, double& credit);
|
|
|
|
int check_pair(RESULT& r1, RESULT& r2, bool& match);
|
2004-03-15 20:40:59 +00:00
|
|
|
"),
|
|
|
|
"</pre>
|
2004-02-09 05:11:05 +00:00
|
|
|
<b>check_set()</b> takes a set of results.
|
|
|
|
If there is sufficient agreement,
|
|
|
|
it selects one of them as the canonical result
|
|
|
|
(returning its ID) and also decides what credit should
|
|
|
|
be granted for correct results for this workunit.
|
|
|
|
<p>
|
|
|
|
<b>check_pair()</b> compares two results and returns match=true
|
|
|
|
if they agree.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
The file <b>validate_test.C</b> contains an example
|
|
|
|
implementation of check_set() and check_pair().
|
|
|
|
|
2003-12-24 00:50:51 +00:00
|
|
|
<p>
|
|
|
|
The XML document listing the output files has the form: <pre>
|
2004-03-15 20:40:59 +00:00
|
|
|
",htmlspecialchars("
|
|
|
|
<file_info>...</file_info>
|
2003-12-24 00:50:51 +00:00
|
|
|
[ ... ]
|
2004-03-15 20:40:59 +00:00
|
|
|
<result>
|
|
|
|
<name>foobar</name>
|
|
|
|
<wu_name>blah</wu_name>
|
|
|
|
<exit_status>blah</exit_status>
|
|
|
|
<file_ref>...</file_ref>
|
2003-12-24 00:50:51 +00:00
|
|
|
[ ... ]
|
2004-03-15 20:40:59 +00:00
|
|
|
</result>
|
|
|
|
"),"
|
2003-12-24 00:50:51 +00:00
|
|
|
</pre>
|
|
|
|
The components are:
|
|
|
|
<ul>
|
|
|
|
<li> The <b><name></b> element is the result name.
|
|
|
|
<li> The <b><wu_name></b> element is the workunit name.
|
|
|
|
<li> Each <b><file_ref></b> element is an association to an
|
|
|
|
output file, described by a corresponding <b><file_info></b> element.
|
|
|
|
</ul>
|
|
|
|
<p>
|
|
|
|
The XML document describing the sizes and checksums of the output
|
|
|
|
files is just a list of <b><file_info></b> elements, with the
|
|
|
|
<b>nbytes</b> and <b>md5_cksum</b> fields present.
|
|
|
|
The project back end
|
|
|
|
must parse this field to find the locations and checksums of output files.
|
|
|
|
";
|
|
|
|
page_tail();
|
|
|
|
?>
|