1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
use std::convert::From;
#[derive(PartialEq, Debug, Default)]
pub struct BaseCounts {
pub a: usize,
pub c: usize,
pub g: usize,
pub t: usize,
pub n: usize,
}
impl BaseCounts {
pub fn sum(&self) -> usize {
self.a + self.c + self.g + self.t + self.n
}
}
#[derive(PartialEq, Debug, Default)]
pub struct BasePercentages {
pub a: f64,
pub c: f64,
pub g: f64,
pub t: f64,
pub n: f64,
}
impl From<BaseCounts> for BasePercentages {
fn from(counts: BaseCounts) -> Self {
let mut result = BasePercentages::default();
let sum = counts.sum() as f64;
result.a = (counts.a as f64) / sum;
result.c = (counts.c as f64) / sum;
result.g = (counts.g as f64) / sum;
result.t = (counts.t as f64) / sum;
result.n = (counts.n as f64) / sum;
result
}
}