Beefy Boxes and Bandwidth Generously Provided by pair Networks
Perl: the Markov chain saw
 
PerlMonks  

Re^2: Regular expression for a comma separated string

by naderra (Novice)
on Nov 25, 2014 at 14:25 UTC ( [id://1108351]=note: print w/replies, xml ) Need Help??


in reply to Re: Regular expression for a comma separated string
in thread Regular expression for a comma separated string

Loops, thank you kindly for your solution.

For testing, the following code generated all, up to 4 in length, possible permutations with repetition of ACGT; the inclusion of incorrect characters can be added later by hand.

#!/usr/bin/perl # usage: ./generate_ACGT_01.pl use strict; use warnings; use Math::Combinatorics; # my @n = qw(A C G T); my $o1 = Math::Combinatorics-> new(count=>1, data=>[@n], frequency=>[1, 1, 1, 1]); my $o2 = Math::Combinatorics-> new(count=>2, data=>[@n], frequency=>[2, 2, 2, 2]); my $o3 = Math::Combinatorics-> new(count=>3, data=>[@n], frequency=>[3, 3, 3, 3]); my $o4 = Math::Combinatorics-> new(count=>4, data=>[@n], frequency=>[4, 4, 4, 4]); my @b = (); # foreach my $o ($o1, $o2, $o3, $o4) { while(my @ox = $o->next_multiset) { my $p = Math::Combinatorics-> new(data=>\@ox, frequency=>[map{1} @ox]); while(my @oy = $p->next_string) { push@b, join('', @oy); } } } # foreach my $e (@b) { foreach my $f (@b) { print$e.','.$f."\n" } } # eof

test program:

#!/usr/bin/perl # usage: | test_ACGT_01.pl use strict; use warnings; ## no valued added (petty) to Loops try 2 : Y #my $side = qr/(?:([ACGT])(?![^,]*\g{-1})){1,4}/; ## try 1 from Loops : N #my $side = qr/(?:([ACGT])(?![^,]*\1))+/; ## try 2 from Loops : Y my $side = qr/(?:([ACGT])(?![^,]*\g{-1}))+/; ## while (<>) { chomp; print "$_ ". (/^$side,$side$/ ? 'Y' : 'N') . $/; } # eof

and then:

$ ./generate_ACGT_01.pl > y $ cat y | ./test_ACGT_01.pl > x $ less x

Robert

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://1108351]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others about the Monastery: (5)
As of 2024-04-18 03:13 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found