Top |
gint | quality | Read / Write / Construct |
guint | sinc-filter-auto-threshold | Read / Write |
GstAudioResamplerFilterMode | sinc-filter-mode | Read / Write |
GstAudioResamplerMethod | resample-method | Read / Write |
GstAudioResamplerFilterInterpolation | sinc-filter-interpolation | Read / Write |
GObject ╰── GInitiallyUnowned ╰── GstObject ╰── GstElement ╰── GstBaseTransform ╰── GstAudioResample
audioresample resamples raw audio buffers to different sample rates using a configurable windowing function to enhance quality.
By default, the resampler uses a reduced sinc table, with cubic interpolation filling in the gaps. This ensures that the table does not become too big. However, the interpolation increases the CPU usage considerably. As an alternative, a full sinc table can be used. Doing so can drastically reduce CPU usage (4x faster with 44.1 -> 48 kHz conversions for example), at the cost of increased memory consumption, plus the sinc table takes longer to initialize when the element is created. A third mode exists, which uses the full table unless said table would become too large, in which case the interpolated one is used instead.
1 |
gst-launch-1.0 -v uridecodebin uri=file:///path/to/audio.ogg ! audioconvert ! audioresample ! audio/x-raw, rate=8000 ! autoaudiosink |
Decode an audio file and downsample it to 8Khz and play sound. To create the Ogg/Vorbis file refer to the documentation of vorbisenc. This assumes there is an audio sink that will accept/handle 8kHz audio.
plugin |
audioresample |
author |
Sebastian Dröge <sebastian.droege@collabora.co.uk> |
class |
Filter/Converter/Audio |
name |
sink |
direction |
sink |
presence |
always |
details |
audio/x-raw, format=(string){ S8, U8, S16LE, S16BE, U16LE, U16BE, S24_32LE, S24_32BE, U24_32LE, U24_32BE, S32LE, S32BE, U32LE, U32BE, S24LE, S24BE, U24LE, U24BE, S20LE, S20BE, U20LE, U20BE, S18LE, S18BE, U18LE, U18BE, F32LE, F32BE, F64LE, F64BE }, rate=(int)[ 1, 2147483647 ], channels=(int)[ 1, 2147483647 ], layout=(string){ interleaved, non-interleaved } |
name |
src |
direction |
source |
presence |
always |
details |
audio/x-raw, format=(string){ S8, U8, S16LE, S16BE, U16LE, U16BE, S24_32LE, S24_32BE, U24_32LE, U24_32BE, S32LE, S32BE, U32LE, U32BE, S24LE, S24BE, U24LE, U24BE, S20LE, S20BE, U20LE, U20BE, S18LE, S18BE, U18LE, U18BE, F32LE, F32BE, F64LE, F64BE }, rate=(int)[ 1, 2147483647 ], channels=(int)[ 1, 2147483647 ], layout=(string){ interleaved, non-interleaved } |
“quality”
property“quality” gint
Resample quality with 0 being the lowest and 10 being the best.
Flags: Read / Write / Construct
Allowed values: [0,10]
Default value: 4
“sinc-filter-auto-threshold”
property“sinc-filter-auto-threshold” guint
Memory usage threshold to use if sinc filter mode is AUTO, given in bytes.
Flags: Read / Write
Default value: 1048576
“sinc-filter-mode”
property“sinc-filter-mode” GstAudioResamplerFilterMode
What sinc filter table mode to use.
Flags: Read / Write
Default value: GST_AUDIO_RESAMPLER_FILTER_MODE_AUTO
“resample-method”
property“resample-method” GstAudioResamplerMethod
What resample method to use.
Flags: Read / Write
Default value: GST_AUDIO_RESAMPLER_METHOD_KAISER
“sinc-filter-interpolation”
property“sinc-filter-interpolation” GstAudioResamplerFilterInterpolation
How to interpolate the sinc filter table.
Flags: Read / Write
Default value: GST_AUDIO_RESAMPLER_FILTER_INTERPOLATION_CUBIC