File: MolecularTransformations.pm

package info (click to toggle)
smiles-scripts 0.4.0%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,296 kB
  • sloc: perl: 2,333; java: 1,231; sh: 1,154; makefile: 253
file content (44 lines) | stat: -rw-r--r-- 1,187 bytes parent folder | download
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
package SmilesScripts::MolecularTransformations;

use strict;
use warnings;

use Chemistry::OpenSMILES qw(
    is_double_bond
    is_single_bond
    valence
);
use List::Util qw( first );

use parent Exporter::;
our @EXPORT_OK = qw(
    canonicalise_nitro_groups
);

sub canonicalise_nitro_groups
{
    my( $moiety ) = @_;

    my @N = grep { $_->{symbol} eq 'N' &&
                   $_->{charge} &&
                   $_->{charge} == 1 &&
                   $moiety->degree( $_  ) == 3 &&
                   valence( $moiety, $_ ) == 4 } $moiety->vertices;
    for my $N (@N) {
        my @O = sort { $a->{number} <=> $b->{number} }
                grep { $_->{symbol} eq 'O' && $moiety->degree( $_ ) == 1 }
                     $moiety->neighbours( $N );
        next unless @O >= 2;
        my $ketone = first { is_double_bond( $moiety, $N, $_ ) } @O;
        my $O      = first { is_single_bond( $moiety, $N, $_ ) &&
                             $_->{charge} &&
                             $_->{charge} == -1 } @O;
        next unless $ketone && $O;

        delete $N->{charge};
        delete $O->{charge};
        $moiety->set_edge_attribute( $N, $O, 'bond', '=' );
    }
}

1;