aboutsummaryrefslogtreecommitdiff
path: root/evc/src/bin
diff options
context:
space:
mode:
authormetamuffin <metamuffin@disroot.org>2022-12-06 15:52:08 +0100
committermetamuffin <metamuffin@disroot.org>2022-12-06 15:52:08 +0100
commit6a3aaca8727d3f0292d62dbcd54e3bf87df74c0c (patch)
treed9bc5fe941c49de0885795288e2ef45f88d0a40c /evc/src/bin
parenta5b09a2fc7a2e1ddc5776993373052cd3eda9b51 (diff)
downloadvideo-codec-experiments-6a3aaca8727d3f0292d62dbcd54e3bf87df74c0c.tar
video-codec-experiments-6a3aaca8727d3f0292d62dbcd54e3bf87df74c0c.tar.bz2
video-codec-experiments-6a3aaca8727d3f0292d62dbcd54e3bf87df74c0c.tar.zst
split files
Diffstat (limited to 'evc/src/bin')
-rw-r--r--evc/src/bin/decode.rs22
-rw-r--r--evc/src/bin/encode.rs40
2 files changed, 9 insertions, 53 deletions
diff --git a/evc/src/bin/decode.rs b/evc/src/bin/decode.rs
index 44fcbe4..1500633 100644
--- a/evc/src/bin/decode.rs
+++ b/evc/src/bin/decode.rs
@@ -3,6 +3,7 @@ use anyhow::Context;
use clap::Parser;
use evc::{
block::{Block, BlockInner},
+ codec::decode::decode_block,
frame::Frame,
header::Header,
pixel::Pixel,
@@ -34,15 +35,11 @@ fn main() -> anyhow::Result<()> {
let block = Block::read(&mut input, size).context("reading encoded frame")?;
let mut frame = Frame::new(size);
- blit_block(
- &block,
- frame.view_mut((0, 0), size),
- prev.view((0, 0), size),
- );
+ decode_block(&block, frame.view_mut(), prev.view());
if args.debug {
let mut f2 = frame.clone();
- draw_debug(&block, f2.view_mut((0, 0), size));
+ draw_debug(&block, f2.view_mut());
f2.write(&mut output).context("writing raw frame")?;
} else {
frame.write(&mut output).context("writing raw frame")?;
@@ -54,19 +51,6 @@ fn main() -> anyhow::Result<()> {
Ok(())
}
-fn blit_block(block: &Block, mut target: View<&mut Frame>, prev: View<&Frame>) {
- match &block.inner {
- BlockInner::Literal(pixels) => target.set_pixels(pixels),
- BlockInner::Split(box [a, b]) => {
- let [at, bt] = target.split_mut_unsafe();
- let [ap, bp] = prev.split();
- blit_block(a, at, ap);
- blit_block(b, bt, bp);
- }
- BlockInner::Reference { translation: _ } => target.copy_from(&prev),
- }
-}
-
fn draw_debug(block: &Block, mut target: View<&mut Frame>) {
match &block.inner {
BlockInner::Literal(_) => {
diff --git a/evc/src/bin/encode.rs b/evc/src/bin/encode.rs
index 3e34a3c..50435e5 100644
--- a/evc/src/bin/encode.rs
+++ b/evc/src/bin/encode.rs
@@ -1,11 +1,10 @@
use anyhow::Context;
use clap::Parser;
use evc::{
- block::{Block, BlockInner},
+ codec::{decode::decode_block, encode::encode_block},
frame::Frame,
header::Header,
ser::Sink,
- view::View,
};
use std::io::{BufReader, BufWriter};
@@ -35,47 +34,20 @@ fn main() -> anyhow::Result<()> {
let mut prev_frame = Frame::new(size);
for i in 0.. {
eprintln!("encode frame {i}");
- let frame = Frame::read(&mut input, size)
+ let mut frame = Frame::read(&mut input, size)
.context("reading raw frame")
.unwrap();
- let v1 = frame.view((0, 0), size);
- let v2 = prev_frame.view((0, 0), size);
+ let v1 = frame.view();
+ let v2 = prev_frame.view();
let root = encode_block(v1, v2);
root.write(&mut output).context("writing encoded frame")?;
+ decode_block(&root, frame.view_mut(), prev_frame.view());
+
prev_frame = frame;
}
Ok(())
}
-
-fn encode_block(view: View<&Frame>, prev: View<&Frame>) -> Block {
- let diff = View::diff(&view, &prev) / view.area() as f64;
- // eprintln!("{:?} {diff}", view.size);
- let inner = if diff < 0.9 {
- BlockInner::Reference {
- translation: (0, 0),
- }
- } else {
- if view.size.0 < 32 {
- BlockInner::Literal(view.pixels())
- } else {
- let [av, bv] = view.split();
- let [ap, bp] = prev.split();
- let a = encode_block(av, ap);
- let b = encode_block(bv, bp);
- if a.is_literal() && b.is_literal() {
- BlockInner::Literal(view.pixels())
- } else {
- BlockInner::Split(Box::new([a, b]))
- }
- }
- };
-
- Block {
- size: view.size,
- inner,
- }
-}