pub struct GoodThomasAlgorithm<T> { /* private fields */ }
Expand description
Implementation of the Good-Thomas Algorithm (AKA Prime Factor Algorithm)
This algorithm factors a size n FFT into n1 * n2, where GCD(n1, n2) == 1
Conceptually, this algorithm is very similar to the Mixed-Radix, except because GCD(n1, n2) == 1 we can do some number theory trickery to reduce the number of floating-point multiplications and additions. Additionally, It can be faster than Mixed-Radix at sizes below 10,000 or so.
// Computes a forward FFT of size 1200, using the Good-Thomas Algorithm
use rustfft::algorithm::GoodThomasAlgorithm;
use rustfft::{Fft, FftPlanner};
use rustfft::num_complex::Complex;
use rustfft::num_traits::Zero;
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 and GCD(n1, n2) == 1
// n1 = 48 and n2 = 25 satisfies this
let mut planner = FftPlanner::new();
let inner_fft_n1 = planner.plan_fft_forward(48);
let inner_fft_n2 = planner.plan_fft_forward(25);
// the good-thomas FFT length will be inner_fft_n1.len() * inner_fft_n2.len() = 1200
let fft = GoodThomasAlgorithm::new(inner_fft_n1, inner_fft_n2);
fft.process(&mut buffer);
Implementations§
Trait Implementations§
Source§impl<T: FftNum> Direction for GoodThomasAlgorithm<T>
impl<T: FftNum> Direction for GoodThomasAlgorithm<T>
Source§fn fft_direction(&self) -> FftDirection
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 GoodThomasAlgorithm<T>
impl<T: FftNum> Fft<T> for GoodThomasAlgorithm<T>
Source§fn process_outofplace_with_scratch(
&self,
input: &mut [Complex<T>],
output: &mut [Complex<T>],
scratch: &mut [Complex<T>],
)
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 moreSource§fn process_with_scratch(
&self,
buffer: &mut [Complex<T>],
scratch: &mut [Complex<T>],
)
fn process_with_scratch( &self, buffer: &mut [Complex<T>], scratch: &mut [Complex<T>], )
Source§fn get_inplace_scratch_len(&self) -> usize
fn get_inplace_scratch_len(&self) -> usize
Returns the size of the scratch buffer required by
process_with_scratch
Read moreSource§fn get_outofplace_scratch_len(&self) -> usize
fn get_outofplace_scratch_len(&self) -> usize
Returns the size of the scratch buffer required by
process_outofplace_with_scratch
Read moreAuto Trait Implementations§
impl<T> Freeze for GoodThomasAlgorithm<T>
impl<T> !RefUnwindSafe for GoodThomasAlgorithm<T>
impl<T> Send for GoodThomasAlgorithm<T>
impl<T> Sync for GoodThomasAlgorithm<T>
impl<T> Unpin for GoodThomasAlgorithm<T>
impl<T> !UnwindSafe for GoodThomasAlgorithm<T>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more