20package denoptim.molecularmodeling;
22import java.util.ArrayList;
23import java.util.logging.Level;
24import java.util.logging.Logger;
26import org.openscience.cdk.interfaces.IAtom;
27import org.openscience.cdk.interfaces.IAtomContainer;
29import denoptim.constants.DENOPTIMConstants;
30import denoptim.exception.DENOPTIMException;
31import denoptim.fragspace.FragmentSpaceParameters;
32import denoptim.graph.DGraph;
33import denoptim.graph.rings.RingClosureParameters;
34import denoptim.integration.tinker.ConformationalSearchPSSROT;
35import denoptim.integration.tinker.TinkerException;
36import denoptim.integration.tinker.TinkerMolecule;
37import denoptim.integration.tinker.TinkerUtils;
38import denoptim.io.DenoptimIO;
39import denoptim.programs.RunTimeParameters.ParametersType;
40import denoptim.programs.moldecularmodelbuilder.MMBuilderParameters;
41import denoptim.utils.AtomOrganizer;
42import denoptim.utils.DummyAtomHandler;
43import denoptim.utils.ObjectPair;
44import denoptim.utils.RotationalSpaceUtils;
90 logger.log(Level.INFO,
"Building Multiple 3D representations for "
94 long startTime = System.nanoTime();
96 long endTime = System.nanoTime();
97 long time = (endTime - startTime);
98 logger.log(Level.FINE,
"TIME (build 3D model): " + time/1000000 +
" ms"
113 ArrayList<ChemicalObjectModel> structures =
new ArrayList<ChemicalObjectModel>();
114 boolean skipConfSearch =
false;
117 startTime = System.nanoTime();
119 endTime = System.nanoTime();
120 time = (endTime - startTime);
121 int numAllClosedCombs = 0;
124 Object o = rcMol.getIAtomContainer().getProperty(
129 logger.log(Level.FINE,
"TIME (close ring): "+time/1000000+
" ms"
133 +
" #allClosedRCSCombs: " + numAllClosedCombs);
136 logger.log(Level.INFO,
"No fully closed RCA combinaton. "
137 +
"Nothing to send to conformational search.");
138 skipConfSearch =
true;
143 structures =
new ArrayList<ChemicalObjectModel>();
144 structures.add(nMol);
157 startTime = System.nanoTime();
167 time = (endTime - startTime);
168 logger.log(Level.FINE,
"TIME (conf. search): "+time/1000000+
" ms"
182 ArrayList<IAtomContainer> results =
new ArrayList<IAtomContainer>();
187 IAtomContainer iac = mol3db.getIAtomContainer();
190 iac, mol3db.getOldToNewOrder(), mol3db.getNewToOldOrder());
191 iac = originalOrderMol;
204 StringBuilder sbMolProp =
new StringBuilder();
205 for (IAtom atm : iac.atoms())
207 sbMolProp.append(
" ").append(atm.getProperty(
211 sbMolProp.toString().trim());
248 logger.log(Level.FINEST,
"oldToNewMap: "+oldToNewMap);
257 logger.log(Level.FINE,
"Rotatable bonds: "+rotBonds);
258 if (
logger.isLoggable(Level.FINEST))
260 logger.log(Level.FINEST,
"Reordered IAtomContainer: 'iacToIC.sdf'");
General set of constants used in DENOPTIM.
static final String ATMPROPVERTEXID
String tag of Atom property used to store the unique ID of the Vertex corresponding to the molecular ...
static final String MOLERRORTAG
SDF tag containing errors during execution of molecule specific tasks.
static final String DUMMYATMSYMBOL
Symbol of dummy atom.
Parameters defining the fragment space.
Container for the list of vertices and the edges that connect them.
List< Vertex > getVertexList()
boolean hasOrEmbedsRings()
Check for rings in this graph and in any graph that is embedded at any level in any vertex of this gr...
Parameters and setting related to handling ring closures.
boolean requireCompleteRingclosure
Flag requesting complete ring closure of all pairs of RCAs in at least one combination of RCAs to con...
void allowRingClosures(boolean value)
Exceptions resulting from a failure of Tinker.
Toolbox of utilities for Tinker style molecular representation.
static TinkerMolecule getICFromIAC(IAtomContainer mol, HashMap< String, Integer > tMap)
Convert IAtomContainer to TinkerMolecule.
static void setTinkerTypes(TinkerMolecule tmol, HashMap< String, Integer > tMap)
Conversion to tinker IC may not always have the necessary atom types.
Utility methods for input/output.
static void writeSDFFile(String fileName, IAtomContainer mol)
Writes IAtomContainer to SDF file.
Collector of molecular information, related to a single chemical object, that is deployed within the ...
ChemicalObjectModel deepcopy()
Return a new Molecule3DBuilder having exactly the same features of this Molecule3DBuilder.
DGraph getGraph()
Returns the graph representation of this molecule as it was originally generated by DEOPTIM.
IAtomContainer getIAtomContainer()
Returns the CDK representation of the molecular system.
ArrayList< ObjectPair > getRotatableBonds()
Returns the list of rotatable bonds.
ArrayList< Set< ObjectPair > > getRCACombinations()
Returns the list of combinations of RingClosingAttractor.
MultiMolecularModelBuilder(String molName, DGraph molGraph, MMBuilderParameters settings)
ChemicalObjectModel build3DTree()
Generate 3D structure by assembling 3D fragments according to attachment point vector and following t...
ArrayList< IAtomContainer > buildMulti3DStructure()
Given the graph representation of the molecular constitution, along with the 3D coordinates of the fr...
Logger logger
Program-specific logger.
MMBuilderParameters settings
Tool to build build three-dimensional (3D) tree-like molecular structures from DGraph.
IAtomContainer convertGraphTo3DAtomContainer(DGraph graph)
Created a three-dimensional molecular representation from a given DGraph.
boolean containsParameters(ParametersType type)
RunTimeParameters getParameters(ParametersType type)
Logger getLogger()
Get the name of the program specific logger.
Randomizer getRandomizer()
Returns the current program-specific randomizer.
Parameters for the conformer generator (3D builder).
ArrayList< String > getKeyFileParams()
ArrayList< String > getInitPSSROTParams()
boolean getKeepDummyFlag()
String getWorkingDirectory()
ArrayList< String > getRestPSSROTParams()
HashMap< String, Integer > getTinkerMap()
int getAtomOrderingScheme()
Tool for re-organizing the list of atoms of an IAtomContainer
void setScheme(int scheme)
ArrayList< Integer > getNewToOldOrder(int seed)
Returns the list of indexes that allow to map the new atom position with the old one.
static IAtomContainer makeReorderedCopy(IAtomContainer original, List< Integer > newToOldOrder, List< Integer > oldToNewOrder)
Produces a new container that looks very similar to the original one, but has a different atom order.
IAtomContainer reorderStartingFrom(int seed, IAtomContainer mol)
Reorder the atoms in mol starting with atom seed
ArrayList< Integer > getOldToNewOrder(int seed)
Returns the list of indexes that allow to map the old atom position with the new one.
Toll to add/remove dummy atoms from linearities or multi-hapto sites.
IAtomContainer removeDummy(IAtomContainer mol)
Removes all dummy atoms and the bonds connecting them to other atoms.
IAtomContainer removeDummyInHapto(IAtomContainer mol)
Tool box for definition and management of the rotational space, which is given by the list of rotatab...
static ArrayList< ObjectPair > defineRotatableBonds(IAtomContainer mol, String defRotBndsFile, boolean addIterfragBonds, boolean excludeRings, Logger logger)
Define the rotational space (also torsional space) for a given molecule.
Identifier of the type of parameters.
FS_PARAMS
Parameters pertaining the definition of the fragment space.
RC_PARAMS
Parameters pertaining to ring closures in graphs.