Trait basic_dsp::TimeToFrequencyDomainOperations [−][src]
pub trait TimeToFrequencyDomainOperations<S, T>: ToFreqResult where
T: RealNumber,
S: ToSliceMut<T>, { fn plain_fft<B>(self, buffer: &mut B) -> Self::FreqResult
where
B: for<'a> Buffer<'a, S, T>; fn fft<B>(self, buffer: &mut B) -> Self::FreqResult
where
B: for<'a> Buffer<'a, S, T>; fn windowed_fft<B>(
self,
buffer: &mut B,
window: &dyn WindowFunction<T>
) -> Self::FreqResult
where
B: for<'a> Buffer<'a, S, T>; }
Expand description
Defines all operations which are valid on DataVecs
containing time domain data.
Failures
All operations in this trait set self.len()
to 0
if the vector isn’t in time domain.
Required methods
fn plain_fft<B>(self, buffer: &mut B) -> Self::FreqResult where
B: for<'a> Buffer<'a, S, T>,
[src]
fn plain_fft<B>(self, buffer: &mut B) -> Self::FreqResult where
B: for<'a> Buffer<'a, S, T>,
[src]Performs a Fast Fourier Transformation transforming a time domain vector into a frequency domain vector.
This version of the FFT neither applies a window nor does it scale the vector.
Example
use std::f32; use basic_dsp_vector::*; let vector = vec!(Complex::new(1.0, 0.0), Complex::new(-0.5, 0.8660254), Complex::new(-0.5, -0.8660254)).to_complex_time_vec(); let mut buffer = SingleBuffer::new(); let result = vector.plain_fft(&mut buffer); let actual = &result[..]; let expected = &[Complex::new(0.0, 0.0), Complex::new(3.0, 0.0), Complex::new(0.0, 0.0)]; assert_eq!(actual.len(), expected.len()); for i in 0..actual.len() { assert!((actual[i] - expected[i]).norm() < 1e-4); }
fn fft<B>(self, buffer: &mut B) -> Self::FreqResult where
B: for<'a> Buffer<'a, S, T>,
[src]
fn fft<B>(self, buffer: &mut B) -> Self::FreqResult where
B: for<'a> Buffer<'a, S, T>,
[src]Performs a Fast Fourier Transformation transforming a time domain vector into a frequency domain vector.
Example
use std::f32; use basic_dsp_vector::*; let vector = vec!(Complex::new(1.0, 0.0), Complex::new(-0.5, 0.8660254), Complex::new(-0.5, -0.8660254)).to_complex_time_vec(); let mut buffer = SingleBuffer::new(); let result = vector.fft(&mut buffer); let actual = &result[..]; let expected = &[Complex::new(0.0, 0.0), Complex::new(0.0, 0.0), Complex::new(3.0, 0.0)]; assert_eq!(actual.len(), expected.len()); for i in 0..actual.len() { assert!((actual[i] - expected[i]).norm() < 1e-4); }
fn windowed_fft<B>(
self,
buffer: &mut B,
window: &dyn WindowFunction<T>
) -> Self::FreqResult where
B: for<'a> Buffer<'a, S, T>,
[src]
fn windowed_fft<B>(
self,
buffer: &mut B,
window: &dyn WindowFunction<T>
) -> Self::FreqResult where
B: for<'a> Buffer<'a, S, T>,
[src]Applies a FFT window and performs a Fast Fourier Transformation transforming a time domain vector into a frequency domain vector.
Implementors
impl<S, T, N, D> TimeToFrequencyDomainOperations<S, T> for DspVec<S, T, N, D> where
N: NumberSpace,
T: RealNumber,
S: ToSliceMut<T>,
D: TimeDomain,
DspVec<S, T, N, D>: ToFreqResult,
<DspVec<S, T, N, D> as ToFreqResult>::FreqResult: RededicateForceOps<DspVec<S, T, N, D>>,
<DspVec<S, T, N, D> as ToFreqResult>::FreqResult: FrequencyDomainOperations<S, T>,
[src]
impl<S, T, N, D> TimeToFrequencyDomainOperations<S, T> for DspVec<S, T, N, D> where
N: NumberSpace,
T: RealNumber,
S: ToSliceMut<T>,
D: TimeDomain,
DspVec<S, T, N, D>: ToFreqResult,
<DspVec<S, T, N, D> as ToFreqResult>::FreqResult: RededicateForceOps<DspVec<S, T, N, D>>,
<DspVec<S, T, N, D> as ToFreqResult>::FreqResult: FrequencyDomainOperations<S, T>,
[src]pub fn plain_fft<B>(
self,
buffer: &mut B
) -> <DspVec<S, T, N, D> as ToFreqResult>::FreqResult where
B: for<'a> Buffer<'a, S, T>,
[src]pub fn fft<B>(
self,
buffer: &mut B
) -> <DspVec<S, T, N, D> as ToFreqResult>::FreqResult where
B: for<'a> Buffer<'a, S, T>,
[src]pub fn windowed_fft<B>(
self,
buffer: &mut B,
window: &dyn WindowFunction<T>
) -> <DspVec<S, T, N, D> as ToFreqResult>::FreqResult where
B: for<'a> Buffer<'a, S, T>,
[src]impl<V, S, T> TimeToFrequencyDomainOperations<S, T> for Matrix2xN<V, S, T> where
T: RealNumber,
V: Vector<T> + TimeToFrequencyDomainOperations<S, T>,
S: ToSliceMut<T>,
<V as ToFreqResult>::FreqResult: Vector<T>,
[src]
impl<V, S, T> TimeToFrequencyDomainOperations<S, T> for Matrix2xN<V, S, T> where
T: RealNumber,
V: Vector<T> + TimeToFrequencyDomainOperations<S, T>,
S: ToSliceMut<T>,
<V as ToFreqResult>::FreqResult: Vector<T>,
[src]pub fn plain_fft<B>(
self,
buffer: &mut B
) -> <Matrix2xN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]pub fn fft<B>(
self,
buffer: &mut B
) -> <Matrix2xN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]pub fn windowed_fft<B>(
self,
buffer: &mut B,
window: &dyn WindowFunction<T>
) -> <Matrix2xN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]impl<V, S, T> TimeToFrequencyDomainOperations<S, T> for Matrix3xN<V, S, T> where
T: RealNumber,
V: Vector<T> + TimeToFrequencyDomainOperations<S, T>,
S: ToSliceMut<T>,
<V as ToFreqResult>::FreqResult: Vector<T>,
[src]
impl<V, S, T> TimeToFrequencyDomainOperations<S, T> for Matrix3xN<V, S, T> where
T: RealNumber,
V: Vector<T> + TimeToFrequencyDomainOperations<S, T>,
S: ToSliceMut<T>,
<V as ToFreqResult>::FreqResult: Vector<T>,
[src]pub fn plain_fft<B>(
self,
buffer: &mut B
) -> <Matrix3xN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]pub fn fft<B>(
self,
buffer: &mut B
) -> <Matrix3xN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]pub fn windowed_fft<B>(
self,
buffer: &mut B,
window: &dyn WindowFunction<T>
) -> <Matrix3xN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]impl<V, S, T> TimeToFrequencyDomainOperations<S, T> for Matrix4xN<V, S, T> where
T: RealNumber,
V: Vector<T> + TimeToFrequencyDomainOperations<S, T>,
S: ToSliceMut<T>,
<V as ToFreqResult>::FreqResult: Vector<T>,
[src]
impl<V, S, T> TimeToFrequencyDomainOperations<S, T> for Matrix4xN<V, S, T> where
T: RealNumber,
V: Vector<T> + TimeToFrequencyDomainOperations<S, T>,
S: ToSliceMut<T>,
<V as ToFreqResult>::FreqResult: Vector<T>,
[src]pub fn plain_fft<B>(
self,
buffer: &mut B
) -> <Matrix4xN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]pub fn fft<B>(
self,
buffer: &mut B
) -> <Matrix4xN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]pub fn windowed_fft<B>(
self,
buffer: &mut B,
window: &dyn WindowFunction<T>
) -> <Matrix4xN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]impl<V, S, T> TimeToFrequencyDomainOperations<S, T> for MatrixMxN<V, S, T> where
T: RealNumber,
V: Vector<T> + TimeToFrequencyDomainOperations<S, T>,
S: ToSliceMut<T>,
<V as ToFreqResult>::FreqResult: Vector<T>,
[src]
impl<V, S, T> TimeToFrequencyDomainOperations<S, T> for MatrixMxN<V, S, T> where
T: RealNumber,
V: Vector<T> + TimeToFrequencyDomainOperations<S, T>,
S: ToSliceMut<T>,
<V as ToFreqResult>::FreqResult: Vector<T>,
[src]pub fn plain_fft<B>(
self,
buffer: &mut B
) -> <MatrixMxN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]pub fn fft<B>(
self,
buffer: &mut B
) -> <MatrixMxN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]pub fn windowed_fft<B>(
self,
buffer: &mut B,
window: &dyn WindowFunction<T>
) -> <MatrixMxN<V, S, T> as ToFreqResult>::FreqResult where
B: for<'b> Buffer<'b, S, T>,
[src]