]>
git.proxmox.com Git - cargo.git/blob - vendor/regex/examples/shootout-regex-dna-bytes.rs
1 // The Computer Language Benchmarks Game
2 // http://benchmarksgame.alioth.debian.org/
4 // contributed by the Rust Project Developers
5 // contributed by TeXitoi
6 // contributed by BurntSushi
10 use std
::io
::{self, Read}
;
16 ::regex
::bytes
::Regex
::new($re
).unwrap()
21 let mut seq
= Vec
::with_capacity(51 * (1 << 20));
22 io
::stdin().read_to_end(&mut seq
).unwrap();
25 seq
= regex
!(">[^\n]*\n|\n").replace_all(&seq
, &b
""[..]).into_owned();
27 let seq_arc
= Arc
::new(seq
.clone());
30 regex
!("agggtaaa|tttaccct"),
31 regex
!("[cgt]gggtaaa|tttaccc[acg]"),
32 regex
!("a[act]ggtaaa|tttacc[agt]t"),
33 regex
!("ag[act]gtaaa|tttac[agt]ct"),
34 regex
!("agg[act]taaa|ttta[agt]cct"),
35 regex
!("aggg[acg]aaa|ttt[cgt]ccct"),
36 regex
!("agggt[cgt]aa|tt[acg]accct"),
37 regex
!("agggta[cgt]a|t[acg]taccct"),
38 regex
!("agggtaa[cgt]|[acg]ttaccct"),
40 let mut counts
= vec
![];
41 for variant
in variants
{
42 let seq
= seq_arc
.clone();
43 let restr
= variant
.to_string();
44 let future
= thread
::spawn(move || variant
.find_iter(&seq
).count());
45 counts
.push((restr
, future
));
49 (regex
!("B"), &b
"(c|g|t)"[..]),
50 (regex
!("D"), &b
"(a|g|t)"[..]),
51 (regex
!("H"), &b
"(a|c|t)"[..]),
52 (regex
!("K"), &b
"(g|t)"[..]),
53 (regex
!("M"), &b
"(a|c)"[..]),
54 (regex
!("N"), &b
"(a|c|g|t)"[..]),
55 (regex
!("R"), &b
"(a|g)"[..]),
56 (regex
!("S"), &b
"(c|g)"[..]),
57 (regex
!("V"), &b
"(a|c|g)"[..]),
58 (regex
!("W"), &b
"(a|t)"[..]),
59 (regex
!("Y"), &b
"(c|t)"[..]),
62 for (re
, replacement
) in substs
{
63 seq
= re
.replace_all(&seq
, replacement
).into_owned();
66 for (variant
, count
) in counts
{
67 println
!("{} {}", variant
, count
.join().unwrap());
69 println
!("\n{}\n{}\n{}", ilen
, clen
, seq
.len());