SRS'de Coklu Arama Yapmak
By Güngör Budak
- 2 minutes read - 258 wordsInceleme yapan scriptin en son hali, oncekilere gore daha fazla okuma inceliyor oldugu icin her okuma icin SRS uzerinde isim aramak oldukca zaman alan bir islemdi. Oyle ki, son inceleme 4 gun surdu.
Bunu azaltmak icin inceleme scriptini tamamen degistirdim. Oncelikle her zaman oldugu gibi esik degerini gecenleri aliyor ama direkt bunlarin ID numaralarini bir dizide (array) listeliyorum. Daha sonra bu listenin herbir elemanini boru karakteri ile ayirarak bir string haline getiriyorum. Son olarak bu stringi direkt getz komutuyla SRS’de aratip, tek seferde tum sayfada esik degerini gecen organizmalarin isimlerini alip, bunlari tek tek okuyup ayirarak hash icinde sakliyorum.
1while (@params = $blast_obj->next_alignment(fields => ['name', 'identity', 'overlap'])) {
2 $overlap_seen = $params[2];
3 $mismatch_seen = $params[2] - $params[1];
4
5 if ($overlap_seen >= $overlap_threshold and $mismatch_seen <= $mismatch_threshold) {
6 if ($database eq "refseq_dna") {
7 $params[0] =~ /:([A-Z|0-9]*\_[A-Z|0-9]*)/;
8 push(@names, $1);
9 }
10 }
11 }
12
13 $ids = join("|", @names);
14
15 if ( !($ids eq "") ) {
16 open (PIPE, "getz '[$database:$ids]' -vf 'ORGANISM' |") or die $!;
17 while(my $line = <PIPE>) {
18 $line =~ /\t(.*)/;
19 $organism_names{$1}++;
20 }
21 }
22 close PIPE;
Gene her ID numarasini duzenli ifade ile elde edip, bunu @names dizisine push komutu ile ekliyorum. Bu tumu icin bittiginde liste elemanlarini join komutu ile aralarinda “|” karakteri olacak sekilde birlestirip $ids stringini elde ediyorum. Sonra eger bu string bos degilse getz komutuyla arama yapip, elde ettigim cok satirli ciktiyi [ozel bir sekilde okuyup]({% post_url 2012-07-23-unixte-perl-ile-bir-komut-ciktisini-okumak %}) her organizma ismini %organism_names hashine key olarak ekliyorum.