$darkmode
DENOPTIM
MultiMolecularModelBuilder.java
Go to the documentation of this file.
1/*
2 * DENOPTIM
3 * Copyright (C) 2019 Vishwesh Venkatraman <vishwesh.venkatraman@ntnu.no> and
4 * Marco Foscato <marco.foscato@uib.no>
5 *
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Affero General Public License as published
8 * by the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Affero General Public License for more details.
15 *
16 * You should have received a copy of the GNU Affero General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19
20package denoptim.molecularmodeling;
21
22import java.util.ArrayList;
23import java.util.logging.Level;
24import java.util.logging.Logger;
25
26import org.openscience.cdk.interfaces.IAtom;
27import org.openscience.cdk.interfaces.IAtomContainer;
28
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;
45
52{
53 private String molName;
55
57
61 private Logger logger;
62
63//------------------------------------------------------------------------------
64
67 {
68 this.settings = settings;
69 this.logger = settings.getLogger();
70 this.molName = molName;
71 this.molGraph = molGraph;
72 }
73
74//------------------------------------------------------------------------------
75
87 public ArrayList<IAtomContainer> buildMulti3DStructure()
89 {
90 logger.log(Level.INFO, "Building Multiple 3D representations for "
91 + "graph = " + molGraph.toString());
92
93 // Generate XYZ and INT representations
94 long startTime = System.nanoTime();
96 long endTime = System.nanoTime();
97 long time = (endTime - startTime);
98
99 logger.log(Level.FINE, "TIME (build 3D model): " + time/1000000 + " ms"
100 + " #frags: " + mol.getGraph().getVertexList().size()
101 + " #atoms: " + mol.getIAtomContainer().getAtomCount());
102
103 // get settings //TODO: this should happen inside RunTimeParameters
106 {
109 }
110
111 // Evaluate source of isomerism
112 // 1: Attempt Ring Closures
114 ArrayList<ChemicalObjectModel> structures =new ArrayList<ChemicalObjectModel>();
115 boolean skipConfSearch = false;
116 if (rcParams.allowRingClosures() && mol.getGraph().hasOrEmbedsRings())
117 {
118 startTime = System.nanoTime();
119 structures = rct.attemptAllRingClosures(mol);
120 endTime = System.nanoTime();
121 time = (endTime - startTime);
122 int numAllClosedCombs = 0;
123 for (ChemicalObjectModel rcMol : structures)
124 {
125 Object o = rcMol.getIAtomContainer().getProperty(
127 if (o == null)
128 numAllClosedCombs++;
129 }
130 logger.log(Level.FINE, "TIME (close ring): "+time/1000000+" ms"
131 + " #frags: " + mol.getGraph().getVertexList().size()
132 + " #atoms: " + mol.getIAtomContainer().getAtomCount()
133 + " #rcaCombs: " + mol.getRCACombinations().size()
134 + " #allClosedRCSCombs: " + numAllClosedCombs);
135 if (rcParams.requireCompleteRingclosure && numAllClosedCombs<1)
136 {
137 logger.log(Level.INFO, "No fully closed RCA combinaton. "
138 + "Nothing to send to conformational search.");
139 skipConfSearch = true;
140 }
141 } else {
142 ChemicalObjectModel nMol = mol.deepcopy();
144 structures = new ArrayList<ChemicalObjectModel>();
145 structures.add(nMol);
146 }
147
148 /*
149 ArrayList<IAtomContainer> iacs = new ArrayList<IAtomContainer>();
150 for (ChemicalObjectModel com : structures)
151 iacs.add(com.getIAtomContainer());
152 DenoptimIO.writeSDFFile("/tmp/afterRC.sdf", iacs);
153 */
154
155 // 2: Conformational search (if possible)
156 if (!skipConfSearch)
157 {
158 startTime = System.nanoTime();
168 time = (endTime - startTime);
169 logger.log(Level.FINE, "TIME (conf. search): "+time/1000000+" ms"
170 + " #frags: " + mol.getGraph().getVertexList().size()
171 + " #atoms: " + mol.getIAtomContainer().getAtomCount()
172 + " #rotBnds: " + mol.getRotatableBonds().size());
173 }
174
175 /*
176 ArrayList<IAtomContainer> iacs2 = new ArrayList<IAtomContainer>();
177 for (ChemicalObjectModel com : structures)
178 iacs.add(com.getIAtomContainer());
179 DenoptimIO.writeSDFFile("/tmp/afterCS.sdf", iacs2);
180 */
181
182 // Convert and return results
183 ArrayList<IAtomContainer> results = new ArrayList<IAtomContainer>();
186 for (ChemicalObjectModel mol3db : structures)
187 {
188 IAtomContainer iac = mol3db.getIAtomContainer();
189
190 IAtomContainer originalOrderMol = AtomOrganizer.makeReorderedCopy(
191 iac, mol3db.getOldToNewOrder(), mol3db.getNewToOldOrder());
192 iac = originalOrderMol;
193
195 {
196 // To keep track of which vertexID should be removed from mol
197 // properties, we remove that property from the mol. It remains
198 // defined in each atom.
199 iac.removeProperty(DENOPTIMConstants.ATMPROPVERTEXID);
200
201 iac = dah.removeDummyInHapto(iac);
202 iac = dah.removeDummy(iac);
203
204 // Now we put the property back among the molecular ones
205 StringBuilder sbMolProp = new StringBuilder();
206 for (IAtom atm : iac.atoms())
207 {
208 sbMolProp.append(" ").append(atm.getProperty(
210 }
211 iac.setProperty(DENOPTIMConstants.ATMPROPVERTEXID,
212 sbMolProp.toString().trim());
213 results.add(iac);
214 } else {
215 results.add(iac);
216 }
217 }
218
219 return results;
220 }
221
222//------------------------------------------------------------------------------
223
233 {
234 // Create 3D tree-like structure
237 IAtomContainer initMol = tb.convertGraphTo3DAtomContainer(molGraph,
238 false, //don't remove used RCAs
239 true, //set the CDK requirements
240 true); //rebuild low-quality structured embedded in templates
241
242 // Reorder atoms and clone molecule.
243 AtomOrganizer oa = new AtomOrganizer();
245 int seedAtm = 0;
246 IAtomContainer reorderedMol = oa.reorderStartingFrom(seedAtm, initMol);
247 ArrayList<Integer> newToOldMap = oa.getNewToOldOrder(seedAtm);
248 ArrayList<Integer> oldToNewMap = oa.getOldToNewOrder(seedAtm);
249 logger.log(Level.FINEST, "oldToNewMap: "+oldToNewMap);
250
251 // Collect rotatable bonds defined by fragment-fragment connections
252 ArrayList<ObjectPair> rotBonds = RotationalSpaceUtils
253 .defineRotatableBonds(reorderedMol,
255 ParametersType.FS_PARAMS)).getRotSpaceDefFile(),
256 true, true, settings.getLogger());
257
258 logger.log(Level.FINE, "Rotatable bonds: "+rotBonds);
259 if (logger.isLoggable(Level.FINEST))
260 {
261 logger.log(Level.FINEST, "Reordered IAtomContainer: 'iacToIC.sdf'");
262 DenoptimIO.writeSDFFile("iacToIC.sdf",reorderedMol,false);
263 }
264
265 // Generate Internal Coordinates
266 TinkerMolecule tmol = TinkerUtils.getICFromIAC(reorderedMol,
269
270 // Generate combined molecular representations (both XYZ and INT)
271 return new ChemicalObjectModel(
272 molGraph,
273 reorderedMol,
274 tmol,
275 molName,
276 rotBonds,
277 oldToNewMap,
278 newToOldMap,
279 logger
280 );
281 }
282
283//------------------------------------------------------------------------------
284
285}
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.
Definition: DGraph.java:102
List< Vertex > getVertexList()
Definition: DGraph.java:947
boolean hasOrEmbedsRings()
Check for rings in this graph and in any graph that is embedded at any level in any vertex of this gr...
Definition: DGraph.java:1134
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...
Toolkit to perform conformational search via Tinker PSSROT program.
static void performPSSROT(ArrayList< ChemicalObjectModel > mols, String runLabel, String ffFilePathName, List< String > keyFileLines, List< String > subParamsInit, List< String > subParamsRest, String pssExePathName, String xyzintPathName, String workDir, int taskId, Logger logger)
Performs PSSROT conformational search for all chemical objects in the list.
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...
Toolkit to perform ring closing conformational search.
void saturateRingClosingAttractor(ChemicalObjectModel mol)
Looks for unused RingClosingAttractors and attach proper capping group saturating the free valency/bo...
ArrayList< ChemicalObjectModel > attemptAllRingClosures(ChemicalObjectModel mol)
Performs one or more attempts to close rings by conformational adaptation.
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).
Tool for re-organizing the list of atoms of an IAtomContainer
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.
FS_PARAMS
Parameters pertaining the definition of the fragment space.
RC_PARAMS
Parameters pertaining to ring closures in graphs.