-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathprepare_data.py
50 lines (37 loc) · 1.66 KB
/
prepare_data.py
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
48
49
50
# Copyright (C) 2019 Computational Science Lab, UPF <http://www.compscience.org/>
# Copying and distribution is allowed under AGPLv3 license
import argparse
import numpy as np
from tqdm import tqdm
from rdkit import Chem
parser = argparse.ArgumentParser()
parser.add_argument("-i", "--input", required=True, help="Path to input .smi file.")
parser.add_argument("-o", "--output", required=True, help="Path to output numpy arrays.")
args = vars(parser.parse_args())
smiles_path = args["input"]
np_save_path = args["output"]
smiles = open(smiles_path, "r").read().strip().split()
strings = np.zeros((len(smiles), 1000), dtype='uint8')
vocab_list = ["pad", "start", "end",
"C", "c", "N", "n", "S", "s", "P", "O", "o",
"B", "F", "I",
"X", "Y", "Z",
"1", "2", "3", "4", "5", "6",
"#", "=", "-", "(", ")","/","\\","@","[","]","H","+","7"
]
vocab_i2c_v1 = {i: x for i, x in enumerate(vocab_list)}
vocab_c2i_v1 = {vocab_i2c_v1[i]: i for i in vocab_i2c_v1}
for i, sstring in enumerate(tqdm(smiles)):
mol = Chem.MolFromSmiles(sstring)
if not mol:
raise ValueError("Failed to parse molecule '{}'".format(mol))
sstring = Chem.MolToSmiles(mol) # Make the SMILES canonical.
sstring = sstring.replace("Cl", "X").replace("[nH]", "Y").replace("Br", "Z")
try:
vals = [1] + [vocab_c2i_v1[xchar] for xchar in sstring] + [2]
except KeyError:
raise ValueError(("Unkown SMILES tokens: {} in string '{}'."
.format(", ".join([x for x in sstring if x not in vocab_c2i_v1]),
sstring)))
strings[i, :len(vals)] = vals
np.save(np_save_path, strings)