2008-02-11 23:38:31 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
// two results are compatible if neither found an ellipse,
|
|
|
|
// or they both did and centers are within 20 pixels
|
|
|
|
//
|
2008-02-12 20:33:05 +00:00
|
|
|
function ellipse_compare($r1, $r2) {
|
2008-02-11 23:38:31 +00:00
|
|
|
if ($r1->have_ellipse) {
|
|
|
|
if ($r2->have_ellipse) {
|
|
|
|
$dx = ($r1->cx - $r2->cx);
|
|
|
|
$dy = ($r1->cy - $r2->cy);
|
|
|
|
$dsq = $dx*$dx + $dy*$dy;
|
|
|
|
return ($dsq < 400);
|
|
|
|
} else return false;
|
|
|
|
} else {
|
|
|
|
return !$r2->have_ellipse;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// handle a completed job with the given consensus set
|
|
|
|
//
|
2008-02-12 20:33:05 +00:00
|
|
|
function ellipse_handle($bj, $c) {
|
2008-02-11 23:38:31 +00:00
|
|
|
$res = $c[0];
|
|
|
|
if ($res->have_ellipse) {
|
|
|
|
$res->cx = 0;
|
|
|
|
$res->cy = 0;
|
|
|
|
foreach ($c as $r) {
|
|
|
|
$res->cx += $r->cx;
|
|
|
|
$res->cy += $r->cy;
|
|
|
|
}
|
|
|
|
$res->cx /= count($c);
|
|
|
|
$res->cy /= count($c);
|
|
|
|
}
|
|
|
|
|
2008-02-13 04:25:52 +00:00
|
|
|
$info = json_decode($bj->info);
|
2008-02-11 23:38:31 +00:00
|
|
|
$info->result = $res;
|
|
|
|
$i = json_encode($info);
|
|
|
|
$bj->update("info='$i'");
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|