#include <cmp.h>
Inheritance diagram for EMAN::QuadMinDotCmp:
Public Member Functions | |
float | cmp (EMData *image, EMData *with) const |
To compare 'image' with another image passed in through its parameters. | |
string | get_name () const |
Get the Cmp's name. | |
string | get_desc () const |
TypeDict | get_param_types () const |
Get Cmp parameter information in a dictionary. | |
Static Public Member Functions | |
Cmp * | NEW () |
Static Public Attributes | |
const string | NAME = "quadmindot" |
negative | Returns -1 * dot product, default true | |
normalize | Returns normalized dot product -1.0 - 1.0 |
Definition at line 314 of file cmp.h.
|
To compare 'image' with another image passed in through its parameters. An optional transformation may be used to transform the 2 images.
Implements EMAN::Cmp. Definition at line 515 of file cmp.cpp. References EMAN::EMData::get_array_offsets(), EMAN::EMData::get_xsize(), EMAN::EMData::get_ysize(), EMAN::EMData::get_zsize(), InvalidValueException, nx, ny, EMAN::EMData::set_array_offsets(), EMAN::Dict::set_default(), sqrt(), EMAN::Cmp::validate_input_args(), x, and y. 00516 { 00517 ENTERFUNC; 00518 validate_input_args(image, with); 00519 00520 if (image->get_zsize()!=1) throw InvalidValueException(0, "QuadMinDotCmp supports 2D only"); 00521 00522 int nx=image->get_xsize(); 00523 int ny=image->get_ysize(); 00524 00525 int normalize = params.set_default("normalize", 0); 00526 float negative = (float)params.set_default("negative", 1); 00527 00528 if (negative) negative=-1.0; else negative=1.0; 00529 00530 double result[4] = { 0,0,0,0 }, sq1[4] = { 0,0,0,0 }, sq2[4] = { 0,0,0,0 } ; 00531 00532 vector<int> image_saved_offsets = image->get_array_offsets(); 00533 vector<int> with_saved_offsets = with->get_array_offsets(); 00534 image->set_array_offsets(-nx/2,-ny/2); 00535 with->set_array_offsets(-nx/2,-ny/2); 00536 int i,x,y; 00537 for (y=-ny/2; y<ny/2; y++) { 00538 for (x=-nx/2; x<nx/2; x++) { 00539 int quad=(x<0?0:1) + (y<0?0:2); 00540 result[quad]+=(*image)(x,y)*(*with)(x,y); 00541 if (normalize) { 00542 sq1[quad]+=(*image)(x,y)*(*image)(x,y); 00543 sq2[quad]+=(*with)(x,y)*(*with)(x,y); 00544 } 00545 } 00546 } 00547 image->set_array_offsets(image_saved_offsets); 00548 with->set_array_offsets(with_saved_offsets); 00549 00550 if (normalize) { 00551 for (i=0; i<4; i++) result[i]/=sqrt(sq1[i]*sq2[i]); 00552 } else { 00553 for (i=0; i<4; i++) result[i]/=nx*ny/4; 00554 } 00555 00556 float worst=static_cast<float>(result[0]); 00557 for (i=1; i<4; i++) if (static_cast<float>(result[i])<worst) worst=static_cast<float>(result[i]); 00558 00559 EXITFUNC; 00560 return (float) (negative*worst); 00561 }
|
|
Implements EMAN::Cmp. Definition at line 324 of file cmp.h. 00325 { 00326 return "Caclultes dot product for each quadrant and returns worst value (default -1 * dot product)"; 00327 }
|
|
Get the Cmp's name. Each Cmp is identified by a unique name.
Implements EMAN::Cmp. Definition at line 319 of file cmp.h. 00320 {
00321 return NAME;
00322 }
|
|
Get Cmp parameter information in a dictionary. Each parameter has one record in the dictionary. Each record contains its name, data-type, and description.
Implements EMAN::Cmp. Definition at line 334 of file cmp.h. References EMAN::TypeDict::put(). 00335 { 00336 TypeDict d; 00337 d.put("negative", EMObject::INT, "If set, returns -1 * dot product. Default = true (smaller is better)"); 00338 d.put("normalize", EMObject::INT, "If set, returns normalized dot product -1.0 - 1.0."); 00339 return d; 00340 }
|
|
Definition at line 329 of file cmp.h. 00330 { 00331 return new QuadMinDotCmp(); 00332 }
|
|
|