This class describes a structural model.
Public Member Functions | |
SB_NODE_GETTER_0 (, std::string, GetTitleInformation) | |
SB_NODE_GETTER_0 (, std::string, GetPrimaryStructureInformation) | |
SB_NODE_GETTER_0 (, std::string, GetHeterogenInformation) | |
SB_NODE_GETTER_0 (, std::string, GetSecondaryStructureInformation) | |
SB_NODE_GETTER_0 (, std::string, GetConnectivityAnnotationInformation) | |
SB_NODE_GETTER_0 (, std::string, GetMiscellaneousInformation) | |
SB_NODE_GETTER_0 (, std::string, GetCrystallographicAndTransformationInformation) | |
SB_NODE_PREDICATE_0 (, HasTitleInformation) | |
SB_NODE_PREDICATE_0 (, HasPrimaryStructureInformation) | |
SB_NODE_PREDICATE_0 (, HasHeterogenInformation) | |
SB_NODE_PREDICATE_0 (, HasSecondaryStructureInformation) | |
SB_NODE_PREDICATE_0 (, HasConnectivityAnnotationInformation) | |
SB_NODE_PREDICATE_0 (, HasMiscellaneousInformation) | |
SB_NODE_PREDICATE_0 (, HasCrystallographicAndTransformationInformation) | |
SB_DECLARE_DATA (SBMStructuralModel) | |
Public Member Functions inherited from SBMModel | |
SB_NODE_GETTER_0 (, SBDDataGraphNode::Type, GetModelType) | |
SB_NODE_PREDICATE_1 (, IsModelType, SBDDataGraphNode::Type) | |
SB_DECLARE_DATA (SBMModel) | |
virtual | ~SBMModel () |
Delete the model. | |
SBMModel * | getNextModel () const |
Returns the next model in the parent. | |
SBMModel * | getPreviousModel () const |
Returns the previous model in the parent. | |
virtual unsigned int | getOpacity () const |
Returns the opacity. | |
virtual void | setOpacity (unsigned int opacity) |
Sets the opacity. | |
virtual unsigned int | getMinimumOpacity () const |
Returns the minimum opacity. | |
virtual unsigned int | getTransparency () const |
Returns the transparency. | |
virtual void | setTransparency (unsigned int transparency) |
Sets the transparency. | |
virtual unsigned int | getMaximumTransparency () const |
Returns the maximum transparency. | |
Public Member Functions inherited from SBDDataGraphNode | |
SB_DECLARE_DATA (SBDDataGraphNode) | |
SBDDataGraphNode * | getParent () const |
Returns the parent of the node. More... | |
SBDDataGraphNode * | getThisNode () const |
Returns the pointer to this node. More... | |
SBDDataGraphNode * | getNextNode () const |
Returns the pointer to the next node in the children of the node's parent. More... | |
SBDDataGraphNode * | getPreviousNode () const |
Returns the pointer to the previous node in the children of the node's parent. More... | |
SBDDataGraphNode * | getNextNode (SBDDataGraphNode::Type nodeType) const |
Returns the pointer to the next node with type nodeType in the children of the node's parent. More... | |
SBDDataGraphNode * | getPreviousNode (SBDDataGraphNode::Type nodeType) const |
Returns the pointer to the previous node with type nodeType in the children of the node's parent. More... | |
SBDDocument * | getDocument () const |
Returns the document the node belongs to. More... | |
virtual bool | canAddChild (SBDDataGraphNode *node, SBDDataGraphNode *nextNode=0) const |
Returns whether this node can add node as a child. More... | |
virtual bool | addChild (SBDDataGraphNode *node, SBDDataGraphNode *nextNode=0) |
Adds a child to the node. More... | |
virtual bool | removeChild (SBDDataGraphNode *node) |
Removes a child from the node. More... | |
bool | hasOneOf (const SBNodeIndexer &nodeIndexer) const |
Returns true if and only if this node is one of the nodes of the nodeIndexer , or is the ancestor of one of them. More... | |
bool | descendsFrom (SBDDataGraphNode *node) const |
Returns true if and only if this node is node , or descends from it. More... | |
bool | descendsFrom (const SBNodeIndexer &nodeIndexer) const |
Returns true if and only if this node is one of the nodes of the nodeIndexer , or descends from one of them. More... | |
bool | descendsFrom (SBPointerIndexer< SBDDataGraphNode > *nodePointerIndexer) const |
Returns true if and only if this node is one of the nodes of the nodePointerIndexer , or descends from one of them. More... | |
bool | isIn (SBDDataGraphNode *node) const |
Returns true if and only if this node is node , or descends from it, or belongs to a group stored in node . More... | |
bool | isIn (const SBNodeIndexer &nodeIndexer) const |
Returns true if and only if this node is one of the nodes of the nodeIndexer , or descends from one of them, or belongs to a group stored in one of the nodes of the nodeIndexer . More... | |
bool | isIn (SBPointerIndexer< SBDDataGraphNode > *nodePointerIndexer) const |
Returns true if and only if this node is one of the nodes of the nodePointerIndexer , or descends from one of them, or belongs to a group stored in of the nodes of the nodePointerIndexer . More... | |
bool | isOneOf (const SBNodeIndexer &nodeIndexer) const |
Returns true if and only if this node is one of the nodes of the nodeIndexer . More... | |
bool | isOneOf (SBPointerIndexer< SBDDataGraphNode > *nodePointerIndexer) const |
Returns true if and only if this node is one of the nodes of the nodePointerIndexer . More... | |
SBDDataGraphNode * | getRoot () const |
Returns the root of the hierarchy the node belongs to. More... | |
unsigned int | getNodeIndex () const |
Returns the node index (unique in the whole data graph, but non-persistent) More... | |
std::string | getTypeString (bool humanReadable=false) const |
Returns a string describing the type of the data graph node. More... | |
virtual std::string const & | getName () const |
Returns the name of the node. | |
virtual void | setName (const std::string &name) |
Sets the name of the node. More... | |
bool | isType (Type type) const |
Returns true when the type of the node corresponds to type . | |
bool | isModel () const |
Returns true when the node is a model. | |
bool | isStructuralNode () const |
Returns true when the node is a structural node. | |
bool | isStructuralModel () const |
Returns true when the node is a structural model. | |
bool | isVisualModel () const |
Returns true when the node is a visual model. | |
bool | isDynamicalModel () const |
Returns true when the node is a dynamical model. | |
bool | isInteractionModel () const |
Returns true when the node is a interaction model. | |
bool | isPropertyModel () const |
Returns true when the node is a property model. | |
bool | isMesh () const |
Returns true when the node is a mesh. | |
bool | isSimulator () const |
Returns true when the node is a simulator. | |
bool | isStructuralParticle () const |
Returns true when the node is a structural particle (an atom or a pseudo-atom) | |
bool | isCreated () const |
Returns true if and only if the node is created. More... | |
void | create () |
Creates the node. More... | |
bool | isErased () const |
Returns true if and only if the node is erased. More... | |
void | erase () |
Erases the node. More... | |
unsigned int | getFlags () const |
Returns the flags. More... | |
unsigned int | getInheritedFlags () const |
Returns the inherited flags. More... | |
bool | isSelected () const |
Returns whether the node is selected. More... | |
bool | getSelected () const |
Returns whether the node is selected. | |
bool | getSelectionFlag () const |
Returns the selection flag. More... | |
void | setSelectionFlag (bool flag) |
Sets the selection flag. More... | |
bool | isVisible () const |
Returns whether the node is visible. More... | |
bool | getVisible () const |
Returns whether the node is visible. | |
bool | getVisibilityFlag () const |
Returns the visibility flag. More... | |
void | setVisibilityFlag (bool flag) |
Sets the visibility flag. More... | |
bool | isHighlighted () const |
Returns whether the node is highlighted. More... | |
bool | getHighlightingFlag () const |
Returns the highlighting flag. More... | |
void | setHighlightingFlag (bool flag) |
Sets the highlighting flag. More... | |
virtual void | display (RenderingPass renderingPass) |
Displays the node. More... | |
virtual void | display () |
Displays the node (deprecated) More... | |
virtual void | displayForShadow () |
Displays the node for shadowing purposes (deprecated) More... | |
virtual void | displayForSelection () |
Displays the node for selection purposes (deprecated) More... | |
virtual bool | hasOpacityRange () const |
Returns whether the node has the opacity range. | |
virtual unsigned int | getDefaultOpacity () const |
Returns the default opacity. | |
virtual unsigned int | getMaximumOpacity () const |
Returns the maximum opacity. | |
virtual unsigned int | getOpacitySingleStep () const |
Returns the opacity single step. | |
virtual std::string | getOpacitySuffix () const |
Returns the opacity suffix. | |
virtual bool | hasTransparencyRange () const |
Returns whether the node has the transparency range. | |
virtual unsigned int | getDefaultTransparency () const |
Returns the default transparency. | |
virtual unsigned int | getMinimumTransparency () const |
Returns the minimum transparency. | |
virtual unsigned int | getTransparencySingleStep () const |
Returns the transparency single step. | |
virtual std::string | getTransparencySuffix () const |
Returns the transparency suffix. | |
float | getInheritedOpacity () const |
Returns the cumulative opacity, when taking into account the ascendants. | |
float | getInheritedTransparency () const |
Returns the cumulative transparency, when taking into account the ascendants. | |
bool | addMaterial (SBDDataGraphNodeMaterial *material) |
Adds a material. More... | |
bool | removeMaterial () |
Removes the material. More... | |
SBDDataGraphNodeMaterial * | getMaterial () const |
Returns the material. More... | |
SBDDataGraphNode * | getMaterialOwner () const |
Returns the node whose material is inherited. More... | |
void | connectBaseSignalToSlot (SBCReferenceTarget *referenceTarget, void(SBCReferenceTarget::*functionPointer)(SBBaseEvent *), SBCReferenceTarget *nextReferenceTarget=0, void(SBCReferenceTarget::*nextFunctionPointer)(SBBaseEvent *)=0) |
Connects the base signal to a slot. More... | |
bool | baseSignalIsConnectedToSlot (SBCReferenceTarget *referenceTarget, void(SBCReferenceTarget::*functionPointer)(SBBaseEvent *)) const |
Returns true when the base signal is connected to a slot. | |
void | disconnectBaseSignalFromSlot (SBCReferenceTarget *referenceTarget, void(SBCReferenceTarget::*functionPointer)(SBBaseEvent *)) |
Disconnects the base signal from a slot. | |
unsigned int | countNodes (SBDDataGraphNode::Type nodeType, bool selectedNodesOnly=false, const SBNodePredicate &visitPredicate=SBDDataGraphNode::All(), bool includeDependencies=false) const |
Collects nodes into nodeIndexer , based on a nodeType , a selection status and a visitPredicate , with our without dependencies. More... | |
unsigned int | countNodes (const SBNodePredicate &selectionPredicate=SBDDataGraphNode::All(), const SBNodePredicate &visitPredicate=SBDDataGraphNode::All(), bool includeDependencies=false) const |
Collects nodes into nodeIndexer , based on a selectionPredicate and a visitPredicate , with our without dependencies. More... | |
virtual std::string | getHierarchyString (const std::string &separator="/", bool includeNodeType=false) const |
Returns a string with hierarchical information on the node and its parents names. More... | |
Public Member Functions inherited from SBCReferenceTarget | |
SBCReferenceTarget () | |
virtual | ~SBCReferenceTarget () |
unsigned int | getMemoryFootprint () const |
void | printReferencesToOwners () const |
Constructors and destructors | |
SBMStructuralModel () | |
Builds a base model. | |
virtual | ~SBMStructuralModel () |
Deletes the model. | |
Serialization | |
bool | isSerializable () const |
Returns true. | |
virtual void | serialize (SBCSerializer *serializer, const SBNodeIndexer &nodeIndexer, const SBVersionNumber &sdkVersionNumber=SB_SDK_VERSION_NUMBER, const SBVersionNumber &classVersionNumber=SBVersionNumber(1, 0, 0)) const |
Serializes the node. | |
virtual void | unserialize (SBCSerializer *serializer, const SBNodeIndexer &nodeIndexer, const SBVersionNumber &sdkVersionNumber=SB_SDK_VERSION_NUMBER, const SBVersionNumber &classVersionNumber=SBVersionNumber(1, 0, 0)) |
Unserializes the node. | |
Rendering | |
virtual void | expandBounds (SBIAPosition3 &bounds) const |
Expands the bounds to make sure the visual model fits inside them. | |
virtual void | collectAmbientOcclusion (const SBPosition3 &boxOrigin, const SBPosition3 &boxSize, unsigned int nCellsX, unsigned int nCellsY, unsigned int nCellsZ, float *ambientOcclusionData) |
To collect ambient occlusion data. | |
Geometry | |
void | centerTransform () |
Centers the pivot of the transform on the center of mass of the particles contained in the structural model. More... | |
SBSpatialTransform const & | getTransform () const |
Returns the spatial transform of the structural model. | |
void | setTransform (const SBSpatialTransform &transform) |
Sets the spatial transform of the structural model. | |
void | setTransform (const SBSpatialTransform &transform, bool transformParticles) |
Sets the spatial transform of the structural model. | |
void | setTransform (SBSpatialTransform const &newTransform, SBSpatialTransform const &oldTransform, bool transformParticles=true) |
Sets the newTransform and the oldTransform of the structural model. | |
SBMatrix33 const & | getOrientation () const |
Returns the orientation of the structural model. | |
void | setOrientation (const SBMatrix33 &orientation) |
Sets the orientation of the structural model. | |
void | setOrientation (const SBMatrix33 &orientation, bool transformParticles) |
Sets the orientation of the structural model. | |
void | setOrientation (SBMatrix33 const &newOrientation, SBMatrix33 const &oldOrientation, bool transformParticles=true) |
Sets the newOrientation and the oldOrientation of the structural model. | |
SBPosition3 const & | getPosition () const |
Returns the position of the structural model. | |
void | setPosition (const SBPosition3 &position) |
Sets the position of the structural model. | |
void | setPosition (const SBPosition3 &position, bool transformParticles) |
Sets the position of the structural model. | |
void | setPosition (SBPosition3 const &newPosition, SBPosition3 const &oldPosition, bool transformParticles=true) |
Sets the newPosition and the oldPosition of the structural model. | |
void | transform (const SBSpatialTransform &transform) |
Applies a spatial transform to the structural model. | |
void | rotate (const SBVector3 &axis, const SBQuantity::dimensionless &angle) |
Rotates the structural model. | |
void | translate (const SBLength3 &translation) |
Translates the structural model. | |
Topology | |
virtual bool | canAddChild (SBNode *node, SBNode *nextNode=0) const |
Returns whether this node can add node as a child. More... | |
virtual bool | canAddChildType (SBNode::Type nodeType) const |
Returns whether this node can add a node with type nodeType as a child. More... | |
virtual bool | canHaveDescendantType (SBNode::Type nodeType) const |
Returns whether this node can have a node with type nodeType as a descendant. More... | |
virtual bool | addChild (SBNode *node, SBNode *nextNode=0) |
Adds a child to the node. More... | |
virtual bool | removeChild (SBNode *node) |
Removes a child from the node. More... | |
virtual SBPointerList< SBMStructuralModelNode > const * | getChildren () const |
This function is a convenience function equivalent to getStructuralRoot()->getChildren | |
SBMStructuralModelNodeRoot * | getStructuralRoot () const |
virtual SBMStructuralModel * | clone () |
Returns a copy of the node and its descendants. | |
static bool | extractStructuralNodes (SBNodeIndexer &structuralModelIndexer, const SBNodeIndexer &structuralNodeIndexer) |
Adds in structuralModelIndexer the structural models resulting from extracting the structural nodes in structuralNodeIndexer . | |
static bool | cloneStructuralNodes (SBNodeIndexer &structuralModelIndexer, const SBNodeIndexer &structuralNodeIndexer) |
Adds in structuralModelIndexer the structural models resulting from cloning the structural nodes in structuralNodeIndexer . | |
static SBSpatialDomain | computeDomain (const SBNodeIndexer &nodeIndexer) |
Computes the domain containing the atoms and bond atoms in the node indexer. | |
Locking | |
virtual bool | isLocked () const |
Returns whether the model is locked. More... | |
virtual bool | getLockedFlag () const |
Returns the locked flag. More... | |
virtual void | setLockedFlag (bool flag) |
Sets the locked flag. More... | |
Identity | |
virtual SBDDataGraphNode::Type | getType () const |
Returns the type of the data graph node. | |
virtual SBDDataGraphNode::Type | getModelType () const |
Returns the model type. | |
Atoms | |
static void | replaceAtom (SBMStructuralModelNodeAtom *oldAtom, SBMStructuralModelNodeAtom *newAtom, bool preserveOldAtomPosition=false) |
Replaces atom oldAtom with atom newAtom . All bonds from the old atom are transferred to the new atom. | |
Bonds | |
void | createCovalentBonds () |
Builds covalent bonds for the atoms belonging to the structural model according to the inter-atomic distances. | |
int | createCovalentBondsByResidueType () |
Builds covalent bonds for the atoms belonging to the structural model according to the residue types, regardless of inter-atomic distances. If the bonds are already present, it sets the order of covalent bonds for the atoms belonging to the structural model according to the residue types. | |
int | createCovalentBondsByResidueType (const SBNodeIndexer &nodeIndexer) |
Builds covalent bonds for the atoms belonging to the given residues of the structural model according to the residue types, regardless of inter-atomic distances. If the bonds are already present, it sets the order of covalent bonds for the atoms belonging to the structural model according to the residue types. | |
static void | replaceBond (SBMStructuralModelNodeBond *oldBond, SBMStructuralModelNodeBond *newBond, bool flipBond=false, bool preserveOldBondPosition=false) |
Replaces bond oldBond with bond newBond . All neighboring bonds from the old bond are transferred to the new bond. | |
Secondary structure | |
bool | computeSecondaryStructure (bool &updated, bool forceUpdate=false) |
Computes the secondary structure for all residues in the structural model. More... | |
Messaging | |
void | connectStructuralSignalToSlot (SBCReferenceTarget *referenceTarget, void(SBCReferenceTarget::*functionPointer)(SBStructuralEvent *), SBCReferenceTarget *nextReferenceTarget=0, void(SBCReferenceTarget::*nextFunctionPointer)(SBStructuralEvent *)=0) |
bool | structuralSignalIsConnectedToSlot (SBCReferenceTarget *referenceTarget, void(SBCReferenceTarget::*functionPointer)(SBStructuralEvent *)) const |
void | disconnectStructuralSignalFromSlot (SBCReferenceTarget *referenceTarget, void(SBCReferenceTarget::*functionPointer)(SBStructuralEvent *)) |
Selection functions | |
virtual void | getNodes (SBNodeIndexer &nodeIndexer, SBNode::Type nodeType, bool selectedNodesOnly=false, const SBNodePredicate &visitPredicate=SBDDataGraphNode::All(), bool includeDependencies=false) const |
Collects nodes into nodeIndexer , based on a nodeType , a selection status and a visitPredicate , with our without dependencies. | |
virtual void | getNodes (SBNodeIndexer &nodeIndexer, const SBNodePredicate &selectionPredicate=SBDDataGraphNode::All(), const SBNodePredicate &visitPredicate=SBDDataGraphNode::All(), bool includeDependencies=false) const |
Returns some nodes. | |
Utility functions | |
void | getWater (SBNodeIndexer &resultNodeIndexer) const |
Finds water nodes in the structural model. More... | |
SBQuantity::mass | getMolecularWeight () const |
Returns the cumulative molecular weight of atoms in the structural model. More... | |
static void | getWater (SBNodeIndexer &resultNodeIndexer, const SBNodeIndexer &nodeIndexer) |
Finds water nodes in the nodeIndexer . More... | |
static SBQuantity::mass | getMolecularWeight (const SBNodeIndexer &nodeIndexer) |
Returns the cumulative molecular weight of atoms in nodeIndexer . More... | |
static SBPosition3 | getCentroid (const SBNodeIndexer &nodeIndexer) |
Returns the centroid (the geometric center) of atoms in nodeIndexer . More... | |
static SBPosition3 | getCenterOfMass (const SBNodeIndexer &nodeIndexer) |
Returns the center of mass of atoms in nodeIndexer . More... | |
static double | getAsphericity (const SBNodeIndexer &nodeIndexer) |
Returns the asphericity parameter computed based on positions of atoms in nodeIndexer . The asphericity parameter changes in the [0, 1] interval: 0 - a sphere, 1 - a rod. More... | |
static SBQuantity::length | getRadiusOfGyration (const SBNodeIndexer &nodeIndexer) |
Returns the radius of gyration based on atoms in nodeIndexer . More... | |
static SBQuantity::squareLength | getSolventAccessibleSurfaceArea (const SBNodeIndexer &nodeIndexer, const SBQuantity::length &probeRadius, const unsigned int numberOfPointsOnSphere) |
Returns the solvent-accessible surface area (SASA) based on atoms in nodeIndexer with the probe radius probeRadius , and the number of points on a sphere numberOfPointsOnSphere . More... | |
static bool | isPlanar (const SBNodeIndexer &nodeIndexer) |
Returns true if all atoms in nodeIndexer are in the same plane. More... | |
Visitor functions | |
virtual void | forEachNodeDepthFirst (void(*action)(SBDDataGraphNode *node)) |
Performs an action on each node. | |
virtual void | forEachNodeDepthFirst (SBCClass *object, void(SBCClass::*action)(SBDDataGraphNode *node)) |
Performs an action on each node. | |
Properties | |
bool | hasTitleInformation () const |
Returns true when the model's title information is set. | |
std::string const & | getTitleInformation () const |
Returns the model's title information. | |
void | setTitleInformation (const std::string &info) |
Sets the model's title information. | |
void | clearTitleInformation () |
Clears the model's title information. | |
bool | hasPrimaryStructureInformation () const |
Returns true when the model's primary structure information is set. | |
std::string const & | getPrimaryStructureInformation () const |
Returns the model's primary structure information. | |
void | setPrimaryStructureInformation (const std::string &info) |
Sets the model's primary structure information. | |
void | clearPrimaryStructureInformation () |
Clears the model's primary structure information. | |
bool | hasHeterogenInformation () const |
Returns true when the model's heterogen information is set. | |
std::string const & | getHeterogenInformation () const |
Returns the model's heterogen information. | |
void | setHeterogenInformation (const std::string &info) |
Sets the model's heterogen information. | |
void | clearHeterogenInformation () |
Clears the model's heterogen information. | |
bool | hasSecondaryStructureInformation () const |
Returns true when the model's secondary structure information is set. | |
std::string const & | getSecondaryStructureInformation () const |
Returns the model's secondary structure information. | |
void | setSecondaryStructureInformation (const std::string &info) |
Sets the model's secondary structure information. | |
void | clearSecondaryStructureInformation () |
Clears the model's secondary structure information. | |
bool | hasConnectivityAnnotationInformation () const |
Returns true when the model's connectivity annotation information is set. | |
std::string const & | getConnectivityAnnotationInformation () const |
Returns the model's connectivity annotation information. | |
void | setConnectivityAnnotationInformation (const std::string &info) |
Sets the model's connectivity annotation information. | |
void | clearConnectivityAnnotationInformation () |
Clears the model's connectivity annotation information. | |
bool | hasMiscellaneousInformation () const |
Returns true when the model's miscellaneous information is set. | |
std::string const & | getMiscellaneousInformation () const |
Returns the model's miscellaneous information. | |
void | setMiscellaneousInformation (const std::string &info) |
Sets the model's miscellaneous information. | |
void | clearMiscellaneousInformation () |
Clears the model's miscellaneous information. | |
bool | hasCrystallographicAndTransformationInformation () const |
Returns true when the model's crystallographic and transformation information is set. | |
std::string const & | getCrystallographicAndTransformationInformation () const |
Returns the model's crystallographic and transformation information. | |
void | setCrystallographicAndTransformationInformation (const std::string &info) |
Sets the model's crystallographic and transformation information. | |
void | clearCrystallographicAndTransformationInformation () |
Clears the model's crystallographic and transformation information. | |
Debugging | |
virtual void | print (unsigned int offset=0) const |
Prints debugging information. | |
This function is a convenience function equivalent to getStructuralRoot()->addChild(node, nextNode)
This function is a convenience function equivalent to getStructuralRoot()->canAddChild(node, nextNode)
|
virtual |
This function is a convenience function equivalent to getStructuralRoot()->canAddChildType(nodeType)
Reimplemented from SBDDataGraphNode.
|
virtual |
This function is a convenience function equivalent to getStructuralRoot()->canHaveDescendantType(nodeType)
Reimplemented from SBDDataGraphNode.
void SBMStructuralModel::centerTransform | ( | ) |
Centers the pivot of the transform on the center of mass of the particles contained in the structural model. This changes the transform only, and does not move particles (atoms or pseudo-atoms) belonging to the structural model.
bool SBMStructuralModel::computeSecondaryStructure | ( | bool & | secondaryStructureChanged, |
bool | forceUpdate = false |
||
) |
This functions incrementally computes the secondary structure of the structural model, i.e. both the secondary structure types of residues and geometric descriptors. The function returns true
if and only if everything went well. The boolean secondaryStructureChanged
is modified by the function and is true
if and only if the secondary structure was changed compared to the previous call. Since several objects may call this function, a SecondaryStructureChanged
event is also sent when this is the case, so that all objects may be warned.
|
static |
This function returns the asphericity parameter computed based on positions of atoms in nodeIndexer
. The asphericity parameter changes in the [0, 1] range, where 0 corresponds to a sphere and 1 corresponds to a rod.
If the nodeIndexer
doesn't contain any atoms or their parents then the function returns zero.
|
static |
This function returns the center of mass of atoms from nodeIndexer
The center of mass is computed as follows: R = sqrt(sum(m_i * r_i, i=1..N)/ M) where N is the number of atoms, m_i is the i-th atom's mass, r_i is the i-th atom's position, and M is the total mass of all of the N atoms.
If the nodeIndexer
doesn't contain any atoms or their parents then the function returns the center of coordinates (SBPosition3::zero).
|
static |
This function returns the centroid (the geometric center) of atoms from nodeIndexer
If the nodeIndexer
doesn't contain any atoms or their parents then the function returns the center of coordinates (SBPosition3::zero).
|
virtual |
This function returns the locked flag of the structural model. When the structural model is locked, its geometry (the atoms positions), topology (the bonds) and identities (node names and indices) cannot be edited by the user. However, other properties can still be edited. For example, secondary structure information can still be computed, and materials and color schemes can still be applied. Note that some properties that cannot be edited by users can still be edited by developers.
Reimplemented from SBDDataGraphNode.
SBQuantity::mass SBMStructuralModel::getMolecularWeight | ( | ) | const |
This function returns the cumulative molecular weight of atoms in the structural model.
If the structural model doesn't contain any atoms then the function returns zero.
|
static |
This function returns the cumulative molecular weight of atoms in nodeIndexer
If the nodeIndexer
doesn't contain any atoms or their parents then the function returns zero.
|
static |
This function returns the radius of gyration computed based on the atoms from nodeIndexer
The radius of gyration is computed as follows: Rg = sqrt(sum(m_i * (r_i - r_c)^2, i=1..N)/ M) where N is the number of atoms, m_i is the mass of i-th atom, r_i is the i-th atom's position, r_c is the center of mass of all N atoms, M is the total mass of all of the N atoms.
If the nodeIndexer
doesn't contain any atoms or their parents then the function returns zero.
|
static |
This function returns the solvent-accessible surface area (SASA) based on atoms in nodeIndexer
with the probe radius probeRadius
, and the number of points on a sphere numberOfPointsOnSphere
.
If the nodeIndexer
doesn't contain any atoms or their parents then the function returns zero.
SBMStructuralModelNodeRoot * SBMStructuralModel::getStructuralRoot | ( | ) | const |
This function returns a pointer to the structural root of the structural model. This root is a structural node, and can be used as a convenience root for e.g. recursive algorithms that operate on structural nodes (such algorithms could not work on the structural model itself, since the SBMStructuralModel class does not derive from SBMStructuralModelNode).
void SBMStructuralModel::getWater | ( | SBNodeIndexer & | resultNodeIndexer | ) | const |
This function finds water nodes in the structural model and adds them to resultNodeIndexer
.
|
static |
This function finds water nodes in the nodeIndexer
and adds them to resultNodeIndexer
The resulting water nodes might include water structural groups and water atoms.
|
virtual |
This function is equivalent to getLockedFlag
Reimplemented from SBDDataGraphNode.
|
static |
This function returns true if all atoms in nodeIndexer
are in the same plane Note that for 3 atoms and less it will always return true
|
virtual |
This function is a convenience function equivalent to getStructuralRoot()->removeChild(node)
|
virtual |
This function sets the locked flag of the structural model.
This function is undoable
Reimplemented from SBDDataGraphNode.