Spaces:
Running
Running
import gradio as gr | |
from utils import ChemicalConverter, validate_smiles2iupac, plot_mol, login | |
def convert(access_code, chemical_name, style, validate, plot): | |
if not login(access_code): | |
return "Currently, you don't have access to the service.", None, None | |
# Initialize the ChemicalConverter | |
converter = ChemicalConverter(mode="SMILES2IUPAC") | |
converted_name = "" | |
validation_score = "" | |
plot_image = None | |
style_prefix = "<" + style[:4] + ">" | |
converted_name = converter.convert(style_prefix + chemical_name) | |
if validate: | |
validation_score = validate_smiles2iupac(chemical_name, converted_name) | |
if plot: | |
plot_image = plot_mol(chemical_name) | |
return converted_name, validation_score, plot_image | |
smiles2iupac = gr.Interface( | |
fn=convert, | |
allow_flagging='auto', | |
inputs=[ | |
gr.Textbox(label="Enter your access code", placeholder=""), | |
gr.Textbox(label="Enter your SMILES name", placeholder="Enter your SMILES name here"), | |
gr.Radio( | |
choices=["BASE", "SYSTEMATIC", "TRADITIONAL"], | |
label="Choose desired IUPAC style", | |
), | |
gr.Checkbox(label="Validate with molecular similarity", value=False), | |
gr.Checkbox(label="Plot molecule", value=True) | |
], | |
outputs=[gr.Text(label="Converted Name"), | |
gr.Text(label="Input-Target similarity score"), | |
gr.Image(type='pil', label="Molecule Plot", height=170, width=890)], | |
examples=[ | |
["", "CCO", "BASE", True, True] | |
], | |
) |