X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=nihav-duck%2Fsrc%2Fcodecs%2Fvpcommon.rs;h=bd7d1cf49066df5e99ea8d61ac501686c378e3b3;hb=0949792ea4f92a10f4f5deadde645349d31d4282;hp=3caf56997f6d96aed2f7361e909fd191fde4f9c4;hpb=3f67638d8b7e163be9579e99a05f672f2ec4f144;p=nihav.git diff --git a/nihav-duck/src/codecs/vpcommon.rs b/nihav-duck/src/codecs/vpcommon.rs index 3caf569..bd7d1cf 100644 --- a/nihav-duck/src/codecs/vpcommon.rs +++ b/nihav-duck/src/codecs/vpcommon.rs @@ -68,6 +68,9 @@ impl VPShuffler { None } } + pub fn has_refs(&self) -> bool { + self.lastframe.is_some() + } } pub const VP56_COEF_BASE: [i16; 6] = [ 5, 7, 11, 19, 35, 67 ]; @@ -120,6 +123,20 @@ impl<'a> BoolCoder<'a> { } val } + pub fn read_byte(&mut self) -> u8 { + let mut val = 0u8; + for _ in 0..8 { + val = (val << 1) | (self.read_prob(128) as u8); + } + val + } + pub fn read_sbits(&mut self, bits: u8) -> i32 { + let mut val = if self.read_prob(128) { -1i32 } else { 0i32 }; + for _ in 1..bits { + val = (val << 1) | (self.read_prob(128) as i32); + } + val + } pub fn read_probability(&mut self) -> u8 { let val = self.read_bits(7) as u8; if val == 0 { @@ -415,21 +432,33 @@ fn vp3_interp10(dst: &mut [u8], dstride: usize, src: &[u8], sstride: usize, bw: } } -fn vp3_interp11(dst: &mut [u8], dstride: usize, src: &[u8], sstride: usize, bw: usize, bh: usize) +fn vp3_interp1x(dst: &mut [u8], dstride: usize, src: &[u8], sstride: usize, bw: usize, bh: usize) { let mut didx = 0; let mut sidx = 0; for _ in 0..bh { for x in 0..bw { dst[didx + x] = (((src[sidx + x] as u16) + - (src[sidx + x + 1] as u16) + - (src[sidx + x + sstride] as u16) + - (src[sidx + x + sstride + 1] as u16)) >> 2) as u8; + (src[sidx + x + sstride + 1] as u16)) >> 1) as u8; + } + didx += dstride; + sidx += sstride; + } +} + +fn vp3_interp1y(dst: &mut [u8], dstride: usize, src: &[u8], sstride: usize, bw: usize, bh: usize) +{ + let mut didx = 0; + let mut sidx = 0; + for _ in 0..bh { + for x in 0..bw { + dst[didx + x] = (((src[sidx + x + 1] as u16) + + (src[sidx + x + sstride] as u16)) >> 1) as u8; } didx += dstride; sidx += sstride; } } -pub const VP3_INTERP_FUNCS: &[blockdsp::BlkInterpFunc] = &[ vp3_interp00, vp3_interp01, vp3_interp10, vp3_interp11 ]; +pub const VP3_INTERP_FUNCS: &[blockdsp::BlkInterpFunc] = &[ vp3_interp00, vp3_interp01, vp3_interp10, vp3_interp1x, vp3_interp1y ];