ResampleAudio

From Avisynth wiki
(Difference between revisions)
Jump to: navigation, search
m (correction in 4% speed up example)
m (remove unclear section on fractional resampling)
Line 3: Line 3:
 
* Accepts any number of channels.
 
* Accepts any number of channels.
 
* The conversion is skipped if the sample rate is already at the given rate.
 
* The conversion is skipped if the sample rate is already at the given rate.
* Supports ''fractional'' resampling (where {{FuncArg|new_rate_denominator}} != 1).
+
* Supports ''fractional'' resampling (where {{FuncArg|new_rate_denominator}} 1).
 +
* Note, internal rounding may affect [[Clip_properties|AudioDuration]] slighly – see [[#Examples|example]] below.
 
</div>
 
</div>
  
Line 14: Line 15:
  
 
:{{Par2|new_rate_numerator|int|}}
 
:{{Par2|new_rate_numerator|int|}}
::Set new sample rate, or if {{FuncArg|new_rate_denominator}} != 1, set the numerator.
+
::Set the numerator for the new sample rate.
  
 
:{{Par2|new_rate_denominator|int|1}}
 
:{{Par2|new_rate_denominator|int|1}}
 
::Set the denominator for the new sample rate. Default 1.
 
::Set the denominator for the new sample rate. Default 1.
 
 
When using fractional resampling (where {{FuncArg|new_rate_denominator}} != 1) the output audio sample rate is given by :
 
:int({{FuncArg|new_rate_numerator}} / {{FuncArg|new_rate_denominator}} + 0.5)
 
 
However internally the resampling factor used is :
 
:{{FuncArg|new_rate_numerator}} / ({{FuncArg|new_rate_denominator}} * [[Clip_properties|AudioRate]])
 
 
This causes the audio duration to vary slightly (which is generally what is desired).{{Clarify}}
 
 
</div>
 
</div>
  

Revision as of 03:12, 27 February 2016

High-quality change of audio sample rate.

  • Accepts any number of channels.
  • The conversion is skipped if the sample rate is already at the given rate.
  • Supports fractional resampling (where new_rate_denominator ≠ 1).
  • Note, internal rounding may affect AudioDuration slighly – see example below.


Syntax and Parameters

ResampleAudio(clip clip, int new_rate_numerator [, int new_rate_denominator ] )

int  new_rate_numerator =
Set the numerator for the new sample rate.
int  new_rate_denominator = 1
Set the denominator for the new sample rate. Default 1.


Examples

  • Resample audio to 48 kHz:
source = WavSource("c:\audio.wav")
return ResampleAudio(source, 48000)
  • Exact 4% speed up for PAL telecine:
Nfr_num = 25
Nfr_den = 1
AviSource("C:\Film.avi") # 23.976 fps, 44100Hz
Ar = AudioRate
# intermediate sample rate:
ResampleAudio(Ar*FramerateNumerator*Nfr_den, FramerateDenominator*Nfr_num)
# final sample rate:
AssumeSampleRate(Ar)
AssumeFPS(Nfr_num, Nfr_den, false)

In the example above, the intermediate sample rate needs to be

(AudioRate*FramerateNumerator*Nfr_den=1)/(FramerateDenominator*Nfr_num=25)
or (44100 * 24000 * 1) / (1001 * 25) = 42293.706294...

but because audio sample rates are always integers, 42293.706294 must be rounded to 42294,
which results in a time slippage of about 30ms per hour.


Changes

v2.56 Added new_sample_rate=float.
Personal tools