EMAN2
|
A base (or parent) class for the Platonic symmetries. More...
#include <symmetry.h>
Public Member Functions | |
PlatonicSym () | |
virtual | ~PlatonicSym () |
virtual TypeDict | get_param_types () const |
Get a dictionary containing the permissable parameters of this class Platonic symmetries actually have no parameters. More... | |
virtual Dict | get_delimiters (const bool inc_mirror=false) const |
Returns the range of altitude and azimuth angles which encompass the asymmetric unit of the Platonic symmetry (and more). 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 bool | is_platonic_sym () const |
Determines whether or not this Symmetry3D is the platonic type - returns true. More... | |
Public Member Functions inherited from EMAN::Symmetry3D | |
Symmetry3D () | |
virtual | ~Symmetry3D () |
virtual Transform | get_sym (const int n) const =0 |
Every Symmetry3D object must provide access to the full set of its symmetry operators via this function. More... | |
virtual int | get_nsym () const =0 |
The total number of unique symmetry operations that will be return by this object when a calling program access Symmetry3D::get_sym. More... | |
virtual float | get_az_alignment_offset () const |
This functionality is only relevant to platonic symmetries. More... | |
virtual bool | is_h_sym () const |
A function that is used to determine if this is a Helical symmetry object This function is only virtually overidden by the HSym 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... | |
virtual int | get_max_csym () const =0 |
The Symmetry3D object must return the maximum degree of symmetry it exhibits about any one axis. 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 () |
virtual string | get_name () const =0 |
Get the unique name of this class (especially for factory based instantiation access) More... | |
virtual string | get_desc () const =0 |
Get a clear, concise description of this class. More... | |
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 |
Protected Member Functions | |
void | init () |
Init - Called to initialize platonic_params, should be called in the constructor of all Platonic solids that derive from this. More... | |
float | platonic_alt_lower_bound (const float &azimuth, const float &alpha) const |
Returns the lower bound of the asymmetric unit, as dependent on azimuth, and on alpha - alpha is alt_max for icos and oct, but may be alt_max/2.0 for tet depending on mirror symmetry etc. 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... | |
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 | |
Dict | platonic_params |
A dictionary that stores important angles, in radians. 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... | |
Private Member Functions | |
PlatonicSym (const PlatonicSym &) | |
Disallow copy construction. More... | |
PlatonicSym & | operator= (const PlatonicSym &) |
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 |
Static Public Member Functions inherited from EMAN::Symmetry3D | |
static vector< Transform > | get_symmetries (const string &symmetry) |
A base (or parent) class for the Platonic symmetries.
It cannot be instantieted on its own. Doctor Phil says: "see www.math.utah.edu/~alfeld/math/polyhedra/polyhedra.html for pictures of platonic solids" Also, see http://blake.bcm.edu/emanwiki/EMAN2/Symmetry for a good pictorial description of what's going on here This class has a fundamental role to play in terms of the Platonic symmetries that derive from it. It is based heavily on the manuscript Baldwin and Penczek, 2007. The Transform Class in SPARX and EMAN2. JSB 157(250-261), where the important angles of the asymmetric units in Platonic solids are described. The MOST IMPORTANT THING TO NOTE is anything that derives from this class must call init() in its constructor. However, because it is unlikey that any class will inherit from this one seeing as the set of Platonic symmetries is finite.
Definition at line 581 of file symmetry.h.
|
inline |
Definition at line 584 of file symmetry.h.
|
inlinevirtual |
Definition at line 585 of file symmetry.h.
|
private |
Disallow copy construction.
|
protectedvirtual |
inc_mirror | whether or not to include the mirror portion of the asymmetric unit |
Implements EMAN::Symmetry3D.
Reimplemented in EMAN::TetrahedralSym.
Definition at line 1777 of file symmetry.cpp.
References EMAN::Symmetry3D::get_az_alignment_offset(), EMAN::Vec3< Type >::normalize(), and platonic_params.
Referenced by get_asym_unit_triangles().
|
protectedvirtual |
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 1750 of file symmetry.cpp.
References get_asym_unit_points().
|
virtual |
Returns the range of altitude and azimuth angles which encompass the asymmetric unit of the Platonic symmetry (and more).
As a general rule you may generate your orientations evenly over the range altitude range as accessed by "alt_max" key in the return dictionary, and over the azimuth range as accessed by the "az_max", but your must call the function is_in_asym_unit as you do it, to accomodate for orientations in the range that are actually beyond the asymmetric unit. See http://blake.bcm.edu/emanwiki/EMAN2/Symmetry for pictures and descriptions. If the inc_mirror is true, the return "az_max" key is twice as large as if not, but only if the platonic symmetry is Icos or Oct. If the symmetry is Tet, the mirror considerations are taken into account in is_in_asym_unit. This is a bit of a design flaw, but it works.
inc_mirror | whether or not to consider the mirror portion of the asymmetric unit (only changes the return values if the symmetry is Icos or Oct) |
Implements EMAN::Symmetry3D.
Definition at line 1694 of file symmetry.cpp.
References EMAN::FactoryBase::get_name(), EMAN::OctahedralSym::NAME, EMAN::IcosahedralSym::NAME, platonic_params, and EMAN::EMConsts::rad2deg.
Referenced by is_in_asym_unit(), and EMAN::TetrahedralSym::is_in_asym_unit().
|
inlinevirtual |
Get a dictionary containing the permissable parameters of this class Platonic symmetries actually have no parameters.
Implements EMAN::FactoryBase.
Definition at line 591 of file symmetry.h.
|
protected |
Init - Called to initialize platonic_params, should be called in the constructor of all Platonic solids that derive from this.
This function generates the important angles of the platonic symmetries which is dependent only on the function get_max_csym ( which must be defined in all classes that inherit from this class)
Definition at line 1673 of file symmetry.cpp.
References EMAN::Symmetry3D::get_max_csym(), and platonic_params.
Referenced by EMAN::IcosahedralSym::IcosahedralSym(), EMAN::OctahedralSym::OctahedralSym(), EMAN::TetrahedralSym::TetrahedralSym(), and EMAN::Icosahedral2Sym::~Icosahedral2Sym().
|
virtual |
A function to be used when generating orientations over portion of the unit sphere defined by parameters returned by get_delimiters.
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.
Reimplemented in EMAN::TetrahedralSym.
Definition at line 1711 of file symmetry.cpp.
References EMAN::EMConsts::deg2rad, get_delimiters(), EMAN::Util::get_min(), platonic_alt_lower_bound(), and platonic_params.
|
inlinevirtual |
Determines whether or not this Symmetry3D is the platonic type - returns true.
Reimplemented from EMAN::Symmetry3D.
Definition at line 627 of file symmetry.h.
|
private |
Disallow assignment.
|
protected |
Returns the lower bound of the asymmetric unit, as dependent on azimuth, and on alpha - alpha is alt_max for icos and oct, but may be alt_max/2.0 for tet depending on mirror symmetry etc.
azimuth | an EMAN style 3D azimuth angle, in radians |
alpha | an EMAN style altitude angle that helps to define arcs on the unit sphere. See Baldwin and Penczek, 2007. The Transform Class in SPARX and EMAN2. JSB 157(250-261) where the angle alpha is described |
Definition at line 1737 of file symmetry.cpp.
References platonic_params.
Referenced by is_in_asym_unit(), and EMAN::TetrahedralSym::is_in_asym_unit().
|
protected |
A dictionary that stores important angles, in radians.
Definition at line 631 of file symmetry.h.
Referenced by get_asym_unit_points(), EMAN::TetrahedralSym::get_asym_unit_points(), get_delimiters(), init(), is_in_asym_unit(), EMAN::TetrahedralSym::is_in_asym_unit(), and platonic_alt_lower_bound().