EMAN2
|
An encapsulation of helical 3D symmetry. More...
#include <symmetry.h>
Public Member Functions | |
HSym () | |
virtual | ~HSym () |
virtual string | get_name () const |
Return HSym::NAME. More... | |
virtual string | get_desc () const |
Get a description. More... | |
virtual TypeDict | get_param_types () const |
Get a dictionary containing the permissable parameters of this class Of all the symmetries, helical has the most options. More... | |
virtual Dict | get_delimiters (const bool inc_mirror=false) const |
Get the altitude and phi angle of the d symmetry, which depends on nysm. More... | |
virtual Transform | get_sym (const int n) const |
Provides access to the complete set of rotational and translational symmetry operations associated with helical symmetry. More... | |
virtual int | get_nsym () const |
For symmetries in general this function is supposed to return the number of unique symmetric operations that can be applied for the given Symmetry3D object. More... | |
virtual int | get_max_csym () const |
Gets the maximum cylcic symmetry exhibited by this object. More... | |
virtual bool | is_h_sym () const |
Determines whether or not this Symmetry3D is the helical type - returns true. More... | |
virtual bool | is_in_asym_unit (const float &altitude, const float &azimuth, const bool inc_mirror) const |
A function to be used when generating orientations over portion of the unit sphere defined by parameters returned by get_delimiters. More... | |
virtual vector< Vec3f > | get_asym_unit_points (bool inc_mirror=false) const |
virtual vector< vector< Vec3f > > | get_asym_unit_triangles (bool inc_mirror) const |
Get triangles that precisely occlude the projection area of the default asymmetric unit. More... | |
Public Member Functions inherited from EMAN::Symmetry3D | |
Symmetry3D () | |
virtual | ~Symmetry3D () |
virtual float | get_az_alignment_offset () const |
This functionality is only relevant to platonic symmetries. More... | |
virtual bool | is_platonic_sym () const |
A function that is used to determine if this is a platonic symmetry object This function is only virtually overidden by the PlatonicSym symmetry, which returns true, not false. More... | |
virtual bool | is_c_sym () const |
A function that is used to determine if this is a c symmetry object This function is only virtually overidden by the CSym object, which returns true. More... | |
virtual bool | is_d_sym () const |
A function that is used to determine if this is a d symmetry object This function is only virtually overidden by the DSym object, which returns true. More... | |
virtual bool | is_tet_sym () const |
A function that is used to determine if this is the tetrahedral symmetry object This function is only virtually overidden by the TetSym object, which returns true. More... | |
vector< Transform > | gen_orientations (const string &generatorname="eman", const Dict &parms=Dict()) |
Ask the Symmetry3D object to generate a set of orientations in its asymmetric unit using an OrientationGenerator constructed from the given parameters (using a Factory). More... | |
virtual Transform | reduce (const Transform &t3d, int n=0) const |
A function that will reduce an orientation, as characterized by Euler anges, into a specific asymmetric unit. More... | |
virtual int | in_which_asym_unit (const Transform &t3d) const |
A function that will determine in which asymmetric unit a given orientation resides The asymmetric unit 'number' will depend entirely on the order in which different symmetry operations are return by the Symmetry3D::get_sym function. More... | |
virtual int | point_in_which_asym_unit (const Vec3f &v) const |
A function that will determine in which asymmetric unit a given vector resides The asymmetric unit 'number' will depend entirely on the order in which different symmetry operations are return by the Symmetry3D::get_sym function The vector is a point. More... | |
virtual vector< Transform > | get_touching_au_transforms (bool inc_mirror=true) const |
Gets a vector of Transform objects that define the set of asymmetric units that touch the default asymmetric unit. More... | |
virtual vector< Transform > | get_syms () const |
Public Member Functions inherited from EMAN::FactoryBase | |
FactoryBase () | |
virtual | ~FactoryBase () |
Dict | get_params () const |
get a copy of the parameters of this class More... | |
void | set_params (const Dict &new_params) |
Set new parameters. More... | |
void | set_param (const string key, const EMObject val) |
void | insert_params (const Dict &new_params) |
Insert parameters. More... | |
Dict | copy_relevant_params (const FactoryBase *const that) const |
Static Public Member Functions | |
static Symmetry3D * | NEW () |
Factory support function NEW. More... | |
Static Public Member Functions inherited from EMAN::Symmetry3D | |
static vector< Transform > | get_symmetries (const string &symmetry) |
Static Public Attributes | |
static const string | NAME = "h" |
The name of this class - used to access it from factories etc. Should be "h". More... | |
Private Member Functions | |
HSym (const HSym &) | |
Disallow copy construction. More... | |
HSym & | operator= (const HSym &) |
Disallow assignment. More... | |
Additional Inherited Members | |
Public Types inherited from EMAN::Symmetry3D | |
typedef vector< vector< Vec3f > >::const_iterator | cit |
typedef vector< vector< Vec3f > >::iterator | ncit |
Protected Member Functions inherited from EMAN::Symmetry3D | |
void | cache_au_planes () const |
Establish the asymmetric unit planes cache. More... | |
void | delete_au_planes () |
Clear the asymmetric unit planes cache. More... | |
Protected Attributes inherited from EMAN::Symmetry3D | |
float ** | cached_au_planes |
The asymmetric unit planes are cached to provide a great speed up the point_in_which_asym_unit function, which is called by reduce and by in_which_asym_unit. More... | |
int | cache_size |
Have to remember the cache size. More... | |
int | num_triangles |
This is stores the number of triangles returned by get_asym_unit_triangles(true) More... | |
vector< vector< Vec3f > > | au_sym_triangles |
This cache is of size cache_size. More... | |
Protected Attributes inherited from EMAN::FactoryBase | |
Dict | params |
This is the dictionary the stores the parameters of the object. More... | |
|
inline |
|
inlinevirtual |
Definition at line 450 of file symmetry.h.
|
private |
Disallow copy construction.
|
virtual |
inc_mirror | whether or not to include the mirror portion of the asymmetric unit |
Implements EMAN::Symmetry3D.
Definition at line 1608 of file symmetry.cpp.
References get_delimiters(), EMAN::FactoryBase::params, and EMAN::Dict::set_default().
|
virtual |
Get triangles that precisely occlude the projection area of the default asymmetric unit.
This is used for collision detection in Symmetry3D::reduce
inc_mirror | whether to include the mirror portion of the asymmetric unit |
Implements EMAN::Symmetry3D.
Definition at line 1602 of file symmetry.cpp.
|
virtual |
Get the altitude and phi angle of the d symmetry, which depends on nysm.
The "alt_max" is always 90 The "alt_min" 90-maxtilt The "az_max" is always 360/nsym degrees Helical symmetry argument is the only symmetry not to act on the inc_mirror argument. The current policy is the orientation generator using this symmetry should make its own accomodation for the inclusion of mirror orientations if the symmetry is helical (hence the presence of the is_h_sym function in the Symmetry3D class).
inc_mirror | this parameter is not specifically acted upon in this class |
InvalidValueException | if nsym is less than or equal to zero |
Implements EMAN::Symmetry3D.
Definition at line 1567 of file symmetry.cpp.
References InvalidValueException, EMAN::FactoryBase::params, and EMAN::Dict::set_default().
Referenced by get_asym_unit_points(), and is_in_asym_unit().
|
inlinevirtual |
Get a description.
Implements EMAN::FactoryBase.
Definition at line 468 of file symmetry.h.
|
inlinevirtual |
Gets the maximum cylcic symmetry exhibited by this object.
This is used by OrientationGenerators, and is probably not something a general user would utilize.
Implements EMAN::Symmetry3D.
Definition at line 530 of file symmetry.h.
References EMAN::FactoryBase::params.
|
inlinevirtual |
Return HSym::NAME.
Implements EMAN::FactoryBase.
Definition at line 463 of file symmetry.h.
References NAME.
|
inlinevirtual |
For symmetries in general this function is supposed to return the number of unique symmetric operations that can be applied for the given Symmetry3D object.
For helical symmetries this is provided by the user as a parameter when setting up the helical symmetry. Generally a multiple of nstart.
InvalidValueException | if d_az (as stored internally in parms) is less than or equal to zero |
Implements EMAN::Symmetry3D.
Definition at line 519 of file symmetry.h.
References EMAN::FactoryBase::params.
|
inlinevirtual |
Get a dictionary containing the permissable parameters of this class Of all the symmetries, helical has the most options.
This is because different approaches have to taken in regard to defining an asymmetric unit and to returning the set of rotational and translational symmetry operations
Implements EMAN::FactoryBase.
Definition at line 476 of file symmetry.h.
References EMAN::EMObject::FLOAT, EMAN::EMObject::INT, and EMAN::TypeDict::put().
|
virtual |
Provides access to the complete set of rotational and translational symmetry operations associated with helical symmetry.
This symmetry operations are generated in a straightforward way from the parameters of this class, specifically the return Transform object has an azimuth of n times the "d_az" (as specified in the parameters of this class), and has a post translation of "tz" in the z direction.
n | the helical symmetry operation number. |
Implements EMAN::Symmetry3D.
Definition at line 1648 of file symmetry.cpp.
References EMAN::FactoryBase::params, EMAN::Dict::set_default(), and EMAN::Transform::set_trans().
|
inlinevirtual |
Determines whether or not this Symmetry3D is the helical type - returns true.
Reimplemented from EMAN::Symmetry3D.
Definition at line 538 of file symmetry.h.
|
virtual |
A function to be used when generating orientations over portion of the unit sphere defined by parameters returned by get_delimiters.
In platonic symmetry altitude and azimuth alone are not enough to correctly demarcate the asymmetric unit. See the get_delimiters comments.
altitude | the EMAN style altitude of the 3D orientation in degrees |
azimuth | the EMAN style azimuth of the 3D orientation in degrees |
inc_mirror | whether or not to include orientations if they are in the mirror portion of the asymmetric unit |
Implements EMAN::Symmetry3D.
Definition at line 1585 of file symmetry.cpp.
References get_delimiters(), EMAN::FactoryBase::params, and EMAN::Dict::set_default().
|
inlinestatic |
Factory support function NEW.
Definition at line 455 of file symmetry.h.
References HSym().
|
static |
The name of this class - used to access it from factories etc. Should be "h".
Definition at line 533 of file symmetry.h.
Referenced by get_name().