Atom class. More...
#include <openbabel/atom.h>
Public Types | |
enum | StereoFlag |
Public Member Functions | |
OBAtom () | |
virtual | ~OBAtom () |
OBAtom & | operator= (OBAtom &) |
bool | operator== (const OBAtom *other) const |
void | Duplicate (OBAtom *) |
bool | Clear () |
double | GetDistance (int index) |
double | GetDistance (OBAtom *) |
double | GetAngle (int b, int c) |
double | GetAngle (OBAtom *b, OBAtom *c) |
virtual OBBase * | DoTransformations (const std::map< std::string, std::string > *, OBConversion *) |
template<class T > | |
T * | CastAndClear (bool clear=true) |
virtual const char * | GetTitle (bool replaceNewlines=true) const |
virtual void | SetTitle (const char *) |
Methods to set atomic information | |
void | SetIdx (int idx) |
void | SetId (unsigned long id) |
void | SetHyb (int hyb) |
void | SetAtomicNum (int atomicnum) |
void | SetIsotope (unsigned int iso) |
void | SetImplicitValence (int val) |
void | IncrementImplicitValence () |
void | DecrementImplicitValence () |
void | SetFormalCharge (int fcharge) |
void | SetSpinMultiplicity (short spin) |
void | SetType (const char *type) |
void | SetType (const std::string &type) |
void | SetPartialCharge (double pcharge) |
void | SetVector (const vector3 &v) |
void | SetVector (const double x, const double y, const double z) |
void | SetCoordPtr (double **c) |
void | SetVector () |
void | SetResidue (OBResidue *res) |
void | SetParent (OBMol *ptr) |
void | SetAromatic () |
void | UnsetAromatic () |
void | SetClockwiseStereo () |
void | SetAntiClockwiseStereo () |
void | SetPositiveStereo () |
void | SetNegativeStereo () |
void | UnsetStereo () |
void | SetInRing () |
void | SetChiral () |
void | ClearCoordPtr () |
Methods to retrieve atomic information | |
int | GetFormalCharge () const |
unsigned int | GetAtomicNum () const |
unsigned short int | GetIsotope () const |
int | GetSpinMultiplicity () const |
double | GetAtomicMass () const |
double | GetExactMass () const |
unsigned int | GetIdx () const |
unsigned int | GetIndex () const |
unsigned long | GetId () const |
unsigned int | GetCoordinateIdx () const |
unsigned int | GetCIdx () const |
unsigned int | GetValence () const |
unsigned int | GetHyb () const |
unsigned int | GetImplicitValence () const |
unsigned int | GetHvyValence () const |
unsigned int | GetHeteroValence () const |
char * | GetType () |
double | GetX () const |
double | GetY () const |
double | GetZ () const |
double | x () const |
double | y () const |
double | z () const |
double * | GetCoordinate () |
vector3 & | GetVector () |
const vector3 & | GetVector () const |
double | GetPartialCharge () |
OBResidue * | GetResidue () |
OBResidue * | GetResidue (bool perception) |
OBMol * | GetParent () |
bool | GetNewBondVector (vector3 &v, double length) |
OBBond * | GetBond (OBAtom *) |
OBAtom * | GetNextAtom () |
Iterator methods | |
OBBondIterator | BeginBonds () |
OBBondIterator | EndBonds () |
OBBond * | BeginBond (OBBondIterator &i) |
OBBond * | NextBond (OBBondIterator &i) |
OBAtom * | BeginNbrAtom (OBBondIterator &i) |
OBAtom * | NextNbrAtom (OBBondIterator &i) |
Addition of residue/bond info. for an atom | |
void | NewResidue () |
void | AddResidue (OBResidue *res) |
void | DeleteResidue () |
void | AddBond (OBBond *bond) |
void | InsertBond (OBBondIterator &i, OBBond *bond) |
bool | DeleteBond (OBBond *bond) |
void | ClearBond () |
Builder utilities | |
bool | HtoMethyl () |
bool | SetHybAndGeom (int) |
void | ForceNoH () |
bool | HasNoHForced () |
void | ForceImplH () |
bool | HasImplHForced () |
Property information | |
unsigned int | CountFreeOxygens () const |
unsigned int | ImplicitHydrogenCount () const |
unsigned int | ExplicitHydrogenCount (bool ExcludeIsotopes=false) const |
unsigned int | MemberOfRingCount () const |
unsigned int | MemberOfRingSize () const |
unsigned int | CountRingBonds () const |
double | SmallestBondAngle () |
double | AverageBondAngle () |
unsigned int | BOSum () const |
unsigned int | KBOSum () const |
bool | HasResidue () |
bool | IsHydrogen () |
bool | IsHydrogen () const |
bool | IsCarbon () |
bool | IsNitrogen () |
bool | IsOxygen () |
bool | IsSulfur () |
bool | IsPhosphorus () |
bool | IsAromatic () const |
bool | IsInRing () const |
bool | IsInRingSize (int) const |
bool | IsHeteroatom () |
bool | IsNotCorH () |
bool | IsConnected (OBAtom *) |
bool | IsOneThree (OBAtom *) |
bool | IsOneFour (OBAtom *) |
bool | IsCarboxylOxygen () |
bool | IsPhosphateOxygen () |
bool | IsSulfateOxygen () |
bool | IsNitroOxygen () |
bool | IsAmideNitrogen () |
bool | IsPolarHydrogen () |
bool | IsNonPolarHydrogen () |
bool | IsAromaticNOxide () |
bool | IsChiral () |
bool | IsAxial () |
bool | IsClockwise () |
bool | IsAntiClockwise () |
bool | IsPositiveStereo () |
bool | IsNegativeStereo () |
bool | HasChiralitySpecified () |
bool | HasChiralVolume () |
bool | IsHbondAcceptor () |
bool | IsHbondDonor () |
bool | IsHbondDonorH () |
bool | HasAlphaBetaUnsat (bool includePandS=true) |
bool | HasBondOfOrder (unsigned int bo) |
int | CountBondsOfOrder (unsigned int bo) |
bool | HasNonSingleBond () |
bool | HasSingleBond () |
bool | HasDoubleBond () |
bool | HasAromaticBond () |
bool | MatchesSMARTS (const char *) |
Generic data handling methods (via OBGenericData) | |
bool | HasData (const std::string &) |
bool | HasData (const char *) |
bool | HasData (const unsigned int type) |
void | DeleteData (unsigned int type) |
void | DeleteData (OBGenericData *) |
void | DeleteData (std::vector< OBGenericData * > &) |
bool | DeleteData (const std::string &s) |
void | SetData (OBGenericData *d) |
void | CloneData (OBGenericData *d) |
size_t | DataSize () const |
OBGenericData * | GetData (const unsigned int type) |
OBGenericData * | GetData (const std::string &) |
OBGenericData * | GetData (const char *) |
std::vector< OBGenericData * > & | GetData () |
std::vector< OBGenericData * > | GetData (DataOrigin source) |
std::vector< OBGenericData * > | GetAllData (const unsigned int type) |
OBDataIterator | BeginData () |
OBDataIterator | EndData () |
Static Public Member Functions | |
static const char * | ClassDescription () |
Public Attributes | |
bool | Visit |
Protected Member Functions | |
int | GetFlag () const |
void | SetFlag (int flag) |
bool | HasFlag (int flag) |
Protected Attributes | |
unsigned char | _ele |
char | _impval |
char | _type [6] |
short | _fcharge |
unsigned short | _isotope |
short | _spinmultiplicity |
unsigned int | _idx |
OBMol * | _parent |
std::vector< OBBond * > | _vbond |
unsigned int | _cidx |
unsigned short | _hyb |
unsigned short | _flags |
double | _pcharge |
double ** | _c |
vector3 | _v |
OBResidue * | _residue |
unsigned long | _id |
std::vector< OBGenericData * > | _vdata |
Atom class.
To understand the OBAtom class it is important to state a key decision on which the design was based. The OBAtom class not only holds data, but facilitates extraction of data perceived from both the atom and the molecule. This prevents the OBMol class from becoming overly large and complicated.
A number of data extraction methods perform what is called `Lazy Evaluation,' which is essentially on-the-fly evaluation. For example, when an atom is queried as to whether it is cyclic or what it's hybridization state is the information is perceived automatically. The perception of a particular trait is actually performed on the entire molecule the first time it is requested of an atom or bond, and stored for subsequent requests for the same trait of additional atoms or bonds.The OBAtom class is similar to OBMol and the whole of Open Babel in that data access and modification is done through Get and Set methods.
The following code demonstrates how to print out the atom numbers, element numbers, and coordinates of a molecule:
OBMol mol; FOR_ATOMS_OF_MOL(atom, mol) { cout << atom->GetIdx() << ` `; cout << atom->GetAtomicNum() << ` `; cout << atom->GetVector() << endl; }
A number of the property member functions indicate that atoms have some knowledge of their covalently attached neighbor atoms. Bonding information is partly redundant within a molecule in that an OBMol has a complete list of bonds in a molecule, and an OBAtom has a list bonds of which it is a member. The following code demonstrates how an OBAtom uses its bond information to loop over atoms attached to itself:
OBMol mol; OBAtom *atom; atom = mol.GetAtom(1); FOR_NBORS_OF_ATOM(nbr, atom) { cout << "atom #" << atom->GetIdx() << " is attached to atom #" << nbr->GetIdx() << endl; }
should produce an output like
atom #1 is attached to atom #2
enum StereoFlag |
OBAtom | ( | ) |
Constructor.
~OBAtom | ( | ) | [virtual] |
Destructor.
int GetFlag | ( | ) | const [inline, protected] |
Referenced by OBAtom::Duplicate().
void SetFlag | ( | int | flag ) | [inline, protected] |
Sets the bitwise flag
.
bool HasFlag | ( | int | flag ) | [inline, protected] |
flag
bool operator== | ( | const OBAtom * | other ) | const [inline] |
Equivalence.
void Duplicate | ( | OBAtom * | src ) |
Duplicate another atom. Copies all information with the exception of index
Referenced by OBUnitCell::FillUnitCell().
bool Clear | ( | void | ) | [virtual] |
Clear all data. Calls OBBase::Clear() to handle any generic data.
Reimplemented from OBBase.
Referenced by OpenBabel::addFragment().
void SetIdx | ( | int | idx ) | [inline] |
Set atom index (i.e., in an OBMol)
Referenced by OBMol::AddAtom(), OBMol::DeleteAtom(), OBMol::DeleteHydrogen(), OBMol::EndModify(), and OBMol::NewAtom().
void SetId | ( | unsigned long | id ) | [inline] |
Referenced by OBMol::AddAtom(), OBMol::NewAtom(), and OBMol::operator+=().
void SetHyb | ( | int | hyb ) | [inline] |
Set atom hybridization (i.e., 1 = sp, 2 = sp2, 3 = sp3 ...)
Referenced by OBResidueData::AssignBonds(), OBAtomTyper::AssignHyb(), OBBuilder::GetNewBondVector(), and OBMol::PerceiveBondOrders().
void SetAtomicNum | ( | int | atomicnum ) | [inline] |
Set atomic number.
Referenced by OpenBabel::addFragment(), OBMol::AddHydrogens(), OBChemTsfm::Apply(), AliasData::Expand(), OBAtom::HtoMethyl(), and OBAtom::SetHybAndGeom().
void SetIsotope | ( | unsigned int | iso ) |
Set isotope number (actual atomic weight is tabulated automatically, 0 = most abundant)
Referenced by AliasData::Expand().
void SetImplicitValence | ( | int | val ) | [inline] |
Set the implicit valence to val
.
Referenced by OBAtomTyper::AssignImplicitValence().
void IncrementImplicitValence | ( | ) | [inline] |
Increase the implicit valence by one.
Referenced by OpenBabel::ExpandKekule().
void DecrementImplicitValence | ( | ) | [inline] |
Decrease the implicit valence by one.
Referenced by OpenBabel::ExpandKekule().
void SetFormalCharge | ( | int | fcharge ) | [inline] |
Set the formal charge of the atom to fcharge
.
Referenced by OpenBabel::addFragment(), OBChemTsfm::Apply(), OBResidueData::AssignBonds(), OBMol::ConvertDativeBonds(), OpenBabel::ExpandKekule(), and OBMol::NewPerceiveKekuleBonds().
void SetSpinMultiplicity | ( | short | spin ) | [inline] |
Set the atomic spin to spin
. See _spinmultiplicity.
Referenced by OpenBabel::addFragment(), and OBMol::AssignSpinMultiplicity().
void SetType | ( | const char * | type ) |
Set the atomic type symbol (see OBTypeTable and OBAtomTyper for more)
Referenced by OBMol::AddHydrogens(), OBResidueData::AssignBonds(), OBAtomTyper::AssignTypes(), OBForceField::GetGrid(), OBAtom::HtoMethyl(), and OBAtom::SetHybAndGeom().
void SetType | ( | const std::string & | type ) |
Set the atomic type symbol (see OBTypeTable and OBAtomTyper for more)
void SetPartialCharge | ( | double | pcharge ) | [inline] |
Set the partial charge to pcharge
.
Referenced by OBGastChrg::AssignPartialCharges(), OBPhModel::AssignSeedPartialCharge(), OBForceField::GetGrid(), and OBAtom::GetPartialCharge().
void SetVector | ( | const vector3 & | v ) |
Set the coordinate vector for this atom to v
as a vector3.
Referenced by OpenBabel::addFragment(), OBMol::Align(), OpenBabel::ApplyRotMatToBond(), OBMol::BeginModify(), OBBuilder::Build(), OpenBabel::CalcSignedVolume(), OBMol::Center(), OBBuilder::Connect(), OBDepict::DrawMolecule(), OBUnitCell::FillUnitCell(), OpenBabel::generateDiagram(), OBForceField::GetCoordinates(), OpenBabel::groupRedraw(), OBAtom::HtoMethyl(), OpenBabel::InternalToCartesian(), OBForceField::LineSearch(), OBForceField::NumericalDerivative(), OBForceField::NumericalSecondDerivative(), OBForceField::SetConformers(), OBForceField::SetCoordinates(), OBAtom::SetHybAndGeom(), OBBond::SetLength(), OBForceField::ValidateConjugateGradients(), OBForceField::ValidateLineSearch(), and OBForceField::ValidateSteepestDescent().
void SetVector | ( | const double | x, |
const double | y, | ||
const double | z | ||
) |
Set the coordinate vector for this atom based on x
y
& z
.
void SetCoordPtr | ( | double ** | c ) | [inline] |
Set the position of this atom from a pointer-driven array of coordinates.
Referenced by OBMol::AddHydrogens(), OBMol::ConnectTheDots(), OBMol::EndModify(), and OBMol::SetCoordinates().
void SetVector | ( | ) |
Set the position of this atom based on the internal pointer array (i.e. from SetCoordPtr() )
void SetResidue | ( | OBResidue * | res ) | [inline] |
Attach an OBResidue res
as containing this atom.
Referenced by OBResidue::AddAtom(), OBMol::AddHydrogens(), and OBResidue::RemoveAtom().
void SetParent | ( | OBMol * | ptr ) | [inline] |
Attach an OBMol ptr
as the parent container for this atom.
Referenced by OBMol::AddAtom(), and OBMol::NewAtom().
void SetAromatic | ( | ) | [inline] |
Mark atom as being aromatic.
Referenced by OBMol::AddBond(), OBAromaticTyper::CheckAromaticity(), and OBAromaticTyper::TraverseCycle().
void UnsetAromatic | ( | ) | [inline] |
Clear aromatic information from the atom.
Referenced by OBAromaticTyper::AssignAromaticFlags().
void SetClockwiseStereo | ( | ) | [inline] |
Referenced by OpenBabel::CorrectChirality().
void SetAntiClockwiseStereo | ( | ) | [inline] |
Referenced by OpenBabel::CorrectChirality().
void SetPositiveStereo | ( | ) | [inline] |
void SetNegativeStereo | ( | ) | [inline] |
void UnsetStereo | ( | ) | [inline] |
Referenced by OpenBabel::CorrectChirality().
void SetInRing | ( | ) | [inline] |
Mark an atom as belonging to at least one ring.
void SetChiral | ( | ) | [inline] |
Mark an atom as being chiral with unknown stereochemistry.
void ClearCoordPtr | ( | ) | [inline] |
Clear the internal coordinate pointer.
Referenced by OBMol::BeginModify(), and OBMol::ConnectTheDots().
int GetFormalCharge | ( | ) | const [inline] |
Referenced by OpenBabel::alternate(), OBMol::ConvertDativeBonds(), OBDepict::DrawMolecule(), OBAtom::Duplicate(), OBSmartsMatcher::EvalAtomExpr(), OpenBabel::ExpandKekule(), OBChargeModel::FillChargeVectors(), OBMol::getorden(), OBMol::GetTotalCharge(), OBMol::NewPerceiveKekuleBonds(), OBMol::PerceiveKekuleBonds(), and OBMol::start_kekulize().
unsigned int GetAtomicNum | ( | ) | const [inline] |
Referenced by OBMol::AddHydrogens(), OpenBabel::alternate(), OBAromaticTyper::AssignAromaticFlags(), OBMol::ConnectTheDots(), OpenBabel::construct_g_matrix(), OBDepict::DrawMolecule(), OBAtom::Duplicate(), OBSmartsMatcher::EvalAtomExpr(), OpenBabel::GetCorrectedBondVector(), OBBond::GetEquibLength(), OBMol::GetGIVector(), OBMol::getorden(), OBAtom::HtoMethyl(), OpenBabel::InternalToCartesian(), OpenBabel::isFerroceneBond(), OBAtom::IsNonPolarHydrogen(), OBAtom::IsPolarHydrogen(), OpenBabel::isPotentialAromaticAtom(), OBQueryAtom::Matches(), OBMol::PerceiveBondOrders(), OBMol::PerceiveKekuleBonds(), and OBAtom::SetHybAndGeom().
unsigned short int GetIsotope | ( | ) | const [inline] |
Referenced by OBDepict::DrawMolecule(), OBAtom::Duplicate(), OBSmartsMatcher::EvalAtomExpr(), and OBAtom::ExplicitHydrogenCount().
int GetSpinMultiplicity | ( | ) | const [inline] |
Referenced by OBMol::AddHydrogens(), OpenBabel::alternate(), OBDepict::DrawMolecule(), OBAtom::Duplicate(), and OBMol::GetTotalSpinMultiplicity().
double GetAtomicMass | ( | ) | const |
Referenced by OBMol::GetMolWt(), and OBMol::ToInertialFrame().
double GetExactMass | ( | ) | const |
Referenced by OBMol::GetExactMass().
unsigned int GetIdx | ( | ) | const [inline] |
Referenced by OBMol::AddAtom(), OBMol::AddHydrogens(), OBMol::Align(), OpenBabel::ApplyRotMatToBond(), OBAromaticTyper::AssignAromaticFlags(), OBResidueData::AssignBonds(), OBGastChrg::AssignPartialCharges(), OBBuilder::Build(), OpenBabel::BuildOBRTreeVector(), OpenBabel::CalcSignedVolume(), OpenBabel::CartesianToInternal(), OBAromaticTyper::CheckAromaticity(), OBMol::ConnectTheDots(), OBMol::ContigFragList(), OBBuilder::CorrectStereoAtoms(), OpenBabel::CreateNewClassVector(), OBMolAtomBFSIter::CurrentDepth(), OBMol::DeleteAtom(), OBMol::DeleteHydrogen(), OBSmartsMatcher::EvalAtomExpr(), OBAromaticTyper::ExcludeSmallRing(), OpenBabel::expand_cycle(), OpenBabel::expand_kekulize_lssr(), OBMol::expandcycle(), OpenBabel::ExpandKekule(), OpenBabel::expandKekulize(), OBSmartsMatcher::FastSingleMatch(), OBMol::FindChildren(), OBMol::FindLargestFragment(), OBRTree::GetAtomIdx(), OpenBabel::GetDFFVector(), OpenBabel::getFragment(), OBBuilder::GetFragment(), OBForceField::GetGradient(), OBForceField::GetGrid(), OBMol::GetGTDVector(), OBRotorRules::GetRotorIncrements(), OpenBabel::has_leftover_electrons(), OBGrid::Init(), OpenBabel::InternalToCartesian(), OBBond::IsClosure(), OBRotorList::IsFixedBond(), OBForceField::IsInSameRing(), OBRing::IsMember(), OBBuilder::IsSpiroAtom(), OpenBabel::KekulePropagate(), OBSSMatch::Match(), OBAtom::MatchesSMARTS(), OBMol::NewAtom(), OBMol::NewPerceiveKekuleBonds(), OBMolAtomBFSIter::OBMolAtomBFSIter(), OBMolAtomDFSIter::OBMolAtomDFSIter(), OBMolPairIter::OBMolPairIter(), OBMolPairIter::operator++(), OBMolAtomBFSIter::operator++(), OBMolAtomDFSIter::operator++(), OBMol::operator=(), OBAtom::operator=(), OBAtom::operator==(), OBMol::PerceiveKekuleBonds(), OBAromaticTyper::PropagatePotentialAromatic(), OBMol::RenumberAtoms(), OBAromaticTyper::SelectRootAtoms(), OBRotorList::SetEvalAtoms(), OBAtom::SetHybAndGeom(), OBBond::SetLength(), OBMol::SetTorsion(), OBProxGrid::Setup(), OBSmartsMatcher::SetupAtomMatchTable(), OBMol::start_kekulize(), and OBAromaticTyper::TraverseCycle().
unsigned int GetIndex | ( | ) | const [inline] |
Referenced by OpenBabel::GetAtomSymClass().
unsigned long GetId | ( | ) | const [inline] |
unsigned int GetCoordinateIdx | ( | ) | const [inline] |
unsigned int GetCIdx | ( | ) | const [inline] |
Referenced by OBMol::DeleteHydrogen(), OpenBabel::SetRotorToAngle(), and OBMol::SetTorsion().
unsigned int GetValence | ( | ) | const [inline] |
Referenced by OBMol::AddBond(), OBMol::AddHydrogens(), OBResidueData::AssignBonds(), OBAtomTyper::AssignImplicitValence(), OBMol::ConnectTheDots(), OpenBabel::construct_c_matrix(), OpenBabel::construct_g_matrix(), OBDepict::DrawMolecule(), OBSmartsMatcher::EvalAtomExpr(), OBBuilder::GetNewBondVector(), OBMol::getorden(), OBRing::GetRootAtom(), OpenBabel::isFerroceneBond(), OBMol::NewPerceiveKekuleBonds(), OBMol::PerceiveBondOrders(), and OBMol::start_kekulize().
unsigned int GetHyb | ( | ) | const |
Referenced by OBMol::AddHydrogens(), OBAromaticTyper::AssignAromaticFlags(), OBBuilder::Connect(), OpenBabel::construct_g_matrix(), OBAtom::Duplicate(), OBSmartsMatcher::EvalAtomExpr(), OpenBabel::GetCorrectedBondVector(), OBBond::GetEquibLength(), OBBuilder::GetNewBondVector(), OBRotorRules::GetRotorIncrements(), OBAtom::HtoMethyl(), OBAtom::IsAxial(), OBMol::PerceiveBondOrders(), and OBAtom::SetHybAndGeom().
unsigned int GetImplicitValence | ( | ) | const |
Referenced by OBMol::AddHydrogens(), OBAromaticTyper::AssignAromaticFlags(), OBAtomTyper::AssignImplicitValence(), OBMol::AssignSpinMultiplicity(), OBSmartsMatcher::EvalAtomExpr(), OpenBabel::ExpandKekule(), OpenBabel::GetCurrentValence(), OBMol::GetGIVector(), OBBond::IsAmide(), OBBond::IsPrimaryAmide(), OBBond::IsSecondaryAmide(), OBBond::IsTertiaryAmide(), and OpenBabel::ValenceSum().
unsigned int GetHvyValence | ( | ) | const |
Referenced by OBMol::AssignSpinMultiplicity(), OpenBabel::CalcSignedVolume(), OBAtom::CountFreeOxygens(), OpenBabel::ExpandKekule(), OBMol::GetGIVector(), OBMol::IsChiral(), OpenBabel::isPotentialAromaticAtom(), OBBond::IsPrimaryAmide(), OBBond::IsSecondaryAmide(), OBBuilder::IsSpiroAtom(), and OBBond::IsTertiaryAmide().
unsigned int GetHeteroValence | ( | ) | const |
char * GetType | ( | ) |
Referenced by OBAtomTyper::AssignTypes(), and OBAtom::Duplicate().
double GetX | ( | ) | const [inline] |
Referenced by OBDepict::DrawMolecule(), OBBond::GetLength(), and OBGrid::Init().
double GetY | ( | ) | const [inline] |
Referenced by OBDepict::DrawMolecule(), OBBond::GetLength(), and OBGrid::Init().
double GetZ | ( | ) | const [inline] |
Referenced by OBBond::GetLength(), and OBGrid::Init().
double x | ( | ) | const [inline] |
Referenced by OBMol::Center(), OBMol::Has2D(), OBMol::Has3D(), OBMol::ToInertialFrame(), OBForceField::ValidateConjugateGradients(), OBForceField::ValidateLineSearch(), and OBForceField::ValidateSteepestDescent().
double y | ( | ) | const [inline] |
Referenced by OBMol::Center(), OBMol::Has2D(), OBMol::Has3D(), OBMol::ToInertialFrame(), OBForceField::ValidateConjugateGradients(), OBForceField::ValidateLineSearch(), and OBForceField::ValidateSteepestDescent().
double z | ( | ) | const [inline] |
Referenced by OBMol::Center(), OBMol::Has2D(), OBMol::Has3D(), OBMol::ToInertialFrame(), and OBForceField::ValidateConjugateGradients().
double* GetCoordinate | ( | ) | [inline] |
See SetCoordPtr() for more. If no coordinate pointer is used (e.g., only vector3), NULL will be returned.
Referenced by OBForceField::GetGrid(), and OBForceField::UpdatePairsSimple().
vector3 & GetVector | ( | ) |
Referenced by OBMol::Align(), OpenBabel::ApplyRotMatToBond(), OBAtom::AverageBondAngle(), OpenBabel::CalcSignedVolume(), OpenBabel::CartesianToInternal(), OBMol::Center(), OBBuilder::Connect(), OBMol::ConnectTheDots(), OBDepict::DrawMolecule(), OBAtom::Duplicate(), OBMol::EndModify(), OBAtom::GetAngle(), OBAtom::GetDistance(), OpenBabel::GetLabelAlignment(), OBBuilder::GetNewBondVector(), OBMol::GetTorsion(), OBMol::HasNonZeroCoords(), OBBond::IsDoubleBondGeometry(), OBForceField::LineSearch(), OBForceField::NumericalDerivative(), OBForceField::NumericalSecondDerivative(), OBAtom::SetHybAndGeom(), OBBond::SetLength(), OBAlign::SetRefMol(), OBAlign::SetTargetMol(), OBAtom::SmallestBondAngle(), OBBuilder::Swap(), and OBForceField::ValidateLineSearch().
double GetPartialCharge | ( | ) |
Referenced by OBGastChrg::AssignPartialCharges(), OBAtom::Duplicate(), OBChargeModel::FillChargeVectors(), and OBForceField::GetPartialCharges().
OBResidue * GetResidue | ( | ) |
Referenced by OBMol::AddHydrogens(), OBResidueData::AssignBonds(), and OBResidue::GetBonds().
OBResidue * GetResidue | ( | bool | perception ) |
perception | implies whether chain perception should occur |
OBMol* GetParent | ( | ) | [inline] |
Referenced by OpenBabel::addNbrs(), OpenBabel::BuildOBRTreeVector(), OBSmartsMatcher::EvalAtomExpr(), OpenBabel::GetAtomSymClass(), OBBuilder::GetNewBondVector(), and OBBond::SetLength().
bool GetNewBondVector | ( | vector3 & | v, |
double | length | ||
) |
Create a vector for a new bond from this atom, with length given by the supplied parameter
Referenced by OBBondTyper::AssignFunctionalGroupBonds(), OBBuilder::Build(), OpenBabel::CorrectBadResonanceForm(), OBBuilder::GetNewBondVector(), and OBMol::PerceiveBondOrders().
OBAtom * GetNextAtom | ( | ) |
OBBondIterator BeginBonds | ( | ) | [inline] |
Referenced by OBResidueData::AssignBonds().
OBBondIterator EndBonds | ( | ) | [inline] |
OBBond * BeginBond | ( | OBBondIterator & | i ) |
Set the iterator i
to the beginning of the bonds
Referenced by OBMol::AddHydrogens(), OpenBabel::CalcSignedVolume(), OBMol::ConnectTheDots(), OBMol::ContigFragList(), OBMol::ConvertDativeBonds(), OpenBabel::ExpandKekule(), OBMol::FindLargestFragment(), OpenBabel::FindRings(), OBResidue::GetBonds(), OpenBabel::GetCurrentValence(), OpenBabel::GetDFFVector(), OBMol::GetGTDVector(), OBBond::IsAmide(), OBAtom::IsAmideNitrogen(), OBBond::IsEster(), OBAtom::IsOneFour(), OBAtom::IsOneThree(), OBBond::IsPrimaryAmide(), OBBond::IsSecondaryAmide(), OBBond::IsTertiaryAmide(), OpenBabel::KekulePropagate(), OBMol::NewPerceiveKekuleBonds(), OBAtomBondIter::OBAtomBondIter(), and OpenBabel::ValenceSum().
OBBond * NextBond | ( | OBBondIterator & | i ) |
Increment the iterator i
Referenced by OBMol::AddHydrogens(), OpenBabel::CalcSignedVolume(), OBMol::ConnectTheDots(), OBMol::ContigFragList(), OBMol::ConvertDativeBonds(), OpenBabel::ExpandKekule(), OBMol::FindLargestFragment(), OpenBabel::FindRings(), OBResidue::GetBonds(), OpenBabel::GetCurrentValence(), OpenBabel::GetDFFVector(), OBMol::GetGTDVector(), OBBond::IsAmide(), OBAtom::IsAmideNitrogen(), OBBond::IsEster(), OBAtom::IsOneFour(), OBAtom::IsOneThree(), OBBond::IsPrimaryAmide(), OBBond::IsSecondaryAmide(), OBBond::IsTertiaryAmide(), OpenBabel::KekulePropagate(), OBMol::NewPerceiveKekuleBonds(), OBAtomBondIter::operator++(), and OpenBabel::ValenceSum().
OBAtom * BeginNbrAtom | ( | OBBondIterator & | i ) |
Set the iterator i
to the beginning of the bonds
Referenced by OBMol::AddBond(), OBAtomTyper::AssignTypes(), OpenBabel::BuildOBRTreeVector(), OpenBabel::CalcSignedVolume(), OBAromaticTyper::CheckAromaticity(), OpenBabel::CreateNewClassVector(), OBMol::DeleteAtom(), OBMol::DeleteHydrogen(), OBMol::DeleteHydrogens(), OBAromaticTyper::ExcludeSmallRing(), OpenBabel::expand_cycle(), OBMol::expandcycle(), OpenBabel::ExpandKekule(), OBSmartsMatcher::FastSingleMatch(), OBMol::FindChildren(), OBMol::FindTorsions(), OBMol::GetBond(), OpenBabel::GetLabelAlignment(), OBBuilder::GetNewBondVector(), OBRotorRules::GetRotorIncrements(), OBAtom::HasAlphaBetaUnsat(), OBAtom::IsAxial(), OBBond::IsClosure(), OBBond::IsDoubleBondGeometry(), OBRotorList::IsFixedBond(), OpenBabel::KekulePropagate(), OBSSMatch::Match(), OBMol::NewPerceiveKekuleBonds(), OBAtomAtomIter::OBAtomAtomIter(), OBMolAtomBFSIter::OBMolAtomBFSIter(), OBMolAtomDFSIter::OBMolAtomDFSIter(), OBMolAtomBFSIter::operator++(), OBMolAtomDFSIter::operator++(), OBMol::PerceiveBondOrders(), OBMol::PerceiveKekuleBonds(), OBAromaticTyper::PropagatePotentialAromatic(), OBAromaticTyper::SelectRootAtoms(), OBRotorList::SetEvalAtoms(), and OBAromaticTyper::TraverseCycle().
OBAtom * NextNbrAtom | ( | OBBondIterator & | i ) |
Increment the iterator i
Referenced by OBAtomTyper::AssignTypes(), OpenBabel::BuildOBRTreeVector(), OpenBabel::CalcSignedVolume(), OBAromaticTyper::CheckAromaticity(), OpenBabel::CreateNewClassVector(), OBMol::DeleteAtom(), OBMol::DeleteHydrogen(), OBMol::DeleteHydrogens(), OBAromaticTyper::ExcludeSmallRing(), OpenBabel::expand_cycle(), OBMol::expandcycle(), OpenBabel::ExpandKekule(), OBAtom::ExplicitHydrogenCount(), OBSmartsMatcher::FastSingleMatch(), OBMol::FindChildren(), OBMol::FindTorsions(), OBMol::GetBond(), OpenBabel::GetLabelAlignment(), OBBuilder::GetNewBondVector(), OBRotorRules::GetRotorIncrements(), OBAtom::HasAlphaBetaUnsat(), OBAtom::IsAxial(), OBBond::IsClosure(), OBRotorList::IsFixedBond(), OpenBabel::KekulePropagate(), OBSSMatch::Match(), OBMol::NewPerceiveKekuleBonds(), OBMolAtomBFSIter::OBMolAtomBFSIter(), OBMolAtomDFSIter::OBMolAtomDFSIter(), OBAtomAtomIter::operator++(), OBMolAtomBFSIter::operator++(), OBMolAtomDFSIter::operator++(), OBMol::PerceiveBondOrders(), OBMol::PerceiveKekuleBonds(), OBAromaticTyper::PropagatePotentialAromatic(), OBAromaticTyper::SelectRootAtoms(), OBRotorList::SetEvalAtoms(), and OBAromaticTyper::TraverseCycle().
double GetDistance | ( | int | index ) |
Referenced by OBBondTyper::AssignFunctionalGroupBonds().
double GetAngle | ( | int | b, |
int | c | ||
) |
Referenced by OBMol::GetAngle().
void NewResidue | ( | ) | [inline] |
If no residue has been set for this atom, create a new one.
void AddResidue | ( | OBResidue * | res ) | [inline] |
Add (set) the residue for this atom.
void DeleteResidue | ( | ) | [inline] |
Delete any residue associated with this atom.
void AddBond | ( | OBBond * | bond ) | [inline] |
Add a bond to the internal list. Does not update the bond.
Referenced by OBMol::AddBond(), and OBBuilder::Connect().
void InsertBond | ( | OBBondIterator & | i, |
OBBond * | bond | ||
) | [inline] |
Insert bond
into the internal list at the position from i
Does not modify the bond.
Referenced by OBMol::AddBond().
bool DeleteBond | ( | OBBond * | bond ) |
Find bond
and remove it from the internal list. Does not update the bond.
void ClearBond | ( | ) | [inline] |
Clear all bonding information in this atom (does not delete them)
bool HtoMethyl | ( | ) |
If this is a hydrogen atom, transform into a methyl group.
bool SetHybAndGeom | ( | int | hyb ) |
Change the hybridization of this atom and modify the geometry accordingly
void ForceNoH | ( | ) | [inline] |
Mark that atom has no hydrogens attached.
bool HasNoHForced | ( | ) | [inline] |
Referenced by OBMol::AssignSpinMultiplicity().
void ForceImplH | ( | ) | [inline] |
Mark that atom is not hydrogen deficient (For SMILES input)
bool HasImplHForced | ( | ) | [inline] |
Referenced by OBMol::AssignSpinMultiplicity().
unsigned int CountFreeOxygens | ( | ) | const |
Referenced by OBAtom::IsCarboxylOxygen(), OBAtom::IsNitroOxygen(), OBAtom::IsPhosphateOxygen(), and OBAtom::IsSulfateOxygen().
unsigned int ImplicitHydrogenCount | ( | ) | const |
Referenced by OBDepict::DrawMolecule(), OBSmartsMatcher::EvalAtomExpr(), OBMol::GetExactMass(), and OBMol::GetMolWt().
unsigned int ExplicitHydrogenCount | ( | bool | ExcludeIsotopes = false ) |
const |
Referenced by OBMol::AssignSpinMultiplicity(), and OBSmartsMatcher::EvalAtomExpr().
unsigned int MemberOfRingCount | ( | ) | const |
Referenced by OBSmartsMatcher::EvalAtomExpr().
unsigned int MemberOfRingSize | ( | ) | const |
unsigned int CountRingBonds | ( | ) | const |
Referenced by OBSmartsMatcher::EvalAtomExpr().
double SmallestBondAngle | ( | ) |
Referenced by OBMol::ConnectTheDots().
double AverageBondAngle | ( | ) |
Referenced by OBBondTyper::AssignFunctionalGroupBonds(), and OBMol::PerceiveBondOrders().
unsigned int BOSum | ( | ) | const |
Referenced by OBMol::ConnectTheDots(), OBRing::GetRootAtom(), and OBMol::PerceiveBondOrders().
unsigned int KBOSum | ( | ) | const |
Referenced by OBSmartsMatcher::EvalAtomExpr().
bool HasResidue | ( | ) | [inline] |
Referenced by OBMol::AddHydrogens().
bool IsHydrogen | ( | ) | [inline] |
Referenced by OBMol::AddHydrogens(), OBResidueData::AssignBonds(), OBGastChrg::AssignPartialCharges(), OBMol::AssignSpinMultiplicity(), OBMol::ConnectTheDots(), OBMol::DeleteAtom(), OBMol::DeleteHydrogen(), OBMol::DeleteHydrogens(), OBDepict::DrawMolecule(), OBAtom::ExplicitHydrogenCount(), OBMol::FindTorsions(), OBMol::GetExactMass(), OBAtom::GetHvyValence(), OBMol::GetMolWt(), OBRotorRules::GetRotorIncrements(), OBStericConformerFilter::IsGood(), OBAtom::IsHbondDonor(), OBMol::NumHvyAtoms(), OBAromaticTyper::SelectRootAtoms(), OBAtom::SetHybAndGeom(), OBAlign::SetRefMol(), and OBAlign::SetTargetMol().
bool IsHydrogen | ( | ) | const [inline] |
bool IsCarbon | ( | ) | [inline] |
Referenced by OBDepict::DrawMolecule(), OBMol::getorden(), OBMol::IsChiral(), OBMol::PerceiveKekuleBonds(), and OpenBabel::potentialAromaticBonds().
bool IsNitrogen | ( | ) | [inline] |
Referenced by OBMol::AddHydrogens(), OpenBabel::ExpandKekule(), OBMol::getorden(), OBRing::GetRootAtom(), OBMol::IsChiral(), OBMol::NewPerceiveKekuleBonds(), OBMol::PerceiveKekuleBonds(), and OBMol::start_kekulize().
bool IsOxygen | ( | ) | [inline] |
Referenced by OBMol::AddHydrogens(), OBResidueData::AssignBonds(), OBBondTyper::AssignFunctionalGroupBonds(), OBAtom::CountFreeOxygens(), OpenBabel::ExpandKekule(), OBMol::getorden(), OBRing::GetRootAtom(), OBAtom::IsAromaticNOxide(), OBMol::NewPerceiveKekuleBonds(), and OBMol::PerceiveKekuleBonds().
bool IsSulfur | ( | ) | [inline] |
Referenced by OBMol::AddHydrogens(), OpenBabel::ExpandKekule(), OBMol::getorden(), OBRing::GetRootAtom(), OBAtom::HasAlphaBetaUnsat(), OBMol::PerceiveKekuleBonds(), and OBMol::start_kekulize().
bool IsPhosphorus | ( | ) | [inline] |
Referenced by OBMol::AddHydrogens(), and OBAtom::HasAlphaBetaUnsat().
bool IsAromatic | ( | ) | const |
Referenced by OBSmartsMatcher::EvalAtomExpr(), OBMol::GetGIVector(), OpenBabel::KekulePropagate(), and OBQueryAtom::Matches().
bool IsInRing | ( | ) | const |
Referenced by OBBuilder::Build(), OBBuilder::CorrectStereoAtoms(), OBSmartsMatcher::EvalAtomExpr(), OBAromaticTyper::ExcludeSmallRing(), OBMol::GetGIVector(), OBAtom::IsAxial(), OBBuilder::IsSpiroAtom(), OBQueryAtom::Matches(), OBMol::PerceiveBondOrders(), and OBAromaticTyper::SelectRootAtoms().
bool IsInRingSize | ( | int | size ) | const |
Referenced by OBSmartsMatcher::EvalAtomExpr(), OpenBabel::findMetalloceneBonds(), and OBMol::getorden().
bool IsHeteroatom | ( | ) |
Referenced by OpenBabel::alternate(), and OBAtom::GetHeteroValence().
bool IsNotCorH | ( | ) |
bool IsConnected | ( | OBAtom * | a1 ) |
Referenced by OBMol::ConnectTheDots(), OpenBabel::construct_g_matrix(), OBAromaticTyper::ExcludeSmallRing(), OBStericConformerFilter::IsGood(), OBMolPairIter::OBMolPairIter(), and OBMolPairIter::operator++().
bool IsOneThree | ( | OBAtom * | a1 ) |
Referenced by OBMolPairIter::OBMolPairIter(), and OBMolPairIter::operator++().
bool IsOneFour | ( | OBAtom * | a1 ) |
bool IsCarboxylOxygen | ( | ) |
Referenced by OBBuilder::GetNewBondVector().
bool IsPhosphateOxygen | ( | ) |
bool IsSulfateOxygen | ( | ) |
bool IsNitroOxygen | ( | ) |
bool IsAmideNitrogen | ( | ) |
Returns true if nitrogen is part of an amide.
Referenced by OBMol::getorden().
bool IsPolarHydrogen | ( | ) |
bool IsNonPolarHydrogen | ( | ) |
Referenced by OBMol::DeleteNonPolarHydrogens().
bool IsAromaticNOxide | ( | ) |
bool IsChiral | ( | ) |
bool IsAxial | ( | ) |
bool IsClockwise | ( | ) | [inline] |
Referenced by OpenBabel::CorrectChirality().
bool IsAntiClockwise | ( | ) | [inline] |
Referenced by OpenBabel::CorrectChirality().
bool IsPositiveStereo | ( | ) | [inline] |
bool IsNegativeStereo | ( | ) | [inline] |
bool HasChiralitySpecified | ( | ) | [inline] |
Referenced by OpenBabel::CorrectChirality().
bool HasChiralVolume | ( | ) | [inline] |
bool IsHbondAcceptor | ( | ) |
bool IsHbondDonor | ( | ) |
Referenced by OBAtom::IsHbondDonorH().
bool IsHbondDonorH | ( | ) |
bool HasAlphaBetaUnsat | ( | bool | includePandS = true ) |
includePandS | Whether to include phosphorus and sulfur neighbors in this determination (or to exclude them) |
This can be sketched as follows
'*'
\
a=b
where a and b are the 'apha' and 'beta' atoms, respectively and '*' indicates the current atom.
bool HasBondOfOrder | ( | unsigned int | bo ) |
bo
Referenced by OBMol::PerceiveBondOrders().
int CountBondsOfOrder | ( | unsigned int | bo ) |
bo
bool HasNonSingleBond | ( | ) |
Referenced by OBMol::PerceiveBondOrders().
bool HasSingleBond | ( | ) | [inline] |
bool HasDoubleBond | ( | ) | [inline] |
Referenced by OBBondTyper::AssignFunctionalGroupBonds().
bool HasAromaticBond | ( | ) | [inline] |
Referenced by OBMol::NewPerceiveKekuleBonds().
bool MatchesSMARTS | ( | const char * | pattern ) |
virtual OBBase* DoTransformations | ( | const std::map< std::string, std::string > * | , |
OBConversion * | |||
) | [inline, virtual, inherited] |
Perform a set of transformations specified by the user
Typically these are program options to filter or modify an object For example, see OBMol::DoTransformations() and OBMol::ClassDescription() Base type does nothing
Reimplemented in OBMol.
static const char* ClassDescription | ( | ) | [inline, static, inherited] |
Reimplemented in OBMol, and OBReaction.
T* CastAndClear | ( | bool | clear = true ) |
[inline, inherited] |
By default clears the object. Called from ReadMolecule of most format classes.
virtual const char* GetTitle | ( | bool | replaceNewlines = true ) |
const [inline, virtual, inherited] |
Base type does nothing Made virtual around r3535 to simplify code which passes around OBBase*.
Reimplemented in OBMol.
Referenced by OBMoleculeFormat::DoOutputOptions().
virtual void SetTitle | ( | const char * | ) | [inline, virtual, inherited] |
Reimplemented in OBMol.
Referenced by OBMoleculeFormat::DoOutputOptions().
bool HasData | ( | const std::string & | s ) | [inherited] |
Referenced by OBDepict::DrawMolecule(), OBForceField::GetAtomTypes(), OBForceField::GetConformers(), OBForceField::GetCoordinates(), OBMol::GetEnergies(), OBMol::GetEnergy(), OBForceField::GetPartialCharges(), OBDescriptor::MatchPairData(), OBMol::operator=(), and OBMol::SetEnergies().
bool HasData | ( | const char * | s ) | [inherited] |
bool HasData | ( | const unsigned int | type ) | [inherited] |
void DeleteData | ( | unsigned int | type ) | [inherited] |
Delete any data matching the given OBGenericDataType.
Referenced by OpenBabel::CanonicalLabels(), OBDescriptor::DeleteProperties(), and OBMol::RenumberAtoms().
void DeleteData | ( | OBGenericData * | gd ) | [inherited] |
Delete the given generic data from this object.
void DeleteData | ( | std::vector< OBGenericData * > & | vg ) | [inherited] |
Delete all of the given generic data from this object.
bool DeleteData | ( | const std::string & | s ) | [inherited] |
Deletes the generic data with the specified attribute, returning false if not found.
void SetData | ( | OBGenericData * | d ) | [inline, inherited] |
Adds a data object; does nothing if d==NULL.
Referenced by OBGastChrg::AssignPartialCharges(), OpenBabel::CalcSignedVolume(), OBForceField::GetAtomTypes(), OBForceField::GetConformers(), OBForceField::GetCoordinates(), OBMol::GetEnergies(), OBMol::GetEnergy(), OBMol::GetNextFragment(), OBForceField::GetPartialCharges(), OBMoleculeFormat::MakeCombinedMolecule(), OBDescriptor::PredictAndSave(), and OBMol::SetEnergies().
void CloneData | ( | OBGenericData * | d ) | [inherited] |
Adds a copy of a data object; does nothing if d == NULL
size_t DataSize | ( | ) | const [inline, inherited] |
OBGenericData * GetData | ( | const unsigned int | type ) | [inherited] |
Referenced by OpenBabel::CalcSignedVolume(), OpenBabel::CorrectChirality(), OBDepict::DrawMolecule(), OBDescriptor::FilterCompare(), OpenBabel::GetAtomSymClass(), OBForceField::GetAtomTypes(), OBForceField::GetConformers(), OBForceField::GetCoordinates(), OBMol::GetNextFragment(), OBForceField::GetPartialCharges(), OBDescriptor::GetValues(), OBMoleculeFormat::MakeCombinedMolecule(), OBMolAngleIter::OBMolAngleIter(), OBMolRingIter::OBMolRingIter(), OBMolTorsionIter::OBMolTorsionIter(), OBMol::operator=(), and OBDescriptor::PredictAndSave().
OBGenericData * GetData | ( | const std::string & | s ) | [inherited] |
OBGenericData * GetData | ( | const char * | s ) | [inherited] |
std::vector<OBGenericData*>& GetData | ( | ) | [inline, inherited] |
Referenced by OBMol::GetEnergies(), OBMol::GetEnergy(), and OBMol::SetEnergies().
std::vector< OBGenericData * > GetData | ( | DataOrigin | source ) | [inherited] |
std::vector< OBGenericData * > GetAllData | ( | const unsigned int | type ) | [inherited] |
Referenced by OpenBabel::CanonicalLabels(), OBBuilder::CorrectStereoAtoms(), and OBBuilder::CorrectStereoBonds().
OBDataIterator BeginData | ( | ) | [inline, inherited] |
Referenced by OBAtom::Duplicate(), OBMoleculeFormat::MakeCombinedMolecule(), and OBMol::operator=().
OBDataIterator EndData | ( | ) | [inline, inherited] |
Referenced by OBAtom::Duplicate(), OBMoleculeFormat::MakeCombinedMolecule(), and OBMol::operator=().
unsigned char _ele [protected] |
atomic number (type unsigned char to minimize space -- allows for 0..255 elements)
char _impval [protected] |
implicit valence
char _type[6] [protected] |
atomic type
short _fcharge [protected] |
formal charge
unsigned short _isotope [protected] |
isotope (0 = most abundant)
short _spinmultiplicity [protected] |
atomic spin, e.g., 2 for radical 1 or 3 for carbene
unsigned int _cidx [protected] |
index into coordinate array
unsigned short _hyb [protected] |
hybridization
unsigned short _flags [protected] |
bitwise flags (e.g. aromaticity)
double _pcharge [protected] |
partial charge
double** _c [protected] |
coordinate array in double*
Referenced by OpenBabel::CartesianToInternal().
unsigned long _id [protected] |
unique id
bool Visit |
Used internally by graph traversal algorithms.
std::vector<OBGenericData*> _vdata [protected, inherited] |
Custom data.
Referenced by OBMol::OBMol().