$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 logger.log(Level.FINE, "TIME (build 3D model): " + time/1000000 + " ms"
99 + " #frags: " + mol.getGraph().getVertexList().size()
100 + " #atoms: " + mol.getIAtomContainer().getAtomCount());
101
102 // get settings //TODO: this should happen inside RunTimeParameters
105 {
108 }
109
110 // Evaluate source of isomerism
111 // 1: Attempt Ring Closures
113 ArrayList<ChemicalObjectModel> structures =new ArrayList<ChemicalObjectModel>();
114 boolean skipConfSearch = false;
115 if (rcParams.allowRingClosures() && mol.getGraph().hasOrEmbedsRings())
116 {
117 startTime = System.nanoTime();
118 structures = rct.attemptAllRingClosures(mol);
119 endTime = System.nanoTime();
120 time = (endTime - startTime);
121 int numAllClosedCombs = 0;
122 for (ChemicalObjectModel rcMol : structures)
123 {
124 Object o = rcMol.getIAtomContainer().getProperty(
126 if (o == null)
127 numAllClosedCombs++;
128 }
129 logger.log(Level.FINE, "TIME (close ring): "+time/1000000+" ms"
130 + " #frags: " + mol.getGraph().getVertexList().size()
131 + " #atoms: " + mol.getIAtomContainer().getAtomCount()
132 + " #rcaCombs: " + mol.getRCACombinations().size()
133 + " #allClosedRCSCombs: " + numAllClosedCombs);
134 if (rcParams.requireCompleteRingclosure && numAllClosedCombs<1)
135 {
136 logger.log(Level.INFO, "No fully closed RCA combinaton. "
137 + "Nothing to send to conformational search.");
138 skipConfSearch = true;
139 }
140 } else {
141 ChemicalObjectModel nMol = mol.deepcopy();
143 structures = new ArrayList<ChemicalObjectModel>();
144 structures.add(nMol);
145 }
146
147 /*
148 ArrayList<IAtomContainer> iacs = new ArrayList<IAtomContainer>();
149 for (ChemicalObjectModel com : structures)
150 iacs.add(com.getIAtomContainer());
151 DenoptimIO.writeSDFFile("/tmp/afterRC.sdf", iacs);
152 */
153
154 // 2: Conformational search (if possible)
155 if (!skipConfSearch)
156 {
157 startTime = System.nanoTime();
167 time = (endTime - startTime);
168 logger.log(Level.FINE, "TIME (conf. search): "+time/1000000+" ms"
169 + " #frags: " + mol.getGraph().getVertexList().size()
170 + " #atoms: " + mol.getIAtomContainer().getAtomCount()
171 + " #rotBnds: " + mol.getRotatableBonds().size());
172 }
173
174 /*
175 ArrayList<IAtomContainer> iacs2 = new ArrayList<IAtomContainer>();
176 for (ChemicalObjectModel com : structures)
177 iacs.add(com.getIAtomContainer());
178 DenoptimIO.writeSDFFile("/tmp/afterCS.sdf", iacs2);
179 */
180
181 // Convert and return results
182 ArrayList<IAtomContainer> results = new ArrayList<IAtomContainer>();
185 for (ChemicalObjectModel mol3db : structures)
186 {
187 IAtomContainer iac = mol3db.getIAtomContainer();
188
189 IAtomContainer originalOrderMol = AtomOrganizer.makeReorderedCopy(
190 iac, mol3db.getOldToNewOrder(), mol3db.getNewToOldOrder());
191 iac = originalOrderMol;
192
194 {
195 // To keep track of which vertexID should be removed from mol
196 // properties, we remove that property from the mol. It remains
197 // defined in each atom.
198 iac.removeProperty(DENOPTIMConstants.ATMPROPVERTEXID);
199
200 iac = dah.removeDummyInHapto(iac);
201 iac = dah.removeDummy(iac);
202
203 // Now we put the property back among the molecular ones
204 StringBuilder sbMolProp = new StringBuilder();
205 for (IAtom atm : iac.atoms())
206 {
207 sbMolProp.append(" ").append(atm.getProperty(
209 }
210 iac.setProperty(DENOPTIMConstants.ATMPROPVERTEXID,
211 sbMolProp.toString().trim());
212 results.add(iac);
213 } else {
214 results.add(iac);
215 }
216 }
217
218 return results;
219 }
220
221//------------------------------------------------------------------------------
222
232 {
233 // Create 3D tree-like structure
236 IAtomContainer initMol = tb.convertGraphTo3DAtomContainer(molGraph,
237 false, //don't remove used RCAs
238 true, //set the CDK requirements
239 true); //rebuild low-quality structured embedded in templates
240
241 // Reorder atoms and clone molecule.
242 AtomOrganizer oa = new AtomOrganizer();
244 int seedAtm = 0;
245 IAtomContainer reorderedMol = oa.reorderStartingFrom(seedAtm, initMol);
246 ArrayList<Integer> newToOldMap = oa.getNewToOldOrder(seedAtm);
247 ArrayList<Integer> oldToNewMap = oa.getOldToNewOrder(seedAtm);
248 logger.log(Level.FINEST, "oldToNewMap: "+oldToNewMap);
249
250 // Collect rotatable bonds defined by fragment-fragment connections
251 ArrayList<ObjectPair> rotBonds = RotationalSpaceUtils
252 .defineRotatableBonds(reorderedMol,
254 ParametersType.FS_PARAMS)).getRotSpaceDefFile(),
255 true, true, settings.getLogger());
256
257 logger.log(Level.FINE, "Rotatable bonds: "+rotBonds);
258 if (logger.isLoggable(Level.FINEST))
259 {
260 logger.log(Level.FINEST, "Reordered IAtomContainer: 'iacToIC.sdf'");
261 DenoptimIO.writeSDFFile("iacToIC.sdf",reorderedMol,false);
262 }
263
264 // Generate Internal Coordinates
265 TinkerMolecule tmol = TinkerUtils.getICFromIAC(reorderedMol,
268
269 // Generate combined molecular representations (both XYZ and INT)
270 return new ChemicalObjectModel(
271 molGraph,
272 reorderedMol,
273 tmol,
274 molName,
275 rotBonds,
276 oldToNewMap,
277 newToOldMap,
278 logger
279 );
280 }
281
282//------------------------------------------------------------------------------
283
284}
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:719
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:906
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.