From b2836206e8572d27881a8ff7962dacdf9bfb79ec Mon Sep 17 00:00:00 2001 From: Benjamin Ries Date: Fri, 15 Sep 2023 08:47:29 +0200 Subject: [PATCH 1/2] adding mol name labels from ofe-name to mapping vis --- gufe/visualization/mapping_visualization.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/gufe/visualization/mapping_visualization.py b/gufe/visualization/mapping_visualization.py index e3fbd287..1d5d2412 100644 --- a/gufe/visualization/mapping_visualization.py +++ b/gufe/visualization/mapping_visualization.py @@ -147,6 +147,9 @@ def _draw_molecules( d2d = Draw.rdMolDraw2D.MolDraw2DCairo( grid_x * 300, grid_y * 300, 300, 300) + # get molecule name labels + labels = [m.GetProp("ofe-name") for m in copies] + # squash to 2D copies = [Chem.Mol(mol) for mol in mols] for mol in copies: @@ -170,6 +173,7 @@ def _draw_molecules( highlightBonds=bonds_list, highlightAtomColors=atom_colors, highlightBondColors=bond_colors, + legends=labels, ) d2d.FinishDrawing() return d2d.GetDrawingText() From 91aee185c2e73d06f4ac929452f16f97e48823c0 Mon Sep 17 00:00:00 2001 From: Benjamin Ries Date: Fri, 15 Sep 2023 08:52:49 +0200 Subject: [PATCH 2/2] Multi Mapping Images draft --- gufe/visualization/mapping_visualization.py | 58 ++++++++++++++++++++- 1 file changed, 57 insertions(+), 1 deletion(-) diff --git a/gufe/visualization/mapping_visualization.py b/gufe/visualization/mapping_visualization.py index 1d5d2412..8dffbd20 100644 --- a/gufe/visualization/mapping_visualization.py +++ b/gufe/visualization/mapping_visualization.py @@ -1,7 +1,9 @@ # This code is part of OpenFE and is licensed under the MIT license. # For details, see https://github.com/OpenFreeEnergy/gufe -from typing import Any, Collection, Optional +from typing import Any, Collection, Optional, List from itertools import chain +from PIL import Image, ImageOps +from io import BytesIO from rdkit import Chem from rdkit.Chem import Draw @@ -304,3 +306,57 @@ def draw_unhighlighted_molecule(mol, d2d=None): bond_colors=[{}], highlight_color=red, ) + + +def _concat_images(imgs, buffer_spacing=4, ncols=3)-> Image: + """ + This helper function is constructing a Grid Image of given imgs. + """ + height = 0 + width = 0 + + #Calculate number of rows + nrows= (len(imgs)+1)//ncols if(len(imgs)%3>0) else len(imgs)//ncols + + #Get total widht and height of img + for img in imgs: + height = max(height, img.height) + width = max(width, img.width) + + height = height * nrows + width = width * ncols + + width += buffer_spacing*ncols + height += buffer_spacing*nrows + + #Construct Concatentated Image + res = Image.new("RGBA",(width,height)) + + x = 0 + y = 0 + for i, img in enumerate(imgs): + img = ImageOps.expand(img, border=3, fill="grey") + res.paste(img,(x,y)) + x += img.width + buffer_spacing + + if(i%ncols == 0 and i!=0): + y+= img.height + buffer_spacing + x=0 + + return res + +def draw_multiple_mappings(mappings:List, out_file_path:str=None)->Image: + """ + This function generates an image, consisting of multiple mapping visualization. + """ + views = [] + for m in mappings: + view = draw_mapping(m._compA_to_compB, m.componentA.to_rdkit(), + m.componentB.to_rdkit(),) + bio = BytesIO(view) + view = Image.open(bio) + views.append(view) + res = show_images(views) + + if(out_file_path is not None): + res.save(out_name) \ No newline at end of file