aboutsummaryrefslogtreecommitdiff
path: root/evc/src/bin/encode.rs
diff options
context:
space:
mode:
authormetamuffin <metamuffin@disroot.org>2025-05-05 15:09:54 +0200
committermetamuffin <metamuffin@disroot.org>2025-05-05 15:09:54 +0200
commit306f96164784a8cbf405e72fa4364d6523366e95 (patch)
tree51717fc139871baa438aad806f4923669ae0896c /evc/src/bin/encode.rs
parent9cc089e2d6e841879e430b01d2f3d92c8820523e (diff)
downloadvideo-codec-experiments-306f96164784a8cbf405e72fa4364d6523366e95.tar
video-codec-experiments-306f96164784a8cbf405e72fa4364d6523366e95.tar.bz2
video-codec-experiments-306f96164784a8cbf405e72fa4364d6523366e95.tar.zst
old dir
Diffstat (limited to 'evc/src/bin/encode.rs')
-rw-r--r--evc/src/bin/encode.rs111
1 files changed, 0 insertions, 111 deletions
diff --git a/evc/src/bin/encode.rs b/evc/src/bin/encode.rs
deleted file mode 100644
index 43f2c57..0000000
--- a/evc/src/bin/encode.rs
+++ /dev/null
@@ -1,111 +0,0 @@
-use anyhow::Context;
-use clap::Parser;
-use indicatif::ProgressBar;
-use libreschmux::{
- codec::{
- decode::{decode_block, DecodeConfig},
- encode::{encode_block, EncodeConfig, EncodeMode},
- },
- format::{header::Header, ser::Sink},
- frame::Frame,
- helpers::vector::Vec2,
-};
-use log::info;
-use std::io::{BufReader, BufWriter};
-
-#[derive(Parser)]
-#[clap(about, version)]
-pub struct EncodeArgs {
- #[arg(short = 'W', long)]
- width: usize,
- #[arg(short = 'H', long)]
- height: usize,
-
- #[arg(short, long)]
- mode: EncodeMode,
-
- #[arg(long)]
- no_linear_transform: bool,
- #[arg(long)]
- no_value_scale: bool,
- #[arg(long)]
- no_translate: bool,
-
- #[arg[short = 'L', long]]
- length: Option<usize>,
-
- #[arg(short, long, default_value = "8")]
- min_block_size: isize,
-
- #[arg(short = 't', long, default_value = "200")]
- ref_thres: f64,
-}
-
-fn main() -> anyhow::Result<()> {
- env_logger::init_from_env("LOG");
- let args = EncodeArgs::parse();
-
- let mut input = BufReader::new(std::io::stdin());
- let mut output = BufWriter::new(std::io::stdout());
-
- let config = EncodeConfig {
- mode: args.mode,
- ref_thres: args.ref_thres,
- weight_factor: 50.0,
- max_diff_area: 10_000,
- min_block_size: args.min_block_size,
- do_translate: !args.no_translate,
- do_linear_transform: !args.no_linear_transform,
- do_value_scale: !args.no_value_scale,
- };
-
- let size = Vec2 {
- x: args.width as isize,
- y: args.height as isize,
- };
- output
- .put(Header {
- resolution: size,
- frame_count: args.length.unwrap_or(usize::MAX),
- })
- .context("writing header")?;
-
- let progress_bar = args.length.map(|len| ProgressBar::new(len as u64));
- let mut prev_frame = Frame::new(size);
-
- for i in 0.. {
- info!("encode frame {i}");
- let mut frame = Frame::read(&mut input, size).context("reading raw frame")?;
-
- let v1 = frame.view();
- let v2 = prev_frame.view();
-
- let (error, root) = encode_block(v1, v2, &config);
-
- // compress_block(
- // &mut root,
- // Vec2 {
- // x: size.x as usize,
- // y: size.y as usize,
- // },
- // );
-
- root.write(&mut output, size)
- .context("writing encoded frame")?;
-
- info!(
- "cumulative error: {error} ({} per pixel)",
- error / frame.view().area() as f64
- );
-
- if let Some(progress_bar) = &progress_bar {
- progress_bar.inc(1);
- }
-
- decode_block(&root, frame.view_mut(), prev_frame.view(), &DecodeConfig {});
-
- prev_frame = frame;
- }
-
- Ok(())
-}