2007-09-20 18:09:08 -04:00
|
|
|
USING: io io.files io.streams.duplex kernel sequences
|
|
|
|
sequences.private strings vectors words memoize splitting
|
2008-02-01 19:26:32 -05:00
|
|
|
hints unicode.case ;
|
2007-09-20 18:09:08 -04:00
|
|
|
IN: benchmark.reverse-complement
|
|
|
|
|
|
|
|
MEMO: trans-map ( -- str )
|
|
|
|
256 >string
|
|
|
|
"TGCAAKYRMBDHV" "ACGTUMRYKVHDB"
|
|
|
|
[ pick set-nth ] 2each ;
|
|
|
|
|
|
|
|
: do-trans-map ( str -- )
|
|
|
|
[ ch>upper trans-map nth ] change-each ;
|
|
|
|
|
|
|
|
HINTS: do-trans-map string ;
|
|
|
|
|
|
|
|
: translate-seq ( seq -- str )
|
|
|
|
concat dup reverse-here dup do-trans-map ;
|
|
|
|
|
|
|
|
: show-seq ( seq -- )
|
|
|
|
translate-seq 60 <groups> [ print ] each ;
|
|
|
|
|
|
|
|
: do-line ( seq line -- seq )
|
|
|
|
dup first ">;" memq? [
|
|
|
|
over show-seq print dup delete-all
|
|
|
|
] [
|
|
|
|
over push
|
|
|
|
] if ;
|
|
|
|
|
2007-12-08 17:47:39 -05:00
|
|
|
HINTS: do-line vector string ;
|
|
|
|
|
2007-09-20 18:09:08 -04:00
|
|
|
: (reverse-complement) ( seq -- )
|
|
|
|
readln [ do-line (reverse-complement) ] [ show-seq ] if* ;
|
|
|
|
|
|
|
|
: reverse-complement ( infile outfile -- )
|
|
|
|
<file-writer> >r <file-reader> r> <duplex-stream> [
|
|
|
|
500000 <vector> (reverse-complement)
|
|
|
|
] with-stream ;
|
|
|
|
|
|
|
|
: reverse-complement-main ( -- )
|
2008-01-04 22:02:09 -05:00
|
|
|
"extra/benchmark/reverse-complement/reverse-complement-test-in.txt"
|
|
|
|
"extra/benchmark/reverse-complement/reverse-complement-test-out.txt"
|
2008-01-04 21:51:02 -05:00
|
|
|
[ resource-path ] 2apply
|
2007-09-20 18:09:08 -04:00
|
|
|
reverse-complement ;
|
|
|
|
|
|
|
|
MAIN: reverse-complement-main
|