Struct rustdct::dct3::DCT3SplitRadix [] [src]

pub struct DCT3SplitRadix<T> { /* fields omitted */ }

DCT Type 3 implemention that recursively divides the problem in half. The problem size must be a power of two.

// Computes a DCT Type 3 of size 1024
use std::sync::Arc;
use rustdct::dct3::{DCT3, DCT3SplitRadix};
use rustdct::DCTplanner;

let len = 1024;
let mut input:  Vec<f32> = vec![0f32; len];
let mut output: Vec<f32> = vec![0f32; len];

let mut planner = DCTplanner::new();
let quarter_dct = planner.plan_dct3(len / 4);
let half_dct = planner.plan_dct3(len / 2);
 
let dct = DCT3SplitRadix::new(half_dct, quarter_dct);
dct.process(&mut input, &mut output);

Methods

impl<T: DCTnum> DCT3SplitRadix<T>
[src]

[src]

Creates a new DCT3 context that will process signals of length len.

Trait Implementations

impl<T: DCTnum> DCT3<T> for DCT3SplitRadix<T>
[src]

[src]

Computes the DCT Type 3 on the input buffer and places the result in the output buffer. Read more

impl<T> Length for DCT3SplitRadix<T>
[src]

[src]

The FFT size that this algorithm can process

Auto Trait Implementations

impl<T> !Send for DCT3SplitRadix<T>

impl<T> !Sync for DCT3SplitRadix<T>