poegi has asked for the wisdom of the Perl Monks concerning the following question:

My intention is to simulate random positions.

I do have: Range (length of my gene) - this should be Start & End positions; Genome - dataset where those ranges should be randomly "attached" hence getting random position.

I already have this: Input - ranges & genome dataset (lots of letters - sorry guys can't post it here).

There is some kind of a mistake in that script and I can't spot it - hope someone could easily solve this misspelling. Whole idea of the script is to: split genome into chromosomes (names) -> get their length -> "attach" my range -> get start & end.

#!/usr/bin/perl use strict; use warnings; use File::Spec; my @name; my @length; open(GENDATA, "<$ARGV[1]"); while (<GENDATA>) { chomp($_); my @field=split(/\t/, $_); push(@length, $field[1]); push(@name, $field[0]); } close(GENDATA); open(RANGE, "<$ARGV[0]"); while (<RANGE>) { chomp($_); my $simlen = $_; my $randname = 0; my $randpos = 0; do { $randname = int(rand(scalar(@name))); $randpos = int(rand($length[$randname] - $simlen - 1)); print $name[$randname] ."\t". $randpos ."\t". ($randpos + $simlen) +."\n"; }} close(RANGE);

Examples:

Range

48 479 324 69 12

Gendata

>chr4.fa_58086846_58087846 GGGATAAGGTGGAAGCAATGATTTAATCACCACAGAAGAAATGTGCTCTGATTAATTGGG AAGAAAGATTTTAAAATTAGAGTTATTCAGAAAGCCTGTCAGGAGACCAGGAAGAGAGGA AAGGATGTGTGTCAACACCTACAGAAAGCTGTCTGTGAAGCTGGGTTATAACCTGATACT TCTGGTCTTCCCTGTAACTAAATGTCCTTTGCTGAGGCCTGAGGCAGACCCTTACTCTGG GTTTCCTGTTCCTGTATGACTAGTTTCAGTCAGGCTTTACGTAGTCATTCTGCCCTGCAG AGCAATCACAGGAGGTAAGAAGGCATGGTCGTTAATAGCATGGGCTATGCTGTTGGACTT GAATTTGGTCTTGTTTCTATCACATTCTGTAATTTAGTTGAAAAATGGAAATAACACCTA TCTCAAGGGTTTGTTGCAAAGACTACATGAGATTATACATGCACAGCGCTTAGTACAGTG TCTGATACATAGTAAATGTTCTTTTTTTTTTTTTTTTTTTTTTTTTTATTATACTCTAAG TTTTAGGGTACATGTGCACATTGTGCAGGTTAGTTACATATGTATACATGTGCCATGCTG GTGCGCTGCACCCACTAATGTGTCATCTAGCATTAGGTATATCTCCCAATGCTATCCCTC CCCCCTCCCCCGACCCCACCTCAGTCCCCAGAGTGTGATATTCCCCTTCCTGTGTCCATG TGATCTCATTGTTCAATTCCCACCTATGAGTGAGAATATGCGGTGTTTGGTTTTTTGTTC TTGCGATAGTTTACTGAGAATGATGGTTTCCAATTTCATCCATGTCCCTACAAAGGATAT GAACTCATCATTTTTTATGGCTGCATAGTATTCCATGGTGTATATGTGAGTAAATGTTCT TTAGCAGCTGTCATTATCATTTTAGAGACAGAGTCTTGCTGGCATTATCTTCCCCATTTT GCTCATGGAGAAACTGAAATAAGAAAATTATAGTCTGACT

Replies are listed 'Best First'.
Re: Simulating random position in the given dataset (Bioinfo)
by snape (Pilgrim) on Apr 24, 2012 at 21:46 UTC

    What are you trying to do ? Your code does not make sense to me. Your split function is not doing anything. The size of array @field is 1 and both your @length and @name contains the same elements. Your $field1 has an uninitialized value.

    Also, your loop for Range data loop doesn't makes sense to me. Illustrate your problem in steps.

Re: Simulating random position in the given dataset (Bioinfo)
by toolic (Bishop) on Apr 24, 2012 at 20:14 UTC