Package chemaxon.struc
Class RgMolecule
java.lang.Object
chemaxon.struc.MoleculeGraph
chemaxon.struc.Molecule
chemaxon.struc.RgMolecule
- All Implemented Interfaces:
- MoleculeWithValence<MolAtom>,- chemaxon.core.structure.MarkushStructureForBuilder,- chemaxon.core.structure.MoleculeForBuilder,- chemaxon.struc.MObjectContainer,- MTransformable,- chemaxon.struc.RgMoleculeGraphIface,- StereoConstants,- Serializable
@PublicApi
public class RgMolecule
extends Molecule
implements chemaxon.struc.RgMoleculeGraphIface, chemaxon.struc.MObjectContainer, chemaxon.core.structure.MarkushStructureForBuilder
A molecule or reaction containing R-groups.
- Since:
- Marvin 2.6
- See Also:
- 
Nested Class SummaryNested classes/interfaces inherited from class chemaxon.struc.MoleculeGraphMoleculeGraph.ValenceCheckState
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringDefault R-logic range.static final intR-group id mask in R-logic.static final intOther R-group ID's presence flag in R-logic.static final intMask of the other R-group's id in R-logic.static final intOffset of the other R-group's id in R-logic.static final intThe RestH flag in R-logic.Fields inherited from class chemaxon.struc.MoleculeDEFAULT_UNGROUP, RECURSIVE_UNGROUP, RMCLEANUP_FROMSGROUPS, RMCLEANUP_SGROUPATOMS, RMSG_DEFAULT, RMSG_KEEP_ALL, RMSG_KEEP_CHILDREN, RMSG_KEEP_MULTICENTER, RMSG_KEEP_PARENTFields inherited from class chemaxon.struc.MoleculeGraphAROM_AMBIGUOUS, AROM_BASIC, AROM_CHUCKEL, AROM_GENERAL, AROM_LOOSE, AROM_SUBSTRUCTURE, atomCount, AUTO_UNGROUP, bondCount, btab, CACHE_REMOVE_ALL, CACHE_REMOVE_AROMATAMODULE, CACHE_REMOVE_CACHEMEMORY, CACHE_REMOVE_GRINVMODULE, CACHE_REMOVE_PARITYMODULE, CACHE_REMOVE_SSSRMODULE, CACHE_REMOVE_TABS, cacheMemory, ctab, DEAROM_GENERAL, DEAROM_HUCKELCHECK, DEAROM_HUCKELCHECK_EX, DIM_MASK, FRAG_BASIC, FRAG_KEEPING_MULTICENTERS, FRAG_KEEPING_SGROUPS, FRAG_TYPE_COUNT, gearch, GRINV_DONT_STORE, GRINV_NOHYDROGEN, GRINV_OLDSTEREO, GRINV_STEREO, GRINV_USEMAPS, GRINV_VALUE_OPTIONS, grinvCC, INITIAL_CAPACITY, INVALID_LINKNODE_MESSAGE, MIN_RING_SIZE_FOR_TRANS_DB, OMIT_POSTCLEAN, orix, oriy, oriz, parentGraph, propertyContainer, RMCLEANUP_ALL, RMCLEANUP_EDGES, RMCLEANUP_FIXCOMPONENT, RMCLEANUP_MOBJECT, RMCLEANUP_NONE, RMCLEANUP_PARENTDOC, RMCLEANUP_STEREO, superGraph, theAtoms, theBonds, useOnlyFirstAtomInStereoCalculation, VALENCE_CHECK, VALENCE_CHECK_AMBIGUOUSFields inherited from interface chemaxon.struc.StereoConstantsANTI, ATOMSTEREO_EITHER, ATOMSTEREO_MASK, ATOMSTEREO_NONE, ATOMSTEREO_SPECIFIC, CHIRALITY_M, CHIRALITY_MASK, CHIRALITY_P, CHIRALITY_r, CHIRALITY_R, CHIRALITY_s, CHIRALITY_S, CHIRALITYSUPPORT_ALL, CHIRALITYSUPPORT_ALL_POSSIBLE, CHIRALITYSUPPORT_NONE, CHIRALITYSUPPORT_SELECTED, CIS, CIS_TRANS, CTUMASK, CTUNKNOWN, CTUNSPEC, DBS_ALL, DBS_MARKED, DBS_NONE, ENDO, EXO, PARITY_ALLENE, PARITY_EITHER, PARITY_EVEN, PARITY_MASK, PARITY_NONE, PARITY_ODD, PARITY_TETRAHEDRAL, PARITY_UNSPEC, STGRP_ABS, STGRP_AND, STGRP_NONE, STGRP_OR, SYN, TRANS
- 
Constructor SummaryConstructorsConstructorDescriptionCreates a 2 dimensional RgMolecule.RgMolecule(Molecule root) Creates an RgMolecule with the given root structure.
- 
Method SummaryModifier and TypeMethodDescriptionvoidAdds an atom to the root structure.voidAdds a bond to the root structure.protected voidaddAtomToFragment(MolAtom atom) Adds an atom to a fragment.intAdds an R-group member.voidaddRgroupBridgeMember(RgroupBridgeId bridgeId, Molecule m) Adds a definition member to an R-group bridge.Creates an RgMolecule containing R-groups of this object from the 'simplified molecule' object made of 'm'.voidAdds an S-group to this object.voidaromatize(int method) Aromatizes molecule.voidaromatize(int method, boolean checkAmbiguity) Aromatizes molecule.booleancanBeCT(int i2, int i3, boolean grcheck) Determines whether the bond between the specified atoms can be a CIS/TRANS or not.booleanTests whether an object of this class can be a reaction component.voidDeprecated, for removal: This API element is subject to removal in a future version.checkRlogicRange(int index, String range) Checks an R-logic occurrence range string for syntax errors and returns a "normalized" string.protected voidChecks the consistency of S-groups.voidcleanupRemovedRgroupMember(MoleculeGraph m, int f) Clean-up after R-group removal.voidclearForImport(String fmt) Clear the edges vector and the properties.voidclone()Clone the markush structure.voidclonecopy(int[] iatoms, MoleculeGraph g) Copies the specified atoms of this graph to another one.voidMake another molecule identical to this one.voidDeprecated.as of Marvin 6.3.
 Not supported feature.Makes an identical copy of the molecule and its document.booleanChecks if the root structure or an R-group contains the specified node.booleanChecks if the root structure or an R-group contains the specified edge.protected chemaxon.struc.gearch.MoleculeGraphGearchvoidendReuse(int n) End reusing atoms.protected voidAdds all atoms and bonds of the root structure and the R-groups to the specified molecule.findRgroupBridgeId(int index) Finds the correspondingRgroupBridgeIdfor an R-group index.intfindRgroupIndex(int rgid) Finds the index of an R-group based on the R-group number.protected booleanFix a property containing reference to the molecule.voidfuse(MoleculeGraph g, boolean check) Add the atoms and bonds of another molecule.protected voidfuse0(MoleculeGraph graph, boolean check) Add those nodes and edges of a graph that are not already elements.getAtom(int i) Gets a node in the graph union.intGets the number of nodes in the root structure.intgetAtomCount(int atomicNumber) Gets the number of atoms with the given atomic number in the root structure.Returns an iterator over the atoms in this molecule in proper sequence.getBond(int i) Gets an edge in the graph union.intGets the number of edges in the root structure.Returns an iterator over the bonds in this molecule in proper sequence.Gets the bond table of the root structre.Gets the comment of the root molecule.int[][]getCtab()Gets the connection table of the root structure.intgetDependentRgroupDefinition(int rgroupIndex) Gets the R-group definition's index which depends on the referenced R-group definition.intgetFlags()Gets the dimension and chiral flags.Gets the molecular formula in Hill order.Gets a graph containing all the atoms and bonds.intgetLocalParity(int i) Computes the local parity of an atom of the RgMolecule instance based on both the coordinates of the neighboring atoms and the stereo information of the bonds to those.intgetLonePairCount(int i) Gets the number of lone pairs.doublegetMass()Calculates the molecular weight of the molecule.intgetMaxAttachmentPointOrder(int rgroupID) Gets the maximal attachment point order of R-group definition molecules specified by an R-group ID.protected MoleculeGets the simplified molecule object even if there is a parent document with other objects.getName()Gets the name of the root molecule.intintgetParity(int i) Computes the parity of an atom of the RgMolecule instance based on both the coordinates of the neighboring atoms and the stereo information of the bonds to those.intReturns the number of R-group bridges defined in this structure.Returns the list of R-group bridge IDs defined in this structure.getRgroupBridgeMember(RgroupBridgeId bridgeId, int memberIndex) Returns a definition member of the given R-group bridge.intgetRgroupBridgeMemberCount(RgroupBridgeId bridgeId) Returns the number of definition members of the given R-group bridge.intGets the number of R-groups.getRgroupDisplayLabel(int rgroupIndex) intgetRgroupId(int i) Gets the ID of an R-group.intgetRgroupId(RgroupBridgeId bridgeId) intgetRgroupIndex(RgroupBridgeId bridgeId) Returns the index of the ordinary R-group that actually represents the given R-group bridge.getRgroupMember(int i, int j) Gets an R-group member.intgetRgroupMemberCount(int i) Gets the number of R-group members.final MoleculeGraphgetRgroupMemberG(int i, int j) Gets an R-group member.longgetRgroupMemberId(MolAtom node) Gets the unique identifier of the R-group member that contains the specified atom.intgetRlogic(int i) Gets R-logic flags.getRlogicRange(int i) Gets R-logic occurrence range.getRoot()Gets the root structure.final MoleculeGraphgetRootG()Gets the root structure.intgetStereo2(MolBond bond, MolAtom leftAtom, MolAtom rightAtom, boolean performGrinvCheck) Gets cis/trans stereo information for an A1-A2=A3-A4 atom configuration.protected final intGets the number of all "submolecules".protected final voidgetSubGraphs(MoleculeGraph[] arr, int off) Gets all "submolecules".Returns the options for valence checking.booleanTests whether the molecule graph has atom sets.booleanTests whether the molecule graph has atom sets.booleanhasRgroupContainedBy(Set<?> set) Tests whether the molecule has an R-group that is a subset of the specified set of atoms.intGets the index of the specified node in the graph union.intGets the index of the specified edge in the graph union.protected voidinsertNullAtoms(int i, int count) Insert nulls into the atom array.protected voidinsertNullBonds(int i, int count) Insert nulls into the bond array.booleanisAtom()Deprecated.As of Marvin 14.7.7, no replacement.
 Not supported feature.booleanisBond()Deprecated.As of Marvin 14.7.7, no replacement.
 Not supported feature.booleanisEmpty()Ask if the molecule is empty or not.booleanCheck whether the reaction is incomplete or not.booleanisQuery()Indicates if the molecule has query features.booleanChecks if the structure represents a reaction or not.protected booleanR-group molecule objects cannot be real node parents.booleanisRestH(int rgroupIndex) Informs whether the restH condition is set to the referenced R-group definition.booleanTests whether the specified property is a self reference to the molecule.protected voidCopies some properties of this molecule to the other one specified as argument.voidmergeAtoms(MolAtom that, MolAtom a) Deprecated, for removal: This API element is subject to removal in a future version.As of Marvin 6.2, useMergeUtil.mergeAtoms(MolAtom, MolAtom, boolean)instead.Creates a new RgMolecule object.Creates a new SelectionMolecule object appropriate for storing selection from this molecule.Gets the property container.voidRegenerate the edge vectors: remove their elements, then put the edge objects from the nodes into it.voidRemove all the atoms and bonds from the root structure, and from all the R-groups.voidRemove all bonds from the root structure, and from all the R-groups.voidremoveAtom(int i, int cleanupFlags) Removes an atom and its bonds from the root structure.voidremoveAtom(MolAtom node, int cleanupFlags) Removes an atom and its bonds from the root structure and from all the R-groups.protected voidremoveBond(int i, int cleanupFlags) Remove a bond from the root structure.protected voidremoveBond(MolBond edge, int cleanupFlags) Remove a bond from the root structure, and from all the R-groups.voidremoveDependentRgroupDefinition(int rgroupIndex) Removes the dependent R-group definition of the referenced R-group definition.voidremoveObject(MObject mo) voidremoveRestH(int rgroupIndex) Removes the restH condition from an R-group definition.voidremoveRgroup(int rgroupIndex) Removes an R-group.voidremoveRgroupBridge(RgroupBridgeId bridgeId) Removes an R-group bridge.voidremoveRgroupBridgeMember(RgroupBridgeId bridgeId, int memberIndex) Removes a definition member of an R-group bridge.voidremoveRgroupMember(int rgroupIndex, int memberIndex) Removes an R-group definition member.voidremoveRgroupMembers(int rgroupIndex, int[] memberIndexes) Removes R-group members.voidreplaceAtomsWithNewRgroup(SelectionMolecule sel, int rgid) Replaces selected atoms with a new R-group.voidreplaceBond(MolBond olde, MolBond newe) Deprecated.as of Marvin 6.2, may constructs inconsistentMoleculeGraph.reuseAtom(int z, int i) Reuse an atom or create a new one.voidRevalidate coordinate dependent properties.intrgroupIdOf(MolAtom node) Finds the ID of the R-group (the number in R#) that contains the specified atom.intrgroupIndexOf(MolAtom node) Finds the index of the R-group (the number in R#) that contains the specified atom.voidselectAllObjects(boolean s) voidsetAbsStereo(boolean c) Sets the absolute stereoconfiguration flag for the root structure and the R-groups.voidDeprecated.as of Marvin 6.2, may constructs inconsistentMoleculeGraph.voidDeprecated.as of Marvin 6.2, may constructs inconsistentMoleculeGraph.voidsetComment(String s) Sets the comment of the root molecule.voidsetDependentRgroupDefinition(int rgroupIndexIf, int rgroupIndexThen) Sets the dependent R-group definition (rgroupIndexThen) for the referenced R-group definition (rgroupIndexIf).voidsetDim(int d) Sets the dimension of the root structure and the R-groups.protected voidsetFlags(int f) Sets the dimension and chiral flags.protected voidsetFlags(int f, int mask) Sets specified bits in the flags.voidsetInputFormat(String format) Sets the input file format.voidSet the origin of the molecule.voidSets the name of the root molecule.voidsetRestH(int rgroupIndex) Sets the restH condition on an R-group definition.voidsetRlogic(int i, int f) Sets R-logic flags.voidsetRlogicRange(int index, String range) Sets R-logic occurrence range.voidSets the root structure.voidsetSgroupParent(MolAtom a, Sgroup sg, boolean set) Sets or unsets an S-group as a parent of an atom in the root structure or an R-group.voidSets the options for valence checking.voidsortBondsAccordingTo(MolBond[] order) Sort edges in the same order as they appear in the specified array.booleanReset the wedges of the molecule, based on the actual parity information in 2D remove wedges in 3D.protected voidsumConservedQuantities(MolAtom a, int[] atoms, int sign) For internal use only.toString()Overrides Object.toString() to ease debugging.voidtransform(CTransform3D t, boolean incg) Apply a transformation matrix to the atomic coordinates.intunRgroupAtoms(Set<?> set) Ungroup R-groups consisting of the specified atoms and make them be part of root.Methods inherited from class chemaxon.struc.MoleculeaddAtom0, addBond0, addSgroupClones, addSgroupsOf, bondlength, clear, clearExtraLabels, clearProperties, cloneAtoms, clonecopyWithoutSgroups, cloneMolecule, connectOriginalBondsToNewAtom, contractSgroups, contractSgroups, convertToFrags, countExpandableContractableSgroups, countOrderedComponentSgroups, dearomatize, expandSgroups, expandSgroups, exportToBinFormat, exportToFormat, exportToObject, findAllSgroupContaining, findAllSgroupsContaining, findContainingMulticenterSgroup, findContractableSgroup, findExpandableSgroup, findFrags, findFrags, findSgroupContaining, findSgroupOf, findSmallestSgroupContaining, findSmallestSgroupsContaining, getBonds, getEndPosition, getGraphUnionAsSelection, getId, getInputFormat, getProperty, getPropertyCount, getPropertyKey, getPropertyKeys, getPropertyObject, getRootSgroups, getSgroup, getSgroupArray, getSgroupCount, getSgroupIterator, getSgroupLigands, getSimplifiedMolecule, getSortedSgroups, getStartPosition, getVisibleCoords, hasContractedSgroup, hasId, implicitizeHydrogens0, indexOf, isExpandable, isGUIContracted, isSgroup, rearrangeSgroups, removeAllSgroups, removeAtomFromChildren, removeSgroupFromList, removeSgroupsOf, removeSgroupsOf, reparentSgroups, replaceAtom, replaceSgroup, residueSymbolOf, residueTypeOf, setAtom0, setEndPosition, setGUIContracted, setGUIContracted, setId, setProperty, setPropertyObject, setStartPosition, sortSgroupXBonds, toBinFormat, toFormat, toObject, ungroupSgroup, ungroupSgroup, ungroupSgroup, ungroupSgroup, ungroupSgroups, ungroupSgroups, ungroupSgroupsMethods inherited from class chemaxon.struc.MoleculeGraphadd, addAtomsAndBondsTo, addAtomWithoutChangingIt, addBondWithoutChangingIt, addExplicitHydrogens, addExplicitHydrogens, addExplicitLonePairs, addSimpleAtomWithoutChangingIt, adjustMultiChiralFlag, aromatize, aromatize, arrangeComponents, atoms, bonds, calcCenter, calcCenter, calcDehydrogenizedGrinv, calcHeight, calcHybridization, calcOutRect, calcOutRect, calcOutRectCenter, calcOutRectCenter, calcWidth, canBeCT, canBeCT, checkBondConsistency, clean, clean, clearCachedInfo, clonecopyMoleculeGraphWithoutSgroups, contains, createDehydrogenizedReadOnlyGraph, createSmolecule, dearomatize, findAtom, findAtomClone, findBasicFrags, findBond, findComponentIds, findComponentIds, findFrag, findFrag, findFragById, findFrags, findInArray, fixProperties, fuse, getAbbreviationAsMolecule, getAromaticAndAliphaticRings, getAtomArray, getAtomicNumber, getAtomReferenceList, getBondArray, getCharge, getChirality, getCSSR, getCSSRIdxesForAtoms, getDesiredLength, getDesiredLength, getDim, getDocument, getDocumentForChild, getEnclosingCube, getExactMass, getExplicitHcount, getExplicitLonePairCount, getEZStereo, getForefather, getFormalCharge, getFragCount, getFragCount, getFragIds, getFreeAttachmentPoints, getGrinv, getGrinv, getGrinv, getGrinv, getGrinvCC, getGrinvOptions, getImplicitHcount, getImplicitHCount, getLigand, getLigandAtno, getLigandBondType, getLigandCount, getLocation, getLock, getMaxRgroupAttachmentPointOrder, getParent, getParentDocument, getParityType, getPoints, getPossibleAttachmentPoints, getRadicalCount, getSmallestRingSizeForIdx, getSSSR, getSSSRBonds, getSSSRBondsAsBitSet, getSSSRBondSet, getSSSRBondSetInLong, getSSSRIdxesForAtoms, getStereo2, getStereo2, getStereo2, getStereo2, getStereo2, getStereo2, getSubGraphs, getTotalCharge, getValenceCheckState, getValenceProperty, hasExplicitLonePairs, hasExtraLabelSet, hasImplicitH, hasSelfReferringProperty, hasValenceError, hydrogenize, implicitizeHydrogens, implicitizeHydrogens, implicitizeHydrogens, incGrinvCC, incGrinvCC, incGrinvCCOnly, insertAtom, insertBond, insertBondInOrder, isAbsStereo, isAcceptedSpecialLigand, isAtomInRing, isBondParallelWith, isGrinvCCValid, isLargeMolecule, isMolecule, isMultiChiral, isolate, isolate, isOnlyFirstAtomInStereoCalculation, isRing, isRingBond, isSimilarTo, isSymmetric, isValenceCheckEnabled, isValidLinkNode, mergeFrags, moveTo, pack, partialClean, partialClean, partialClean, qpropCheck, regenBtab, regenCtab, regenGearch, removeAtom, removeAtom, removeBond, removeBond, removeExplicitLonePairs, removeIsolatedAtoms, removeIsolatedBonds, resetCtab, resetGrinvInParents, restoreCache, saveCache, setAtomSetSeqs, setBondSetSeqs, setChirality, setChirality, setGrinvCC, setGrinvOptions, setLinkNodeDefaultOuters, setLocalParity, setLocalParity, setParity, setParity, setParity, setSupergraph, setValenceCheckEnabled, setValenceCheckState, smol, transform, updateDim, useOnlyFirstAtomInStereoCalculation, valenceCheck, valenceCheckMethods inherited from class java.lang.Objectequals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface chemaxon.struc.RgMoleculeGraphIfacegetRgroupIndex, getRgroupIndexFromMemberId, getRgroupMemberIndexFromMemberId
- 
Field Details- 
RG_ID_MASKpublic static final int RG_ID_MASKR-group id mask in R-logic.- See Also:
 
- 
RG_ID2_FLAGpublic static final int RG_ID2_FLAGOther R-group ID's presence flag in R-logic.- See Also:
 
- 
RG_ID2_OFFpublic static final int RG_ID2_OFFOffset of the other R-group's id in R-logic.- See Also:
 
- 
RG_ID2_MASKpublic static final int RG_ID2_MASKMask of the other R-group's id in R-logic.- See Also:
 
- 
RG_RESTHpublic static final int RG_RESTHThe RestH flag in R-logic.- See Also:
 
- 
DEFAULT_RLOGIC_RANGEDefault R-logic range. It is an empty string.- See Also:
 
 
- 
- 
Constructor Details- 
RgMoleculepublic RgMolecule()Creates a 2 dimensional RgMolecule.
- 
RgMoleculeCreates an RgMolecule with the given root structure.
 
- 
- 
Method Details- 
setRootSets the root structure.- Parameters:
- mol- the root structure
 
- 
getStereo2Description copied from class:MoleculeGraphGets cis/trans stereo information for an A1-A2=A3-A4 atom configuration. Calculates the stereo information if the molecule is 2D or 3D, reports previously set information if it is 0D. Atoms A2 and A3 are atom1 and atom2 of the specified bond. Both (A2, A3) = (atom1, atom2) and (A2, A3) = (atom2, atom1) works. If A1 or A4 is null 0 is returned. Not checking if the bond is in small ring (MoleculeGraph.MIN_RING_SIZE_FOR_TRANS_DB(so chemically the double bond with its ring ligand can be cis only), but due to the perspective depiction in two dimension the double bond ligand arrangement looks trans. In this case the chemically incorrect trans returned.See MoleculeGraph.getStereo2(chemaxon.struc.MolAtom, int, int, chemaxon.struc.MolAtom)for detailed examples.- Overrides:
- getStereo2in class- MoleculeGraph
- Parameters:
- bond- the bond
- leftAtom- atom A1
- rightAtom- atom A4
- performGrinvCheck- true if check atom equivalences using graph invariants
- Returns:
- the stereo flags
- See Also:
 
- 
getRootGets the root structure.- Returns:
- the root
 
- 
getRootGGets the root structure.- Specified by:
- getRootGin interface- chemaxon.struc.RgMoleculeGraphIface
- Returns:
- the root
 
- 
getRgroupCountpublic int getRgroupCount()Gets the number of R-groups.- Specified by:
- getRgroupCountin interface- chemaxon.struc.RgMoleculeGraphIface
- Returns:
- number of R-groups
 
- 
getRgroupMemberCountpublic int getRgroupMemberCount(int i) Gets the number of R-group members.- Specified by:
- getRgroupMemberCountin interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- i- R-group index
- Returns:
- number of R-group members
 
- 
getRgroupMemberGets an R-group member.- Parameters:
- i- R-group index
- j- member index
- Returns:
- the R-group member
 
- 
getRgroupMemberGGets an R-group member.- Specified by:
- getRgroupMemberGin interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- i- R-group index
- j- member index
- Returns:
- the R-group member
 
- 
getRgroupIdpublic int getRgroupId(int i) Gets the ID of an R-group.- Specified by:
- getRgroupIdin interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- i- R-group index
- Returns:
- number between 0 and MolAtom.RGROUP_MAX
 
- 
findRgroupIndexpublic int findRgroupIndex(int rgid) Finds the index of an R-group based on the R-group number.- Specified by:
- findRgroupIndexin interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- rgid- number between 0 and- MolAtom.RGROUP_MAX
- Returns:
- R-group index, or -1 if not found
 
- 
addSgroupAdds an S-group to this object.
- 
addRgroupAdds an R-group member.- Parameters:
- rl- R-logic flags or an R-group ID number between 0 and- MolAtom.RGROUP_MAX
- m- the R-group
- Returns:
- the Rgroup index
 
- 
getRgroupIndexReturns the index of the ordinary R-group that actually represents the given R-group bridge.- Parameters:
- bridgeId- R-group bridge ID
- Returns:
- the index of the ordinary R-group that actually represents the given R-group bridge or -1if the given bridge is not defined in the structure
- Since:
- Marvin 14.10.13
- See Also:
 
- 
getRgroupId- Specified by:
- getRgroupIdin interface- chemaxon.struc.RgMoleculeGraphIface
 
- 
findRgroupBridgeIdFinds the correspondingRgroupBridgeIdfor an R-group index.- Parameters:
- index- the index of an R-group
- Returns:
- the corresponding RgroupBridgeIdif the specified R-group is actually representing an R-group bridge,nullotherwise
- Since:
- Marvin 14.10.13
- See Also:
 
- 
getRgroupBridgeCountpublic int getRgroupBridgeCount()Returns the number of R-group bridges defined in this structure.- Returns:
- the number of R-group bridges
- Since:
- Marvin 14.10.13
- See Also:
 
- 
getRgroupBridgeIdsReturns the list of R-group bridge IDs defined in this structure.- Returns:
- the sorted list of R-group bridge IDs
- Since:
- Marvin 14.10.13
- See Also:
 
- 
getRgroupBridgeMemberCountReturns the number of definition members of the given R-group bridge.- Parameters:
- bridgeId- R-group bridge ID
- Returns:
- the number of definition members of the given R-group bridge or 0if the bridge is not defined in this structure
- Since:
- Marvin 14.10.13
- See Also:
 
- 
getRgroupBridgeMemberReturns a definition member of the given R-group bridge.- Parameters:
- bridgeId- R-group bridge ID
- memberIndex- index of the definition member
- Returns:
- the definition member molecule
- Since:
- Marvin 14.10.13
- See Also:
 
- 
addRgroupBridgeMemberAdds a definition member to an R-group bridge.- Parameters:
- bridgeId- R-group bridge ID
- m- the member molecule
- Since:
- Marvin 14.10.13
- See Also:
 
- 
removeRgroupMemberpublic void removeRgroupMember(int rgroupIndex, int memberIndex) Removes an R-group definition member. If it is the last member to be removed, then the whole R-group definition will be removed. Note: the R-group members are always indexed continuously starting with 0.- Parameters:
- rgroupIndex- the index of the R-group definition
- memberIndex- the index of the member
- Throws:
- IndexOutOfBoundsException- If the definition index is not valid or if the member index is not valid
- Since:
- 5.10 2012.05.10
 
- 
removeRgroupBridgeMemberRemoves a definition member of an R-group bridge. If it is the last member to be removed, then the whole R-group bridge will be removed. Note: the R-group bridge members are always indexed continuously starting with 0.- Parameters:
- bridgeId- R-group bridge ID
- memberIndex- the index of the member
- Since:
- Marvin 14.10.13
- See Also:
 
- 
removeRgroupMemberspublic void removeRgroupMembers(int rgroupIndex, int[] memberIndexes) Removes R-group members. If the last member is removed then the whole R-group definition will be removed. Note: the R-group members are always indexed continuously starting with 0.- Parameters:
- rgroupIndex- the index of the R-group definition
- memberIndexes- the array of the member indexes
- Throws:
- IndexOutOfBoundsException- If the definition index is not valid or if a member index is not valid
- Since:
- 5.10 2012.05.10
 
- 
removeRgrouppublic void removeRgroup(int rgroupIndex) Removes an R-group. Note: the R-group definitions are always indexed continuously starting with 0.- Parameters:
- rgroupIndex- the index of the R-group definition
- Throws:
- IndexOutOfBoundsException- If the definition index is not valid
- Since:
- 5.10 2012.05.10
 
- 
removeRgroupBridgeRemoves an R-group bridge.- Parameters:
- bridgeId- R-group bridge ID
- Since:
- Marvin 14.10.13
- See Also:
 
- 
hasRgroupContainedByTests whether the molecule has an R-group that is a subset of the specified set of atoms.- Parameters:
- set- set of atoms
- Since:
- 5.0, 02/24/2007
 
- 
unRgroupAtomsUngroup R-groups consisting of the specified atoms and make them be part of root.- Parameters:
- set- selected atoms
- Returns:
- the number of ungrouped R-group members
- Since:
- 5.0, 02/24/2007
 
- 
replaceAtomsWithNewRgroupReplaces selected atoms with a new R-group.- Parameters:
- sel- selected atoms
- rgid- R-group ID
- Since:
- 4.0, 06/30/2005
 
- 
getRlogicpublic int getRlogic(int i) Gets R-logic flags.- Specified by:
- getRlogicin interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- i- R-group index
- Returns:
- R-logic flags
- See Also:
 
- 
setRlogicpublic void setRlogic(int i, int f) Sets R-logic flags.- Parameters:
- i- R-group index
- f- R-logic flags
- See Also:
 
- 
getRlogicRangeGets R-logic occurrence range.- Specified by:
- getRlogicRangein interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- i- R-group index
- Returns:
- the occurrence range: By default it is an empty string which means "as drawn".
 
- 
setRlogicRangeSets R-logic occurrence range. If null is given as range, de R-logic range is set to default empty string.- Parameters:
- index- R-group index
- range- range of occurrance.
- Throws:
- IllegalArgumentException- bad occurrence range
 
- 
checkRlogicRangeChecks an R-logic occurrence range string for syntax errors and returns a "normalized" string.- Parameters:
- index- R-group index
- range- range of occurrence
- Returns:
- the normalized occurrence range string
- Throws:
- IllegalArgumentException- bad occurrence range
- Since:
- Marvin 3.4
 
- 
clearForImportClear the edges vector and the properties.- Overrides:
- clearForImportin class- Molecule
- Parameters:
- fmt- input file format. See the text formats on the File Formats in Marvin page.
- See Also:
 
- 
setNameSets the name of the root molecule.
- 
getNameGets the name of the root molecule.
- 
setCommentSets the comment of the root molecule.- Overrides:
- setCommentin class- Molecule
- Parameters:
- s- the comment, empty string or null (null is equivalent to empty string)
 
- 
getCommentGets the comment of the root molecule.- Overrides:
- getCommentin class- Molecule
- Returns:
- the comment or empty string
 
- 
propertiesGets the property container.- Overrides:
- propertiesin class- MoleculeGraph
- Returns:
- the property container
- Since:
- Marvin 4.0, 06/20/2005
 
- 
revalidateCoordDependentPropspublic void revalidateCoordDependentProps()Revalidate coordinate dependent properties. This method should be called at molecule import, after all atomic coordinates and bonds are parsed.- Overrides:
- revalidateCoordDependentPropsin class- MoleculeGraph
- Since:
- Marvin 4.1, 08/03/2006
 
- 
setInputFormatSets the input file format.- Overrides:
- setInputFormatin class- Molecule
- Parameters:
- format- the input format
- See Also:
 
- 
reuseAtomReuse an atom or create a new one. If an atom is reused, all its properties except the corners are initialized.
- 
endReusepublic void endReuse(int n) End reusing atoms.
- 
getCtabpublic int[][] getCtab()Gets the connection table of the root structure. If there is no connection table for the molecule, then create it. ctab[i][j] will be the index of the jth neighbor of the ith atom.- Overrides:
- getCtabin class- MoleculeGraph
- Returns:
- the ctab array
 
- 
getBondTableGets the bond table of the root structre. If there is no bond table for the molecule, then create it. btab.elementAt(i, j) will be the index of the bond between atoms i and j, or -1 if there is no bond.- Overrides:
- getBondTablein class- MoleculeGraph
- Returns:
- the btab array
- Since:
- Marvin 5.4
 
- 
rgroupIdOfFinds the ID of the R-group (the number in R#) that contains the specified atom.- Specified by:
- rgroupIdOfin interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- node- the atom
- Returns:
- the R-group ID if found or -1 if not found
 
- 
rgroupIndexOfFinds the index of the R-group (the number in R#) that contains the specified atom.- Specified by:
- rgroupIndexOfin interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- node- the atom
- Returns:
- the R-group index if found or -1 if not found
 
- 
getRgroupMemberIdGets the unique identifier of the R-group member that contains the specified atom.- Specified by:
- getRgroupMemberIdin interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- node- the atom
- Returns:
- the ID or -1
- Since:
- Marvin 4.1, 11/23/2005
 
- 
setDimpublic void setDim(int d) Sets the dimension of the root structure and the R-groups.
- 
getFlagspublic int getFlags()Gets the dimension and chiral flags.- Overrides:
- getFlagsin class- MoleculeGraph
- Returns:
- the flags
- Since:
- Marvin 5.0.1, 02/10/2008
 
- 
setFlagsprotected void setFlags(int f) Sets the dimension and chiral flags.- Overrides:
- setFlagsin class- MoleculeGraph
- Parameters:
- f- the flags
- Since:
- Marvin 5.0.1, 02/10/2008
- See Also:
 
- 
setFlagsprotected void setFlags(int f, int mask) Sets specified bits in the flags.- Overrides:
- setFlagsin class- MoleculeGraph
- Parameters:
- f- new value of the specified bits
- mask- bits to set
 
- 
setAbsStereopublic void setAbsStereo(boolean c) Sets the absolute stereoconfiguration flag for the root structure and the R-groups.- Overrides:
- setAbsStereoin class- MoleculeGraph
- Parameters:
- c- the absolute stereoconfiguration flag
- See Also:
 
- 
getAtomCountpublic int getAtomCount()Gets the number of nodes in the root structure.- Overrides:
- getAtomCountin class- MoleculeGraph
- Returns:
- number of nodes
 
- 
getAtomCountpublic int getAtomCount(int atomicNumber) Gets the number of atoms with the given atomic number in the root structure. When atomicNumber is 1, sum includes only explicit Hydrogen atoms (but also D and T isotopes).- Overrides:
- getAtomCountin class- MoleculeGraph
- Parameters:
- atomicNumber- atomic number of atoms looked for
- Returns:
- number of atoms with the given atomic number
- Since:
- Marvin 5.5, 27/01/2011
 
- 
getAtomGets a node in the graph union.- Overrides:
- getAtomin class- MoleculeGraph
- Parameters:
- i- node index
- Returns:
- the node object
 
- 
setAtomDeprecated.as of Marvin 6.2, may constructs inconsistentMoleculeGraph. UseMoleculeGraph.removeAtom(MolAtom)andadd(MolAtom)to modify the structure.Sets the node at the specified index in the graph union.- Overrides:
- setAtomin class- MoleculeGraph
- Parameters:
- iu- the atom index
- node- the atom
 
- 
cloneClone the markush structure. Document is not cloned!
- 
cloneMoleculeWithDocumentDescription copied from class:MoleculeMakes an identical copy of the molecule and its document. If the molecule does not have a parent, then copies non-molecular data: graphics objects, electron flows, text boxes, atom and bond sets (color, font and thickness). Otherwise (root, rgroup, component molecule) creates a new document.- Overrides:
- cloneMoleculeWithDocumentin class- Molecule
- Returns:
- the copy
 
- 
addAdds an atom to the root structure.- Overrides:
- addin class- MoleculeGraph
- Parameters:
- node- the atom
 
- 
addAtomToFragmentDescription copied from class:MoleculeAdds an atom to a fragment. S-groups are added only if all atoms are already in the molecule.- Overrides:
- addAtomToFragmentin class- Molecule
- Parameters:
- atom- the atom reference
 
- 
insertNullAtomsprotected void insertNullAtoms(int i, int count) Insert nulls into the atom array.- Overrides:
- insertNullAtomsin class- MoleculeGraph
- Parameters:
- i- starting index
- count- number of new entries
- Since:
- Marvin 3.4
 
- 
insertNullBondsprotected void insertNullBonds(int i, int count) Insert nulls into the bond array.- Overrides:
- insertNullBondsin class- MoleculeGraph
- Parameters:
- i- starting index
- count- number of new entries
- Since:
- Marvin 3.5.5
 
- 
getBondCountpublic int getBondCount()Gets the number of edges in the root structure.- Overrides:
- getBondCountin class- MoleculeGraph
- Returns:
- number of edges
 
- 
getBondGets an edge in the graph union.- Overrides:
- getBondin class- MoleculeGraph
- Parameters:
- i- edge index
- Returns:
- the edge object
 
- 
setBondDeprecated.as of Marvin 6.2, may constructs inconsistentMoleculeGraph. UseMoleculeGraph.removeBond(MolBond)for bond removal andadd(MolBond)for adding a new bond to the molecule.Sets the edge at the specified index in the graph union.- Overrides:
- setBondin class- MoleculeGraph
- Parameters:
- iu- the bond index
- edge- the bond
 
- 
replaceBondDeprecated.as of Marvin 6.2, may constructs inconsistentMoleculeGraph. UseMoleculeGraph.removeBond(MolBond)for bond removal andadd(MolBond)for adding a new bond to the molecule.Replaces an edge by another one.- Overrides:
- replaceBondin class- MoleculeGraph
- Parameters:
- olde- the old edge
- newe- the new edge
- Since:
- Marvin 4.1, 11/24/2005
 
- 
addAdds a bond to the root structure.
- 
indexOfGets the index of the specified node in the graph union.- Overrides:
- indexOfin class- MoleculeGraph
- Parameters:
- node- the node
- Returns:
- the index, or -1 if not found
 
- 
indexOfGets the index of the specified edge in the graph union.- Overrides:
- indexOfin class- MoleculeGraph
- Parameters:
- edge- the edge
- Returns:
- the index, or -1 if not found
- See Also:
 
- 
containsChecks if the root structure or an R-group contains the specified node.
- 
containsChecks if the root structure or an R-group contains the specified edge.- Overrides:
- containsin class- MoleculeGraph
- Parameters:
- edge- the edge object
- Returns:
- true if the graph contains the object, false otherwise
- See Also:
 
- 
isEmptypublic boolean isEmpty()Ask if the molecule is empty or not.
- 
isQuerypublic boolean isQuery()Indicates if the molecule has query features.- Overrides:
- isQueryin class- MoleculeGraph
- Returns:
- trueif there are R-definitions for this molecule or the root has query features.
- Since:
- Marvin 4.1.2 08/30/2006
- See Also:
 
- 
isAtomDeprecated.As of Marvin 14.7.7, no replacement.
 Not supported feature.Determines whether the structure represents only one atom and an arbitrary number of bonds.- Overrides:
- isAtomin class- MoleculeGraph
- Returns:
- truethe root structure represents an atom and there are no R-groups,- falseotherwise
 
- 
isBondDeprecated.As of Marvin 14.7.7, no replacement.
 Not supported feature.Determines whether the structure represents only one bond and zero or two atoms. Determines whether the structure represents only one atom and an arbitrary number of bonds.- Overrides:
- isBondin class- MoleculeGraph
- Returns:
- trueif the root structure represents a bond and there are no R-groups,- falseotherwise
 
- 
isReactionpublic boolean isReaction()Checks if the structure represents a reaction or not.- Overrides:
- isReactionin class- Molecule
- Returns:
- trueif the root structure is a reaction
- Since:
- Marvin 3.0
 
- 
canBeReactionComponentpublic boolean canBeReactionComponent()Tests whether an object of this class can be a reaction component. This implementation returnsfalse, an RgMolecule cannot be a reaction component.- Overrides:
- canBeReactionComponentin class- Molecule
- Returns:
- trueif it can be a reactant, product or agent,- falseif adding it to an- RxnMoleculeis not supported
- Since:
- Marvin 4.1.13, 09/19/2007
 
- 
hasAtomSetpublic boolean hasAtomSet()Tests whether the molecule graph has atom sets.- Overrides:
- hasAtomSetin class- Molecule
- Returns:
- trueif there are atom sets,- falseotherwise
- Since:
- Marvin 4.0, 03/02/2005
 
- 
hasBondSetpublic boolean hasBondSet()Tests whether the molecule graph has atom sets.- Overrides:
- hasBondSetin class- MoleculeGraph
- Returns:
- trueif there are atom sets,- falseotherwise
- Since:
- Marvin 4.0, 03/02/2005
 
- 
getMostSimplifiedMoleculeGets the simplified molecule object even if there is a parent document with other objects.- Overrides:
- getMostSimplifiedMoleculein class- Molecule
- Returns:
- the root structure if there are no R-groups present, thisotherwise
- Since:
- Marvin 4.1.13, 09/20/2007
 
- 
addRgroupsToCreates an RgMolecule containing R-groups of this object from the 'simplified molecule' object made of 'm'.- Parameters:
- m- the simple molecule object
- Returns:
- RgMolecule and the specified molecule as root
- Since:
- Marvin 3.1
 
- 
removeAtomRemoves an atom and its bonds from the root structure and from all the R-groups. This method is for internal use only. UseMoleculeGraph.removeAtom(MolAtom)instead unless you are sure what you are doing.- Overrides:
- removeAtomin class- Molecule
- Parameters:
- node- the atom
- cleanupFlags- extra clean-up methods
- Since:
- Marvin 3.1
- See Also:
 
- 
removeAtompublic void removeAtom(int i, int cleanupFlags) Removes an atom and its bonds from the root structure. This method is for internal use only. UseMoleculeGraph.removeAtom(MolAtom)instead unless you are sure what you are doing.- Overrides:
- removeAtomin class- Molecule
- Parameters:
- i- the atom index
- cleanupFlags- extra clean-up methods
- Since:
- Marvin 3.1
- See Also:
 
- 
cleanupRemovedRgroupMemberClean-up after R-group removal.- Specified by:
- cleanupRemovedRgroupMemberin interface- chemaxon.struc.RgMoleculeGraphIface
- Parameters:
- m- the removed R-group member
- f- clean-up flags
- Since:
- Marvin 4.1, 11/25/2005
 
- 
removeBondRemove a bond from the root structure, and from all the R-groups.- Overrides:
- removeBondin class- Molecule
- Parameters:
- edge- the bond
- cleanupFlags- extra clean-up methods
- Since:
- Marvin 3.1
- See Also:
 
- 
removeBondprotected void removeBond(int i, int cleanupFlags) Remove a bond from the root structure.- Overrides:
- removeBondin class- Molecule
- Parameters:
- i- the bond index
- cleanupFlags- extra clean-up methods
- Since:
- Marvin 3.1
- See Also:
 
- 
removeAllBondspublic void removeAllBonds()Remove all bonds from the root structure, and from all the R-groups.- Overrides:
- removeAllBondsin class- Molecule
 
- 
removeAllpublic void removeAll()Remove all the atoms and bonds from the root structure, and from all the R-groups.
- 
isRealAtomParentprotected boolean isRealAtomParent()R-group molecule objects cannot be real node parents.- Overrides:
- isRealAtomParentin class- MoleculeGraph
- Returns:
- false
- Since:
- Marvin 3.0
 
- 
regenBondspublic void regenBonds()Regenerate the edge vectors: remove their elements, then put the edge objects from the nodes into it.- Overrides:
- regenBondsin class- MoleculeGraph
 
- 
sortBondsAccordingToSort edges in the same order as they appear in the specified array.- Overrides:
- sortBondsAccordingToin class- MoleculeGraph
- Parameters:
- order- the array
- Since:
- Marvin 3.5, 09/02/2004
 
- 
setLocationSet the origin of the molecule. The MolAtom coordinates are relative to this origin.- Overrides:
- setLocationin class- MoleculeGraph
- Parameters:
- p- the location
- See Also:
 
- 
fuseAdd the atoms and bonds of another molecule.- Overrides:
- fusein class- MoleculeGraph
- Parameters:
- g- the other molecule
- check-- trueif a containment check should be performed to ensure that only those nodes and edges are added that are not already elements -- falseif the graph is known to be disjoint from this graph and this check can be safely skipped
- Since:
- Marvin 5.0
 
- 
checkConsistencyDeprecated, for removal: This API element is subject to removal in a future version.As of Marvin 5.7, no replacement.
 Not intended for public use, it was intended only for internal debugging.Checks the internal consistency of the structure. Use this method for debugging.- Overrides:
- checkConsistencyin class- Molecule
- Throws:
- RuntimeException- if inconsistency found
- Since:
- Marvin 5.0, 11/06/2007
 
- 
fuse0Add those nodes and edges of a graph that are not already elements. If the graph is a reaction and the root structure is not a reaction then the root structure will become a reaction determined by the reaction arrow corresponding to the graph. For each connected component of the graph checks if it contains an atom connected to an R-group in this RgMolecule; if yes then also adds the component to that R-group, otherwise adds it to the root structure.- Overrides:
- fuse0in class- Molecule
- Parameters:
- graph- the graph that will be fused into this molecule
- check-- trueif a containment check should be performed to ensure that only those nodes and edges are added that are not already elements -- falseif the graph is known to be disjoint from this graph and this check can be safely skipped
- Since:
- Marvin 5.0
 
- 
mergeAtoms@Deprecated(forRemoval=true) @SubjectToRemoval(date=JUL_01_2025) public void mergeAtoms(MolAtom that, MolAtom a) Deprecated, for removal: This API element is subject to removal in a future version.As of Marvin 6.2, useMergeUtil.mergeAtoms(MolAtom, MolAtom, boolean)instead.Merges bonds of an atom with another atom, then add the atom to the molecule.- Overrides:
- mergeAtomsin class- Molecule
- Parameters:
- that- the atom
- a- the other atom
 
- 
setSgroupParentSets or unsets an S-group as a parent of an atom in the root structure or an R-group.- Overrides:
- setSgroupParentin class- Molecule
- Parameters:
- a- the atom
- sg- the S-group
- set- set (true) or unset (false)
- Throws:
- IllegalArgumentException- if neither root, nor any R-group contains the atom
- Since:
- Marvin 3.0
 
- 
clonecopyMake another molecule identical to this one. If the target molecule is not an RgMolecule, then only the root structure will be cloned.
- 
clonecopyCopies the specified atoms of this graph to another one. The RgMolecule implementation of this method is incomplete, R-groups are not handled.
- 
isSelfReferenceTests whether the specified property is a self reference to the molecule.- Overrides:
- isSelfReferencein class- MoleculeGraph
- Parameters:
- p- the property
- Since:
- Marvin 4.1.6, 02/11/2007
 
- 
fixSelfReferringPropertyFix a property containing reference to the molecule. Called from clonelesscopy().- Overrides:
- fixSelfReferringPropertyin class- Molecule
- Parameters:
- prop- the property
- Since:
- Marvin 4.1.6, 02/14/2007
- See Also:
 
- 
clonelesscopyDeprecated.as of Marvin 6.3.
 Not supported feature.Copy to selection. Make another molecule identical to this one, but do not clone atoms, bonds, and the props.- Overrides:
- clonelesscopyin class- Molecule
- Parameters:
- g- the target molecule
 
- 
getFormulaGets the molecular formula in Hill order.- Overrides:
- getFormulain class- MoleculeGraph
- Returns:
- the formula
 
- 
getMasspublic double getMass()Calculates the molecular weight of the molecule. Returns 0 if the molecule contains R-group or reaction- Overrides:
- getMassin class- MoleculeGraph
- Returns:
- the molecular weight
 
- 
newInstanceCreates a new RgMolecule object. The dimension and the origin coordinates will be the same as in the original molecule.- Overrides:
- newInstancein class- Molecule
- Returns:
- an RgMolecule object
 
- 
newSelectionMoleculeCreates a new SelectionMolecule object appropriate for storing selection from this molecule.- Overrides:
- newSelectionMoleculein class- Molecule
- Returns:
- an empty selection molecule
- Since:
- Marvin 4.1, 11/24/2005
 
- 
makeItSimilarCopies some properties of this molecule to the other one specified as argument. Copies properties in the root structures.- Overrides:
- makeItSimilarin class- Molecule
- Parameters:
- g- the molecule to change
 
- 
isIncompleteReactionpublic boolean isIncompleteReaction()Check whether the reaction is incomplete or not.- Returns:
- true if something is missing, false if it seems to be okay
- Since:
- Marvin 2.9
 
- 
transformApply a transformation matrix to the atomic coordinates.
- 
getGraphUnionGets a graph containing all the atoms and bonds.- Overrides:
- getGraphUnionin class- MoleculeGraph
- Returns:
- root.getGraphUnion() if there are no R-groups, getGraphUnionAsSelection() otherwise
- Since:
- Marvin 3.0, 11/11/2002
- See Also:
 
- 
getSubGraphCountprotected final int getSubGraphCount()Gets the number of all "submolecules".- Overrides:
- getSubGraphCountin class- MoleculeGraph
- Returns:
- the number of submolecules
- Since:
- Marvin 4.1.2
- See Also:
 
- 
getSubGraphsGets all "submolecules".- Overrides:
- getSubGraphsin class- MoleculeGraph
- Parameters:
- arr- the output array
- off- offset
- Since:
- Marvin 4.1.2
- See Also:
 
- 
fillSelectionMoleculeAdds all atoms and bonds of the root structure and the R-groups to the specified molecule.- Overrides:
- fillSelectionMoleculein class- Molecule
- Parameters:
- s- the selection molecule
- Since:
- Marvin 3.0, 11/05/2002
 
- 
getLonePairCountpublic int getLonePairCount(int i) Gets the number of lone pairs.- Overrides:
- getLonePairCountin class- MoleculeGraph
- Parameters:
- i- atom index
- Returns:
- the number of lone pairs
 
- 
aromatizepublic void aromatize(int method) Aromatizes molecule. Changes the bonds.- Overrides:
- aromatizein class- Molecule
- Parameters:
- method- Specifies the algorithm for aromatization. Possible values:- AROM_BASIC - Basic aromatization
- AROM_GENERAL - General (Daylight compatible) aromatization
 
 - AROM_BASIC: only up to 18 membered rings are checked
- AROM_GENERAL: no ring system limit
 
- Throws:
- SecurityException- cannot load module because of a security problem (firewall)
- Since:
- Marvin 3.4, Marvin 4.1
- See Also:
 
- 
aromatizepublic void aromatize(int method, boolean checkAmbiguity) Aromatizes molecule. Changes the bonds.- Overrides:
- aromatizein class- Molecule
- Parameters:
- method- Specifies the algorithm for aromatization. Possible values:- AROM_BASIC - Basic aromatization
- AROM_GENERAL - General (Daylight compatible) aromatization
 
 - AROM_BASIC: only up to 18 membered rings are checked
- AROM_GENERAL: no ring system limit
 
- checkAmbiguity- Specifies whether ANY bonds should be considered during aromatization.
- Throws:
- SecurityException- cannot load module because of a security problem (firewall)
- Since:
- Marvin 3.4, Marvin 4.1
- See Also:
 
- 
checkSgroupConsistencyprotected void checkSgroupConsistency()Checks the consistency of S-groups.- Overrides:
- checkSgroupConsistencyin class- Molecule
- Throws:
- RuntimeException- if inconsistency found
- Since:
- Marvin 5.0, 11/06/2007
 
- 
toStringOverrides Object.toString() to ease debugging.- Overrides:
- toStringin class- MoleculeGraph
- Returns:
- a string representation of the object
- Since:
- 4.1, 11/28/2005
 
- 
sumConservedQuantitiesFor internal use only.- Overrides:
- sumConservedQuantitiesin class- MoleculeGraph
- Since:
- Marvin 4.1.13, 09/19/2007
- See Also:
 
- 
createGearchprotected chemaxon.struc.gearch.MoleculeGraphGearch createGearch()- Overrides:
- createGearchin class- Molecule
 
- 
getMaxAttachmentPointOrderpublic int getMaxAttachmentPointOrder(int rgroupID) Gets the maximal attachment point order of R-group definition molecules specified by an R-group ID. The attachment point order of an R-gruop definition molecule is the maximal attachment point order of its atoms.- Parameters:
- rgroupID- the rgroup identifier to specify the R-group definition molecules.
- Returns:
- the maximal attachment point order of the definition molecules.
- Since:
- Marvin 5.4
 
- 
clearObjectspublic void clearObjects()- Specified by:
- clearObjectsin interface- chemaxon.struc.MObjectContainer
- Overrides:
- clearObjectsin class- Molecule
 
- 
getObjectCountpublic int getObjectCount()- Specified by:
- getObjectCountin interface- chemaxon.struc.MObjectContainer
- Overrides:
- getObjectCountin class- Molecule
 
- 
removeObject- Specified by:
- removeObjectin interface- chemaxon.struc.MObjectContainer
- Overrides:
- removeObjectin class- Molecule
 
- 
selectAllObjectspublic void selectAllObjects(boolean s) - Specified by:
- selectAllObjectsin interface- chemaxon.struc.MObjectContainer
- Overrides:
- selectAllObjectsin class- Molecule
 
- 
getAllObjects- Specified by:
- getAllObjectsin interface- chemaxon.struc.MObjectContainer
- Overrides:
- getAllObjectsin class- Molecule
 
- 
getParitypublic int getParity(int i) Computes the parity of an atom of the RgMolecule instance based on both the coordinates of the neighboring atoms and the stereo information of the bonds to those. Leaves the imported parity unchanged.- Overrides:
- getParityin class- MoleculeGraph
- Parameters:
- i- the index of the atom whose parity is to be determined
- Returns:
- 0 for nonchiral, PARITY_ODD or PARITY_EVEN for atoms of odd or even parity, PARITY_ODD|PARITY_EVEN for atoms whose parity is unspecified or cannot be assigned -as they are defined in MolAtom
- Throws:
- SecurityException- the Parity module cannot be loaded because of security reasons (firewall)
- See Also:
 
- 
getLocalParitypublic int getLocalParity(int i) Computes the local parity of an atom of the RgMolecule instance based on both the coordinates of the neighboring atoms and the stereo information of the bonds to those. The molecule symmetry is not checked, so even an atom with same ligands can have parity. Leaves the imported parity unchanged. Contracted sgroups must be expanded to achieve consistent result.- Overrides:
- getLocalParityin class- MoleculeGraph
- Parameters:
- i- the index of the atom whose parity is to be determined
- Returns:
- PARITY_ODD or PARITY_EVEN for atoms of odd or even parity, PARITY_EITHER for atoms with wiggly bond 0 for atoms whose parity is unspecified or not known.
- Throws:
- SecurityException- the Parity module cannot be loaded because of security reasons (firewall)
- See Also:
 
- 
stereoCleanpublic boolean stereoClean()Reset the wedges of the molecule, based on the actual parity information in 2D remove wedges in 3D. Take care of expanding the molecule if neccessary.- Overrides:
- stereoCleanin class- MoleculeGraph
- Returns:
- true if succesful
- See Also:
 
- 
setValenceCheckOptionsDescription copied from class:MoleculeGraphSets the options for valence checking. To just enable/disable valence check in the molecule useMoleculeGraph.setValenceCheckEnabled(boolean). Calling this function with a not null parameter automatically enables the valence check.- Overrides:
- setValenceCheckOptionsin class- MoleculeGraph
- Parameters:
- options- the new valence check options
- See Also:
 
- 
getValenceCheckOptionsDescription copied from class:MoleculeGraphReturns the options for valence checking. To see if the valence check is enabled on the molecule useMoleculeGraph.isValenceCheckEnabled()- Overrides:
- getValenceCheckOptionsin class- MoleculeGraph
- Returns:
- the valence check options
- See Also:
 
- 
canBeCTpublic boolean canBeCT(int i2, int i3, boolean grcheck) Determines whether the bond between the specified atoms can be a CIS/TRANS or not. In case of ring bonds the ring sizes of the ring for the existence of CIS/TRANS specific bond should be checked before calling this method as ring sizes are not checked in this method.- Overrides:
- canBeCTin class- MoleculeGraph
- Parameters:
- i2- index of the first atom
- i3- index of the second atom
- grcheck- true if check atom equivalences using graph invariants
- Returns:
- true if this is a double bond that can be either CIS, TRANS or EITHER, false otherwise.
- Since:
- Marvin 4.0 1/23/2005
 
- 
getAtomIteratorReturns an iterator over the atoms in this molecule in proper sequence.- Overrides:
- getAtomIteratorin class- MoleculeGraph
- Returns:
- an iterator over the atoms in this molecule in proper sequencer
- Since:
- Marvin 6.2, 2013.09.09.
 
- 
getBondIteratorReturns an iterator over the bonds in this molecule in proper sequence.- Overrides:
- getBondIteratorin class- MoleculeGraph
- Returns:
- an iterator over the bonds in this molecule in proper sequence
- Since:
- Marvin 6.2, 2013.09.09.
 
- 
setRestHpublic void setRestH(int rgroupIndex) Sets the restH condition on an R-group definition.- Parameters:
- rgroupIndex- the index of the R-group definition
 
- 
removeRestHpublic void removeRestH(int rgroupIndex) Removes the restH condition from an R-group definition.- Parameters:
- rgroupIndex- the index of the R-group definition
 
- 
isRestHpublic boolean isRestH(int rgroupIndex) Informs whether the restH condition is set to the referenced R-group definition.- Parameters:
- rgroupIndex- the index of the R-group definition
- Returns:
- true if the restH condition is set false otherwise
 
- 
setDependentRgroupDefinitionpublic void setDependentRgroupDefinition(int rgroupIndexIf, int rgroupIndexThen) Sets the dependent R-group definition (rgroupIndexThen) for the referenced R-group definition (rgroupIndexIf).- Parameters:
- rgroupIndexIf- the R-group definition on which the other one depends
- rgroupIndexThen- the R-group definition which depends on the other one
 
- 
getDependentRgroupDefinitionpublic int getDependentRgroupDefinition(int rgroupIndex) Gets the R-group definition's index which depends on the referenced R-group definition.- Parameters:
- rgroupIndex- the R-group definition index
- Returns:
- the index of the dependent R-group definition or -1 if none exists
 
- 
removeDependentRgroupDefinitionpublic void removeDependentRgroupDefinition(int rgroupIndex) Removes the dependent R-group definition of the referenced R-group definition.- Parameters:
- rgroupIndex- the R-group definition ID
 
- 
getRgroupDisplayLabel- Specified by:
- getRgroupDisplayLabelin interface- chemaxon.struc.RgMoleculeGraphIface
 
 
- 
Not intended for public use, it was intended only for internal debugging.