annotate cpt_psm_plotter/lib/CPT/External/LipoP.pm @ 0:54c7a3ea81e2 draft

Uploaded
author cpt
date Tue, 05 Jul 2022 05:40:36 +0000
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
1 package CPT::External::LipoP;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
2 no warnings;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
3 use Moose;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
4 use File::Temp qw(tempfile);
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
5 use IPC::Run qw(run);
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
6
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
7 has 'sequence' => ( is => 'rw', isa => 'Str' );
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
8 has 'response' => ( is => 'rw', isa => 'Str' );
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
9 has 'cleavage' => ( is => 'rw', isa => 'ArrayRef' );
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
10 has 'tmpfile' => (is => 'rw', isa => 'Any');
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
11
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
12 sub create_fasta_file {
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
13 my ( $self, $seq ) = @_;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
14 my ( $fh, $filename ) = tempfile( "cpt.lipop.XXXXXXX", UNLINK => 1 );
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
15
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
16 #printf $fh ">%s\n%s\n", 'seq', $seq;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
17 printf $fh "%s\n", $seq;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
18 close($fh);
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
19 return $filename;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
20 }
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
21
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
22 sub parse_text {
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
23 my ($self) = @_;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
24
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
25 foreach my $line ( split( /\n/, $self->response() ) ) {
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
26 if ( $line =~ /#.*cleavage=(\d+)-(\d+)/ ) {
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
27 $self->cleavage( [ $1, $2 ] );
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
28 }
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
29 }
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
30 # # seq SpII score=17.8897 margin=13.48964 cleavage=19-20 Pos+2=K
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
31 # # Cut-off=-3
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
32 # seq LipoP1.0:Best SpII 1 1 17.8897
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
33 # seq LipoP1.0:Margin SpII 1 1 13.48964
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
34 # seq LipoP1.0:Class SpI 1 1 4.40006
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
35 # seq LipoP1.0:Class CYT 1 1 -0.200913
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
36 # seq LipoP1.0:Signal CleavII 19 20 17.8897 # LVVSA|CKSPP Pos+2=K
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
37 # seq LipoP1.0:Signal CleavI 28 29 4.03409 # PPVQS|QRPEP
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
38 # seq LipoP1.0:Signal CleavI 21 22 2.04071 # VSACK|SPPPV
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
39 # seq LipoP1.0:Signal CleavI 27 28 -2.07502 # PPPVQ|SQRPE
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
40 # seq LipoP1.0:Signal CleavI 19 20 -2.6907 # LVVSA|CKSPP
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
41 # seq LipoP1.0:Signal CleavI 22 23 -2.87659 # SACKS|PPPVQ
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
42 }
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
43
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
44 sub analyze {
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
45 my ( $self, $seq ) = @_;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
46 $self->sequence($seq);
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
47 $self->tmpfile($self->create_fasta_file($seq));
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
48 my @cmd = ( 'LipoP', $self->tmpfile(), '-workdir', '/tmp/nonexistant/', '-wwwdir', '/tmp/nonexistant' );
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
49 my ( $in, $out, $err );
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
50 run \@cmd, \$in, \$out, \$err;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
51 if ($err) { print "Error: $err\n"; }
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
52 $self->response($out);
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
53 $self->parse_text();
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
54 unlink($self->tmpfile());
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
55 }
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
56
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
57 sub cleanup {
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
58 my ($self) = @_;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
59 return;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
60 }
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
61
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
62
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
63 no Moose;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
64 1;
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
65
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
66 __END__
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
67
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
68 =pod
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
69
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
70 =encoding UTF-8
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
71
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
72 =head1 NAME
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
73
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
74 CPT::External::LipoP
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
75
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
76 =head1 VERSION
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
77
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
78 version 1.99.4
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
79
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
80 =head1 AUTHOR
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
81
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
82 Eric Rasche <rasche.eric@yandex.ru>
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
83
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
84 =head1 COPYRIGHT AND LICENSE
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
85
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
86 This software is Copyright (c) 2014 by Eric Rasche.
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
87
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
88 This is free software, licensed under:
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
89
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
90 The GNU General Public License, Version 3, June 2007
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
91
54c7a3ea81e2 Uploaded
cpt
parents:
diff changeset
92 =cut