世界中の Perl マスターにこんにちは。
私はプログラミングに関して別の問題を抱えています。特定の入力番号を持つプロテオム fasta ファイルからランダムなシーケンスを選択するプログラムをコーディングしています。
一般的な fasta ファイルは次のようになります。
>seq_ID_1 説明など
>seq_ID_2 説明など ASDGDSAHSAHASDFRHGSDHSDGEWTSHSDHDSHFSDGSGASGADGHHAH ASDSADGDASHDASHSAREWAWGDASHASGASGASG
等々.......
文字はアミノ酸ペプチドを表します。
したがって、1000 シーケンスの fasta ファイルがあり、それらの 63.21% (632.1 シーケンス) を取得したいと考えています。ただし、シーケンスは浮動小数点数にすることはできないため、0.5 を超える場合は切り上げ、0.5 未満の場合は切り捨てます。
これは、ランダム シーケンス サブセットを生成するための私のコードですが、少しうまく動作しません。
#!/usr/bin/perl
#Selecting 63.21% of random sequnces from a proteom file.
use strict;
use warnings;
use List::Util qw(shuffle);
#Give the first argument as a proteom file.
if (@ARGV != 1)
{
print "Invalid arguments\n";
print "Usage: perl randseq.pl [proteom_file]";
exit(0);
}
my $FILE = $ARGV[0];
my $i = 0;
my %protseq = {};
my $nIdx = 0;
#Extraction and counting of the all headers from a proteom file.
open(LIST,$FILE);
open(TEMP1, ">temp1");
while (my $line = <LIST>){
chomp $line;
if ($line =~ />(\S+) (.+)/){
$i++;
print TEMP1 $1,"\n";
}
}
close(LIST);
close(TEMP1);
#Selection of random headers for generating a random subset of the proteom file.
my $GET_LINES = RoundToInt ($i*0.6321);
my @line_starts;
open(my $FH,'<','temp1');
open(TEMP2, ">temp2");
do {
push @line_starts, tell $FH
} while ( <$FH> );
my $count = @line_starts;
my @shuffled_starts = (shuffle @line_starts)[1..$GET_LINES+1];
for my $start ( @shuffled_starts ) {
seek $FH, $start, 0
or die "Unable to seek to line - $!\n";
print TEMP2 scalar <$FH>;
}
close(TEMP2);
#Assigning the sequence data to randomly generated header file.
open(DATA,'<','temp2');
while(my $line = <DATA>)
{
chomp($line);
$line =~ s/[\t\s]//g;
if($line =~ /^([^\s]+)/)
{
$protseq{$1}++;
}
}
close(DATA);
open(DATA, "$FILE");
open(OUT, ">random_seqs.fasta");
while(my $line = <DATA>)
{
chomp($line);
if($line =~ /^>([^\s]+)/)
{
if($protseq{$1} ne "")
{
$nIdx = 1;
print OUT "$line\n";
}
else
{
$nIdx = 0;
}
}
else
{
if($nIdx == 1)
{
print OUT "$line\n";
}
}
}
close(DATA);
close(OUT);
#subroutine for rounding
sub RoundToInt {
int($_[0] + .5 * ($_[0] <=> 0));
}
system("erase temp1");
system("erase temp2");
exit;
ただし、適切な数のシーケンスが得られることもあれば、もう 1 つのシーケンスが得られることもあります。どうすればそれを取り除くことができますか...何かアイデアをお願いします?
またはおそらくより短いコードですか?
ここでは、75 酵母プロテオム ファイルを取得できます。[http://www.peroxisomedb.org/Download/Saccharomyces_cerevisiae.fas][1]
これをすぐに修正できることを願っています... :(