Struct Resampler

Source
pub struct Resampler { /* private fields */ }
Expand description

How the Resampler works For audio stretching:

  1. The input audio remains its original length, and zero-padding is applied at the end to reach the target length.
  2. Perform FFT transformation to obtain the frequency domain.
  3. In the frequency domain, scale down the frequency values proportionally (shift them lower).
  4. Perform inverse FFT to obtain the stretched audio.

For audio compression:

  1. Take the input audio.
  2. Perform FFT transformation.
  3. In the frequency domain, scale up the frequency values proportionally (shift them higher).
  4. Perform inverse FFT to obtain audio with increased pitch but unchanged length.
  5. Truncate the audio to shorten its duration.

This implies: the FFT length must be chosen as the longest possible length involved.

Implementations§

Source§

impl Resampler

Source

pub fn new(fft_size: usize) -> Resampler

Source

pub fn resample_core( &self, samples: &[f32], desired_length: usize, ) -> Result<Vec<f32>, ResamplerError>

desired_length: The target audio length to achieve, which must not exceed the FFT size. When samples.len() < desired_length, it indicates audio stretching to desired_length. When samples.len() > desired_length, it indicates audio compression to desired_length.

Source

pub fn get_process_size( &self, orig_size: usize, src_sample_rate: u32, dst_sample_rate: u32, ) -> usize

The processing unit size should be adjusted to work in “chunks per second”, and artifacts will vanish when the chunk count aligns with the maximum infrasonic frequency. Calling self.get_desired_length() determines the processed chunk size calculated based on the target sample rate.

Source

pub fn get_desired_length( &self, proc_size: usize, src_sample_rate: u32, dst_sample_rate: u32, ) -> usize

Get the processed chunk size calculated based on the target sample rate.

Source

pub fn resample( &self, input: &[f32], src_sample_rate: u32, dst_sample_rate: u32, ) -> Result<Vec<f32>, ResamplerError>

Source

pub fn get_fft_size(&self) -> usize

Trait Implementations§

Source§

impl Clone for Resampler

Source§

fn clone(&self) -> Resampler

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Resampler

Source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more

Auto Trait Implementations§

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

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

Source§

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>,

Source§

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.