You want to organize and depict a set of molecules according to given
activity data and common substructure.
See the separate pages of a multi-page
|page 1||page 2||..||page 8|
Requires OpenEye toolkits version 2013.Feb or later.
First you have to import the molecules being depicted with their activity information.
In this example the ImportMolecule
functions reads the molecules and extracts the activity information attached
to the molecule as SD data with the “activity” tag (line 14).
(See example in the
activity.sdf input file.)
After converting the SD string to a floating point number the number is added to
the title of the molecule in order to depict it later along with the molecule
Each imported molecule, along with its corresponding activity, is inserted into
a list of (molecule, activity) tuples (line 18).
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
def ImportMolecules(ifs, mollist): if ifs.GetFormat() != OEFormat_SDF: OEThrow.Fatal("The input file has to be an SDF file") tag = "activity" for mol in ifs.GetOEGraphMols(): id = mol.GetTitle() if not OEHasSDData(mol, tag): OEThrow.Warning("Non activity data found for molecule '%s'." "Compound will be ignored." % id) else: activitystr = OEGetSDData(mol, tag) try: activity = float(activitystr) mol.SetTitle("%s -- Activity: %s uM" % (id, activitystr)) mollist.append((OEGraphMol(mol), activity)) except ValueError: OEThrow.Warning("Non-numeric activity data '%s' found for molecule '%s'." "Compound will be ignored." % (activitystr, id))
The DepictMoleculesWithActivity function, that takes the following parameters, shows how to depict the molecules along with their activities.
First, the activity numbers are extracted from the list of (molecule, activity) tuples in order to find the minimum and maximum activity number of the dataset (lines 3-5). These number are used to construct a color gradient (lines 7-9) that will be used to color the molecules by their activity. The molecules are then sorted in decreasing order of their activities (lines 11). This will be the order in which they are rendered.
Before rendering a substructure search is performed to find the common core substructure of the molecule. The match returned by the substructure search is used to align the molecule by this common core (line 19), Then the bonds of the common core are highlighted by calling the FadeCoreSubstructure function (line 26), while the bonds that are not in the common core are highlighted by the activity of the molecule by calling the HighlightByActivity function (line 27). After rendering the molecules, the color gradient is depicted in the footer of each page (lines 34-47) along with a box that indicates the range of the activities of the molecule in each page.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
def DepictMoleculesWithActivity(report, mollist, coresubs, opts): activities = [activity for mol, activity in mollist] minactivity = min(activities) maxactivity = max(activities) colorg = OELinearColorGradient(OEColorStop((minactivity + maxactivity) / 2.0, OEYellow)) colorg.AddStop(OEColorStop(maxactivity, OERed)) colorg.AddStop(OEColorStop(minactivity, OEGreen)) sortedmollist = sorted(mollist, key=itemgetter(1)) for mol, activity in sortedmollist: unique = True match = None for mi in coresubs.Match(mol, unique): match = mi OEPrepareAlignedDepiction(mol, coresubs.GetPattern(), match) break cell = report.NewCell() disp = OE2DMolDisplay(mol, opts) if match is not None: FadeCoreSubstructure(disp, match) HighlightByActivity(disp, match, activity, colorg) OERenderMolecule(cell, disp) cellsperpage = report.NumRowsPerPage() * report.NumColsPerPage() opts = OEColorGradientDisplayOptions() for pageidx, footer in enumerate(report.GetFooters()): bgnidx = pageidx * cellsperpage endidx = (pageidx + 1) * cellsperpage pageactivities = [activity for mol, activity in sortedmollist[bgnidx:endidx]] minpageactivities = min(pageactivities) maxpageactivities = max(pageactivities) opts.ClearMarkedValues() if minpageactivities == maxpageactivities: opts.AddMarkedValue(minpageactivities) else: opts.SetBoxRange(minpageactivities, maxpageactivities) OEDrawColorGradient(footer, colorg, opts)
1 2 3 4 5 6
def FadeCoreSubstructure(disp, corematch): bondpred = OEIsBondMember(corematch.GetTargetBonds()) lineWidthScale = 0.75 highlightstyle = OEHighlightByColor(OEGrey, lineWidthScale) OEAddHighlighting(disp, highlightstyle, bondpred)
1 2 3 4 5 6
def HighlightByActivity(disp, corematch, activity, colorg): bondpred = OENotBond(OEIsBondMember(corematch.GetTargetBonds())) color = colorg.GetColorAt(activity) highlightstyle = OEHighlightByStick(color) OEAddHighlighting(disp, highlightstyle, bondpred)
prompt > python3 activity2pdf.py -in activity.sdf -out activity.pdf -core "c1ccc2cc(ccc2c1)N"