perl生成特定堿基比例的隨機(jī)序列的代碼
更新時(shí)間:2013年03月01日 11:24:56 作者:
怎么用perl程序,隨機(jī)生成一條序列,使ACGT四種堿基的含量分別為0.3,0.3,0.2,0.2!
方法一(不使用模塊,by agonyr)
復(fù)制代碼 代碼如下:
#!/usr/bin/perl -w
use strict;
my @seq = ( "A", "T", "C", "G" );
my $length = 10000;
undef my %hash;
$hash{"A"} = int( $length * 0.3 );
$hash{"C"} = int( $length * 0.3 );
$hash{"G"} = int( $length * 0.2 );
$hash{"T"} = int( $length * 0.2 );
my $i = 0;
while ( $i 《 $length ) {
my $word = $seq[ rand(@seq) ];
if ( $hash{$word} ) {
print "$word";
$i++;
}
$hash{$word}--;
}
print "n";
方法二(使用模塊,by yixf)
復(fù)制代碼 代碼如下:
#!/usr/bin/perl
use strict;
use warnings;
use BioX::SeqUtils::RandomSequence;
my $randomizer = BioX::SeqUtils::RandomSequence-》new(
{
l =》 10000,
s =》 1,
y =》 "dna",
a =》 3,
c =》 3,
g =》 2,
t =》 2
}
);
print $randomizer-》rand_seq(), "n";
兩種方法比較
設(shè)定長度為10000,ACGT的比例為3:3:2:2。
復(fù)制代碼 代碼如下:
withoutModule Length=10000 GC=49.42% A=2558,C=2503,G=2439,T=2500,Others=0
withModule Length=10000 GC=50.00% A=3000,C=3000,G=2000,T=2000,Others=0
相關(guān)文章
perl特殊符號(hào)及默認(rèn)的內(nèi)部變量
perl特殊符號(hào)及默認(rèn)的內(nèi)部變量,有需要的朋友不妨參考下2013-02-02
在EditPlus中配置Perl開發(fā)編譯環(huán)境
這篇文章主要介紹了在EditPlus中配置Perl開發(fā)編譯環(huán)境,配置起來蠻簡單,適合小型開發(fā)環(huán)境,需要的朋友可以參考下2015-06-06
強(qiáng)大的Perl正則表達(dá)式實(shí)例詳解
正則表達(dá)式是Perl語言的特色,基本的語法不是很難,但是編寫一個(gè)符合需求、高效的正則表達(dá)式,還是有一些挑戰(zhàn)的。下面這篇文章主要給大家介紹了關(guān)于強(qiáng)大的Perl正則表達(dá)式的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-11-11
perl中的字符串操作函數(shù)chomp與chop介紹
這篇文章主要介紹了perl中的字符串操作函數(shù)chomp與chop介紹,chomp與chop都是用于去除字符串變量尾部的字符,但它們有各自的區(qū)別,需要的朋友可以參考下2015-02-02

