2.3.1. Retrieving Feature Properties

The script print_ph4_ftrs.py demonstrates how to iterate over the features of pharmacophores read from a specified input file and query the following feature properties:

  • Type

  • Geometry

  • Tolerance

  • Position

  • Orientation

  • Orientation vector length

  • Weight

  • Hydrophobicity

  • Is optional

  • Is disabled

Synopsis

python print_ph4_ftrs.py <file>

Code

 1import sys
 2
 3import CDPL.Pharm as Pharm
 4import CDPL.Chem as Chem
 5
 6
 7# outputs all (available) properties of the features stored in the given feature container
 8def outputFeatureProps(ph4: Pharm.FeatureContainer) -> None: 
 9    ftr_type_str = { Pharm.FeatureType.UNKNOWN               : 'UNKNOWN',
10                     Pharm.FeatureType.HYDROPHOBIC           : 'HYDROPHOBIC',
11                     Pharm.FeatureType.AROMATIC              : 'AROMATIC',
12                     Pharm.FeatureType.NEGATIVE_IONIZABLE    : 'NEGATIVE_IONIZABLE',
13                     Pharm.FeatureType.POSITIVE_IONIZABLE    : 'POSITIVE_IONIZABLE',
14                     Pharm.FeatureType.H_BOND_DONOR          : 'H_BOND_DONOR',
15                     Pharm.FeatureType.H_BOND_ACCEPTOR       : 'H_BOND_ACCEPTOR',
16                     Pharm.FeatureType.HALOGEN_BOND_DONOR    : 'HALOGEN_BOND_DONOR',
17                     Pharm.FeatureType.HALOGEN_BOND_ACCEPTOR : 'HALOGEN_BOND_ACCEPTOR',
18                     Pharm.FeatureType.EXCLUSION_VOLUME      : 'EXCLUSION_VOLUME' }
19  
20    geom_str = { Pharm.FeatureGeometry.UNDEF   : 'UNDEF',
21                 Pharm.FeatureGeometry.SPHERE  : 'SPHERE',
22                 Pharm.FeatureGeometry.VECTOR  : 'VECTOR',
23                 Pharm.FeatureGeometry.PLANE   : 'PLANE' }
24
25    print('Composition of pharmacophore \'%s\':' % Pharm.getName(ph4))
26
27    for i in range(0, len(ph4)):
28        ftr = ph4[i]
29
30        print(' - Feature #%s:' % str(i))
31        print('  - Type: %s' % ftr_type_str[Pharm.getType(ftr)])
32        print('  - Geometry: %s' % geom_str[Pharm.getGeometry(ftr)])
33        print('  - Tolerance: %s' % Pharm.getTolerance(ftr))
34        print('  - Weight: %s' % Pharm.getWeight(ftr))
35        print('  - Optional: %s' % Pharm.getOptionalFlag(ftr))
36        print('  - Disabled: %s' % Pharm.getDisabledFlag(ftr))
37        print('  - Length: %s' % Pharm.getLength(ftr))
38        print('  - Hydrophobicity: %s' % Pharm.getHydrophobicity(ftr))
39
40        if Chem.has3DCoordinates(ftr):         # Pharm.Feature derives from Chem.Entity3D - therefore a function from the Chem package is used here!
41            print('  - Position: %s' % Chem.get3DCoordinates(ftr))
42 
43        if Pharm.hasOrientation(ftr):
44            print('  - Orientation: %s' % Pharm.getOrientation(ftr))
45
46def main() -> None:
47    if len(sys.argv) < 2:
48        sys.exit('Usage: %s <input pharm. file>' % sys.argv[0])
49
50    # create reader for input pharmacophores (format specified by file extension)
51    reader = Pharm.PharmacophoreReader(sys.argv[1]) 
52    
53    # create an instance of the default implementation of the Pharm.Pharmacophore interface
54    ph4 = Pharm.BasicPharmacophore()
55    
56    # read and process pharmacophores one after the other until the end of input has been reached
57    try:
58        while reader.read(ph4): 
59            try:
60                outputFeatureProps(ph4)
61            except Exception as e:
62                sys.exit('Error: processing of pharmacophore failed: ' + str(e))
63                
64    except Exception as e: # handle exception raised in case of severe read errors
65        sys.exit('Error: reading pharmacophore failed: ' + str(e))
66
67    sys.exit(0)
68        
69if __name__ == '__main__':
70    main()

Download source file