#include <processor.h>
Inheritance diagram for EMAN::ZeroEdgeRowProcessor:
Public Member Functions | |
void | process_inplace (EMData *image) |
To process an image in-place. | |
string | get_name () const |
Get the processor's name. | |
string | get_desc () const |
Get the descrition of this specific processor. | |
TypeDict | get_param_types () const |
Get processor parameter information in a dictionary. | |
Static Public Member Functions | |
static Processor * | NEW () |
Static Public Attributes | |
static const string | NAME = "mask.zeroedge2d" |
x0 | The number of columns to zero from left | |
x1 | The number of columns to zero from right | |
y0 | The number of rows to zero from the bottom | |
y1 | The number of rows to zero from the top |
Definition at line 3946 of file processor.h.
string EMAN::ZeroEdgeRowProcessor::get_desc | ( | ) | const [inline, virtual] |
Get the descrition of this specific processor.
This function must be overwritten by a subclass.
Implements EMAN::Processor.
Definition at line 3960 of file processor.h.
string EMAN::ZeroEdgeRowProcessor::get_name | ( | ) | const [inline, virtual] |
Get the processor's name.
Each processor is identified by a unique name.
Implements EMAN::Processor.
Definition at line 3950 of file processor.h.
References NAME.
03951 { 03952 return NAME; 03953 }
TypeDict EMAN::ZeroEdgeRowProcessor::get_param_types | ( | ) | const [inline, virtual] |
Get processor parameter information in a dictionary.
Each parameter has one record in the dictionary. Each record contains its name, data-type, and description.
Reimplemented from EMAN::Processor.
Definition at line 3965 of file processor.h.
References EMAN::EMObject::INT, and EMAN::TypeDict::put().
03966 { 03967 TypeDict d; 03968 d.put("x0", EMObject::INT, "The number of columns to zero from left"); 03969 d.put("x1", EMObject::INT, "The number of columns to zero from right"); 03970 d.put("y0", EMObject::INT, "The number of rows to zero from the bottom"); 03971 d.put("y1", EMObject::INT, "The number of rows to zero from the top"); 03972 return d; 03973 }
static Processor* EMAN::ZeroEdgeRowProcessor::NEW | ( | ) | [inline, static] |
Definition at line 3955 of file processor.h.
03956 { 03957 return new ZeroEdgeRowProcessor(); 03958 }
void ZeroEdgeRowProcessor::process_inplace | ( | EMData * | image | ) | [virtual] |
To process an image in-place.
For those processors which can only be processed out-of-place, override this function to just print out some error message to remind user call the out-of-place version.
image | The image to be processed. |
Implements EMAN::Processor.
Definition at line 3386 of file processor.cpp.
References EMAN::EMData::get_data(), EMAN::EMData::get_xsize(), EMAN::EMData::get_ysize(), EMAN::EMData::get_zsize(), ImageDimensionException, LOGERR, LOGWARN, EMAN::Processor::params, and EMAN::EMData::update().
03387 { 03388 if (!image) { 03389 LOGWARN("NULL Image"); 03390 return; 03391 } 03392 03393 if (image->get_zsize() > 1) { 03394 LOGERR("ZeroEdgeRowProcessor is not supported in 3D models"); 03395 throw ImageDimensionException("3D model not supported"); 03396 } 03397 03398 int nx = image->get_xsize(); 03399 int ny = image->get_ysize(); 03400 03401 float *d = image->get_data(); 03402 int top_nrows = params["y0"]; 03403 int bottom_nrows = params["y1"]; 03404 03405 int left_ncols = params["x0"]; 03406 int right_ncols = params["x1"]; 03407 03408 size_t row_size = nx * sizeof(float); 03409 03410 memset(d, 0, top_nrows * row_size); 03411 memset(d + (ny - bottom_nrows) * nx, 0, bottom_nrows * row_size); 03412 03413 for (int i = top_nrows; i < ny - bottom_nrows; i++) { 03414 memset(d + i * nx, 0, left_ncols * sizeof(float)); 03415 memset(d + i * nx + nx - right_ncols, 0, right_ncols * sizeof(float)); 03416 } 03417 image->update(); 03418 }
const string ZeroEdgeRowProcessor::NAME = "mask.zeroedge2d" [static] |