4.1.3. MDL MACCS Keys
The script gen_maccs_key.py generates and outputs the 166 bit MACCS key of molecules read from a specified input file.
Synopsis
python gen_maccs_key.py [-h] -i <file> -o <file>
Mandatory options
- -i <file>
Input molecule file
- -o <file>
MACCS key output file
Other options
- -h, --help
Show help message and exit
Code
1import sys
2import argparse
3
4import CDPL.Chem as Chem
5import CDPL.Descr as Descr
6import CDPL.Util as Util
7
8
9# generates the MACCS key of the given molecular graph
10def genMACCSKey(molgraph: Chem.MolecularGraph) -> Util.BitSet:
11 Chem.calcBasicProperties(molgraph, False) # calculate basic molecular properties (if not yet done)
12
13 mk_gen = Descr.MACCSFingerprintGenerator() # create MACCS key generator instance
14 fp = Util.BitSet() # create Util.BitSet instance storing the generated key
15
16 # generate the MACCS key
17 mk_gen.generate(molgraph, fp)
18
19 # if needed, fp could be converted into a numpy single precision float array as follows:
20 # fp = numpy.array(fp, dtype=numpy.float32)
21
22 return fp
23
24def parseArgs() -> argparse.Namespace:
25 parser = argparse.ArgumentParser(description='Generates 166 bit MACCS keys for given input molecules.')
26
27 parser.add_argument('-i',
28 dest='in_file',
29 required=True,
30 metavar='<file>',
31 help='Input molecule file')
32 parser.add_argument('-o',
33 dest='out_file',
34 required=True,
35 metavar='<file>',
36 help='MACCS key output file')
37
38 return parser.parse_args()
39
40def main() -> None:
41 args = parseArgs()
42
43 # create reader for input molecules (format specified by file extension)
44 reader = Chem.MoleculeReader(args.in_file)
45
46 # open output file storing the generated fingerprints
47 out_file = open(args.out_file, 'w')
48
49 # create an instance of the default implementation of the Chem.Molecule interface
50 mol = Chem.BasicMolecule()
51
52 # read and process molecules one after the other until the end of input has been reached
53 try:
54 while reader.read(mol):
55 try:
56 fp = genMACCSKey(mol)
57
58 out_file.write(str(fp))
59 out_file.write('\n')
60
61 except Exception as e:
62 sys.exit('Error: processing of molecule failed: ' + str(e))
63
64 except Exception as e: # handle exception raised in case of severe read errors
65 sys.exit('Error: reading molecule failed: ' + str(e))
66
67 out_file.close()
68 sys.exit(0)
69
70if __name__ == '__main__':
71 main()