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
use std::io::Read;
use bitbit::reader::Bit;
use bitbit::BitReader;
use std::error::Error;
use crate::util::source_model::SourceModel;
use super::decoder::ArithmeticDecoder;
pub struct BinaryDecoder {
models: Vec<SourceModel>
}
impl BinaryDecoder {
pub fn new(max_value: u32) -> Self {
let bit_width = 32 - max_value.leading_zeros();
let mut models: Vec<SourceModel> = Vec::with_capacity(bit_width as usize);
for _i in 0..bit_width {
models.push(SourceModel::new_binary());
}
Self {
models
}
}
pub fn decode<R: Read, B: Bit>(&mut self, decoder: &mut ArithmeticDecoder, input: &mut BitReader<R, B>) -> Result<u32, Box<Error>> {
let mut value: u32 = 0;
for model in self.models.iter_mut() {
let sym = decoder.decode(model, input)?;
model.update_symbol(sym);
value = value * 2 + sym;
}
Ok(value)
}
}