pub struct MixedRadix<T> { /* private fields */ }
Expand description

Implementation of the Mixed-Radix FFT algorithm

This algorithm factors a size n FFT into n1 * n2, computes several inner FFTs of size n1 and n2, then combines the results to get the final answer

// Computes a forward FFT of size 1200, using the Mixed-Radix Algorithm
use rustfft::algorithm::MixedRadix;
use rustfft::{Fft, FftPlanner};
use rustfft::num_complex::Complex;

let mut buffer = vec![Complex{ re: 0.0f32, im: 0.0f32 }; 1200];

// we need to find an n1 and n2 such that n1 * n2 == 1200
// n1 = 30 and n2 = 40 satisfies this
let mut planner = FftPlanner::new();
let inner_fft_n1 = planner.plan_fft_forward(30);
let inner_fft_n2 = planner.plan_fft_forward(40);

// the mixed radix FFT length will be inner_fft_n1.len() * inner_fft_n2.len() = 1200
let fft = MixedRadix::new(inner_fft_n1, inner_fft_n2);
fft.process(&mut buffer);

Implementations§

source§

impl<T: FftNum> MixedRadix<T>

source

pub fn new(width_fft: Arc<dyn Fft<T>>, height_fft: Arc<dyn Fft<T>>) -> Self

Creates a FFT instance which will process inputs/outputs of size width_fft.len() * height_fft.len()

Trait Implementations§

source§

impl<T: FftNum> Direction for MixedRadix<T>

source§

fn fft_direction(&self) -> FftDirection

Returns FftDirection::Forward if this instance computes forward FFTs, or FftDirection::Inverse for inverse FFTs
source§

impl<T: FftNum> Fft<T> for MixedRadix<T>

source§

fn process_outofplace_with_scratch( &self, input: &mut [Complex<T>], output: &mut [Complex<T>], scratch: &mut [Complex<T>] )

Divides input and output into chunks of size self.len(), and computes a FFT on each chunk. Read more
source§

fn process_with_scratch( &self, buffer: &mut [Complex<T>], scratch: &mut [Complex<T>] )

Divides buffer into chunks of size self.len(), and computes a FFT on each chunk. Read more
source§

fn get_inplace_scratch_len(&self) -> usize

Returns the size of the scratch buffer required by process_with_scratch Read more
source§

fn get_outofplace_scratch_len(&self) -> usize

Returns the size of the scratch buffer required by process_outofplace_with_scratch Read more
source§

fn process(&self, buffer: &mut [Complex<T>])

Computes a FFT in-place. Read more
source§

impl<T: FftNum> Length for MixedRadix<T>

source§

fn len(&self) -> usize

The FFT size that this algorithm can process

Auto Trait Implementations§

§

impl<T> !RefUnwindSafe for MixedRadix<T>

§

impl<T> Send for MixedRadix<T>
where T: Send,

§

impl<T> Sync for MixedRadix<T>
where T: Sync,

§

impl<T> Unpin for MixedRadix<T>

§

impl<T> !UnwindSafe for MixedRadix<T>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.