From 21191f9a280df9435e7f298e2ad12be6aaccee23 Mon Sep 17 00:00:00 2001 From: diego Date: Sat, 11 Jan 2003 14:09:19 +0000 Subject: [PATCH] Further libaf documentation by Anders with some more updates by me. git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@8892 b3059339-0415-0410-9bf9-f77b7e298cf2 --- DOCS/documentation.html | 2 + DOCS/mplayer.1 | 28 ++++-- DOCS/sound.html | 205 +++++++++++++++++++++++++++++----------- 3 files changed, 173 insertions(+), 62 deletions(-) diff --git a/DOCS/documentation.html b/DOCS/documentation.html index 5e57f2fee8..fec4f63a75 100644 --- a/DOCS/documentation.html +++ b/DOCS/documentation.html @@ -197,6 +197,8 @@
  • 2.3.2.3.5 Software volume control
  • 2.3.2.3.6 Equalizer
  • 2.3.2.3.7 Panning filter
  • +
  • 2.3.2.3.8 Sub-woofer
  • +
  • 2.3.2.3.9 Surround-sound decoder
  • 2.3.2.4 Audio plugins (deprecated) diff --git a/DOCS/mplayer.1 b/DOCS/mplayer.1 index 1ebcbe5318..ee1769db84 100644 --- a/DOCS/mplayer.1 +++ b/DOCS/mplayer.1 @@ -1010,7 +1010,7 @@ Activate a comma separated list of audio filters and their options. Available filters are: . .RSs -.IPs resample[=srate[:sloppy][:fast]] +.IPs resample[=srate[:sloppy][:type]] Changes the sample rate of the audio stream to an integer srate (Hz). It only supports the 16 bit little endian format. .IPs channels[=nch] @@ -1034,7 +1034,7 @@ unsigned or signed .br le or be (little or big endian) .br -.IPs "volume[=v:sc:pr:en]" +.IPs "volume[=v:sc]" Select the output volume level. This filter is not reentrant and can therefore only be enabled once for every audio stream. @@ -1045,15 +1045,25 @@ completely and +40dB equals a gain of 1000). The default gain is -20dB. .br sc: enable soft clipping. +.REss +.IPs "pan[=n:l01:l02:..l10:l11:l12:...ln0:ln1:ln2:...]" +Mixes channels arbitrarily, see DOCS/sound.html for details. +.RSss +n: number of output channels (1 - 6). .br -pr: enable probing of the volume level for each audio stream. -Both the maximum and instantaneous volume is probed. -The instantaneous volume can only be accessed through the runtime interface, -but the maximum volume is printed at the end of the movie. -This value can be used when transcoding movies to maximize the utilization -of the dynamic range. +lij: how much of input channel j is mixed into output channel i. +.REss +.IPs "sub[=fc:ch]" +Add sub-woofer channel. +.RSss +fc: Cutoff frequency for low-pass filter (20Hz to 300Hz) default is 60Hz. .br -en: enable and disable the volume control. +ch: channel number for the sub-channel. +.REss +.IPs "surround[=d]" +Decoder for matrix encoded surround sound, works on many 2 channel files. +.RSss +d: delay time in ms for the rear speakers (0ms to 1000ms) default is 15ms. .REss .IPs delay[=ch1:ch2:...] Delays the sound output. diff --git a/DOCS/sound.html b/DOCS/sound.html index 20b6cf41f1..b2d02fee78 100644 --- a/DOCS/sound.html +++ b/DOCS/sound.html @@ -189,40 +189,71 @@

    would set the output frequency of the resample filter to 11025Hz and downmix the audio to 1 channel using the pan filter.

    -

    Most filters respond to the -v switch, which makes the filters - print out status messages.

    -

    The overall execution of the filter layer is controlled using the -af-adv switch. This switch has two suboptions:

    force
    -
    is an integer between 0 and 3 that controls how the filters are inserted - and what speed/accuracy optimizations they use: +
    is a Bit field that controls how the filters are inserted and what + speed/accuracy optimizations they use:
    -
    0
    +
    0
    Use automatic insertion of filters and optimize according to CPU speed.
    -
    1
    -
    Use automatic insertion of filters and optimize for the highest speed. - If this option is set the processing of the audio data will be done - using fix point arithmetics. Warning: Some features in the audio filters - will silently fail, and the sound quality may drop.
    -
    2
    -
    Use automatic insertion of filters and optimize for quality. If this - option is set the processing of the audio data will be done using - floating point instructions and is therefore quite CPU intensive, but - gives a lot higher sound quality than fix point processing.
    -
    3
    -
    Use no automatic insertion of filters and no optimization. Warning: It - may be possible to crash MPlayer using this setting.
    +
    1
    +
    Use automatic insertion of filters and optimize for the highest + speed.
    + Warning: Some features in the audio filters may silently fail, + and the sound quality may drop.
    +
    2
    +
    Use automatic insertion of filters and optimize for quality.
    +
    3
    +
    Use no automatic insertion of filters and no optimization.
    + Warning: It may be possible to crash MPlayer using this + setting.
    +
    4
    +
    Use automatic insertion of filters according to 0 above, but use + floating point processing when possible.
    +
    5
    +
    Use automatic insertion of filters according to 1 above, but use + floating point processing when possible.
    +
    6
    +
    Use automatic insertion of filters according to 2 above, but use + floating point processing when possible.
    +
    7
    +
    Use no automatic insertion of filters according to 3 above, and use + floating point processing when possible.
    - +
    list
    is an alias for the -af switch.
    +

    The filter layer is also affected by the following generic switches: + +

    +
    -v
    +
    Increases the verbosity level and makes most filters print out extra + status messages.
    +
    -channels
    +
    This option sets the number of output channels your sound card is using. + It also affects the number of channels that are being decoded from the + media. If the media contains less channels than requested the channels + filter (see below) will automatically be inserted. The routing will be the + default routing for the channels filter.
    +
    -srate
    +
    This option selects the sample rate of your sound card. If the sample + frequency of your sound card is different from that of the current media, + the resample filter (see below) will be inserted into the audio filter layer + to compensate for the difference.
    +
    -format
    +
    This option sets the sample format of the audio filter layer and the sound + card. If the requested sample format of your sound card is different from + that of the current media, a format filter (see below) will be inserted to + rectify the difference.
    +
    +
    2.3.2.3.1 Up/Down-sampling
    @@ -233,7 +264,7 @@ has three switches:

    -
    srate
    +
    srate <8-192>
    is an integer used for setting the output sample frequency in Hz. The valid range for this parameter is 8kHz to 192kHz. If the input and output sample frequency are the same or if this parameter is @@ -244,12 +275,19 @@
    sloppy
    is an optional binary parameter that allows the output frequency to differ slightly from the frequency given by srate. This switch can be - used if the startup of the playback is extremely slow.
    + used if the startup of the playback is extremely slow. It is enabled by + default. -
    fast
    -
    is an optional binary parameter that enables linear interpolation as - resampling method. Linear interpolation is extremely fast, but suffers from - poor sound quality especially when used for up-sampling.
    +
    type <0-2>
    +
    is an optional integer between 0 and 2 that + selects which resampling method to use. Here 0 represents + linear interpolation as resampling method, 1 represents + resampling using a poly-phase filter-bank and integer processing and + 2 represents resampling using a poly-phase filter-bank and + floating point processing. Linear interpolation is extremely fast, but + suffers from poor sound quality especially when used for up-sampling. The + best quality is given by 2 but this method also suffers from + the highest CPU load.

    Example:
    @@ -268,19 +306,19 @@ itself if not needed. The number of switches is dynamic:

    -
    nch
    -
    is an integer between 1 and 6 that is used for setting the number of - output channels. This switch is required, leaving it empty results in a - runtime error.
    +
    nch <1-6>
    +
    is an integer between 1 and 6 that is used for + setting the number of output channels. This switch is required, leaving it + empty results in a runtime error.
    -
    nr
    -
    is an integer between 1 and 6 that is used for specifying the number of - routes. This parameter is optional. If it is omitted the default routing is - used.
    +
    nr <1-6>
    +
    is an integer between 1 and 6 that is used for + specifying the number of routes. This parameter is optional. If it is + omitted the default routing is used.
    from1:to1:from2:to2:from3:to3...
    -
    are pairs of numbers between 0 and 5 that define where each channel should - be routed.
    +
    are pairs of numbers between 0 and 5 that define + where each channel should be routed.

    If only nch is given the default routing is used, it works as @@ -311,11 +349,12 @@ needed by the sound card or another filter.

    -
    bps
    -
    can be 1, 2 or 4 and denotes the number of bytes per sample. This switch - is required, leaving it empty results in a runtime error.
    +
    bps <number>
    +
    can be 1, 2 or 4 and denotes the + number of bytes per sample. This switch is required, leaving it empty + results in a runtime error.
    -
    f
    +
    f <format>
    is a text string describing the sample format. The string is a concatenated mix of: alaw, mulaw or imaadpcm, float or int, @@ -377,9 +416,9 @@ background is gone. This filter has two switches:

    -
    v
    -
    is a floating point number between -200 and +60 which represents the - volume level in dB. The default level is -10dB.
    +
    v <-200 - +60>
    +
    is a floating point number between -200 and +60 + which represents the volume level in dB. The default level is -10dB.
    c
    is a binary control that turns soft clipping on and off. Soft-clipping can @@ -402,7 +441,7 @@
    2.3.2.3.6 Equalizer
    -

    This filter is a 10 octave band graphic equalizer, implemented using 10 IIR +

    This filter is a 10 octave band graphic equalizer, implemented using 10 IIR band pass filters. This means that it works regardless of what type of audio is being played back. The center frequencies for the 10 bands are:

    @@ -427,12 +466,12 @@ that band. This problem can be worked around by up-sampling the sound using the resample filter before it reaches this filter.

    -

    This filter has 10 parameters:

    +

    This filter has 10 parameters:

    g1:g2:g3...g10
    -
    are floating point numbers between -12 to +12dB representing the gain in - dB for each frequency band.
    +
    are floating point numbers between -12 and +12 + representing the gain in dB for each frequency band.

    Example:
    @@ -457,14 +496,15 @@ the number of output channels:

    -
    nch
    -
    is an integer between 1 and 6 and is used for setting the number of output - channels. This switch is required, leaving it empty results in a runtime - error.
    +
    nch <1-6>
    +
    is an integer between 1 and 6 and is used for + setting the number of output channels. This switch is required, leaving it + empty results in a runtime error.
    l00:l01:l02:..l10:l11:l12:...ln0:ln1:ln2:...
    -
    are floating point values between 0 and 1. l[i][j] determines - how much of input channel j is mixed into output channel i.
    +
    are floating point values between 0 and 1. + l[i][j] determines how much of input channel j is mixed into + output channel i.

    Example 1:
    @@ -480,6 +520,65 @@ example).

    +
    2.3.2.3.8 Sub-woofer
    + +

    This filter adds a sub woofer channel to the audio stream. The audio data + used for creating the sub-woofer channel is an average of the sound in channel + 0 and channel 1. The resulting sound is then low-pass filtered by a a 4th + order Butterworth filter with a default cutoff frequency of 60Hz and added to + a separate channel in the audio stream. Warning: Disable this filter when you + are playing DVDs with Dolby Digital 5.1 sound, otherwise this filter will + disrupt the sound to the sub-woofer. This filter has two parameters:

    + +
    +
    fc <20-300>
    +
    is an optional floating point number used for setting the cutoff frequency + for the filter in Hz. The valid range is 20Hz to 300Hz. For the best result + try setting the cutoff frequency as low as possible. This will improve the + stereo or surround sound experience. The default cutoff frequency is + 60Hz.
    + +
    ch <0-5>
    +
    is an optional integer between 0 and 5 which + determines the channel number in which to insert the sub-channel audio. + The default is channel number 5. Observe that the number of + channels will automatically be increased to ch if + necessary.
    +
    + +

    Example:
    +   mplayer -af sub=100:4 -channels 5 media.avi

    + +

    would add a sub-woofer channel with a cutoff frequency of 100Hz to output + channel 4.

    + +
    2.3.2.3.9 Surround-sound decoder
    + +

    This filter is a decoder for matrix encoded surround sound. Dolby Surround is + an example of a matrix encoded format. Many files with 2 channel audio + actually contain matrixed surround sound. To use this feature you need a sound + card supporting at least 4 channels. This filter has one parameter:

    + +
    +
    d <0-1000>
    +
    is an optional floating point number between 0 and + 1000 used for setting the delay time in ms for the rear + speakers. This delay should be set as follows: if d1 is the distance from + the listening position to the front speakers and d2 is the distance from + the listening position to the rear speakers, then the delay d + should be set to 15ms if d1 <= d2 and to 15 + 5*(d1-d2) if d1 > d2. + The default value for d is 20ms.
    +
    + +

    Example:
    +   mplayer -af surround=15 -channels 4 media.avi

    + +

    would add a surround sound decoding with 15ms delay for the sound to the rear + speakers.

    + + + +

    Note: Audio plugins have been deprecated by audio filters and will be removed soon.