X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=nihav-duck%2Fsrc%2Fcodecs%2Fvp3.rs;h=947377498cf698d95cbace4d5d33462a2296f0a2;hb=72c6f2634b57fe73d101376602e21b81bebf3c1a;hp=059ff9da7a6416686334ea7f4474d414138f863c;hpb=503368d15e17aa865c8abc6ebcc2943ad822867b;p=nihav.git diff --git a/nihav-duck/src/codecs/vp3.rs b/nihav-duck/src/codecs/vp3.rs index 059ff9d..9473774 100644 --- a/nihav-duck/src/codecs/vp3.rs +++ b/nihav-duck/src/codecs/vp3.rs @@ -1537,50 +1537,28 @@ println!("intra, ver {} (self {})", version, self.version); if self.blocks[blk_idx + bx].btype != VPMBType::InterFourMV { continue; } - let mv_a = self.blocks[blk_idx + bx].mv; - let mv_b = self.blocks[blk_idx + bx + 1].mv; - let mv_c = self.blocks[blk_idx + bx + bstride].mv; - let mv_d = self.blocks[blk_idx + bx + 1 + bstride].mv; - let mut mv_sum = mv_a + mv_b + mv_c + mv_d; + let mvs = [ self.blocks[blk_idx + bx].mv, + self.blocks[blk_idx + bx + 1].mv, + self.blocks[blk_idx + bx + bstride].mv, + self.blocks[blk_idx + bx + 1 + bstride].mv ]; + let mut mv_sum = mvs[0] + mvs[1] + mvs[2] + mvs[3]; mv_sum.x = (mv_sum.x + 2) >> 2; mv_sum.y = (mv_sum.y + 2) >> 2; let src = self.shuf.get_last().unwrap(); - let mode = ((mv_a.x & 1) + (mv_a.y & 1) * 2) as usize; - if self.version != 4 { - copy_block(frm, src.clone(), 0, bx * 8, by * 8, - mv_a.x >> 1, mv_a.y >> 1, 8, 8, 0, 1, mode, VP3_INTERP_FUNCS); - } else { - vp_copy_block(frm, src.clone(), 0, bx * 8, by * 8, - mv_a.x >> 1, mv_a.y >> 1, 0, 1, self.loop_str, - mode, VP3_INTERP_FUNCS, self.mc_buf.clone()); - } - let mode = ((mv_b.x & 1) + (mv_b.y & 1) * 2) as usize; - if self.version != 4 { - copy_block(frm, src.clone(), 0, bx * 8 + 8, by * 8, - mv_b.x >> 1, mv_b.y >> 1, 8, 8, 0, 1, mode, VP3_INTERP_FUNCS); - } else { - vp_copy_block(frm, src.clone(), 0, bx * 8 + 8, by * 8, - mv_b.x >> 1, mv_b.y >> 1, 0, 1, self.loop_str, - mode, VP3_INTERP_FUNCS, self.mc_buf.clone()); - } - let mode = ((mv_c.x & 1) + (mv_c.y & 1) * 2) as usize; - if self.version != 4 { - copy_block(frm, src.clone(), 0, bx * 8, by * 8 + 8, - mv_c.x >> 1, mv_c.y >> 1, 8, 8, 0, 1, mode, VP3_INTERP_FUNCS); - } else { - vp_copy_block(frm, src.clone(), 0, bx * 8, by * 8 + 8, - mv_c.x >> 1, mv_c.y >> 1, 0, 1, self.loop_str, - mode, VP3_INTERP_FUNCS, self.mc_buf.clone()); - } - let mode = ((mv_d.x & 1) + (mv_d.y & 1) * 2) as usize; - if self.version != 4 { - copy_block(frm, src.clone(), 0, bx * 8 + 8, by * 8 + 8, - mv_d.x >> 1, mv_d.y >> 1, 8, 8, 0, 1, mode, VP3_INTERP_FUNCS); - } else { - vp_copy_block(frm, src.clone(), 0, bx * 8 + 8, by * 8 + 8, - mv_d.x >> 1, mv_d.y >> 1, 0, 1, self.loop_str, - mode, VP3_INTERP_FUNCS, self.mc_buf.clone()); + for i in 0..4 { + let xoff = (i & 1) * 8; + let yoff = (i >> 1) * 8; + + let mode = ((mvs[i].x & 1) + (mvs[i].y & 1) * 2) as usize; + if self.version != 4 { + copy_block(frm, src.clone(), 0, bx * 8 + xoff, by * 8 + yoff, + mvs[i].x >> 1, mvs[i].y >> 1, 8, 8, 0, 1, mode, VP3_INTERP_FUNCS); + } else { + vp_copy_block(frm, src.clone(), 0, bx * 8 + xoff, by * 8 + yoff, + mvs[i].x >> 1, mvs[i].y >> 1, 0, 1, self.loop_str, + mode, VP3_INTERP_FUNCS, self.mc_buf.clone()); + } } let mx = (mv_sum.x >> 1) | (mv_sum.x & 1); @@ -1709,12 +1687,27 @@ println!("intra, ver {} (self {})", version, self.version); } blk_idx += blk_w; } -/* for plane in 1..3 { + let blk_w = self.mb_w; + for plane in 1..3 { for by in 0..self.mb_h { for bx in 0..self.mb_w { + let blk = &self.blocks[blk_idx + bx]; + if (bx > 0) && blk.coded { + vp31_loop_filter_v(frm, bx * 8, by * 8, plane, self.loop_str); + } + if (by > 0) && blk.coded { + vp31_loop_filter_h(frm, bx * 8, by * 8, plane, self.loop_str); + } + if (bx < blk_w - 1) && !self.blocks[blk_idx + bx + 1].coded { + vp31_loop_filter_v(frm, bx * 8 + 8, by * 8, plane, self.loop_str); + } + if (by < self.mb_h - 1) && !self.blocks[blk_idx + bx + blk_w].coded { + vp31_loop_filter_h(frm, bx * 8, by * 8 + 8, plane, self.loop_str); + } } + blk_idx += blk_w; } - }*/ + } } fn generate_block_addr(&mut self) { let sb_w_y = (self.width + 31) >> 5;