Le codec audio Opus semble être la meilleure solution pour la compression audio. Il a récemment été pris en charge par les derniers lecteurs ffmpeg et VLC. Cependant, il n'y a pas de documentation que je puisse trouver sur la manière de coder un média avec. Quelqu'un peut-il me diriger vers ces documents, de préférence avec des détails sur les drapeaux ffmpeg et leur utilisation? J'ai beaucoup de livres audio qui prennent beaucoup trop de place et Opus semble être le format idéal pour les conserver.
ffmpeg -i <input> -c:a libopus -b:a bitrate <output>
Le débit peut être donné comme -b:a 96K
pour 96 kBit/s.
La documentation de ffmpeg contient une liste d’options et des descriptions pour libopus. Ici, vous pouvez définir les options -vbr
ou un autre -compression_level
.
Assurez-vous d'avoir compilé ffmpeg avec --enable-libopus
!
Télécharger Opus-tools
Encoder:opusenc --bitrate 64 What_A_Feeling.wav What_A_Feeling_64.opus
Décoder: (à jouer dans n’importe quel lecteur multimédia, utile si votre lecteur multimédia ne supporte pas encore opus):opusdec What_A_Feeling_64.opus What_A_Feeling_opus64.wav
(What_A_Feeling est un nom de chanson)
Options détaillées affichées lors de l'exécution de opusenc
par lui-même:
Usage: opusenc [options] input_file output_file.opus
Encodes input_file using Opus.
It can read the WAV, AIFF, FLAC, Ogg/FLAC, or raw files.
General options:
-h, --help This help
-V, --version Version information
--quiet Quiet mode
input_file can be:
filename.wav file
- stdin
output_file can be:
filename.opus compressed file
- stdout
Encoding options:
--bitrate n.nnn Target bitrate in kbit/sec (6-256/channel)
--vbr Use variable bitrate encoding (default)
--cvbr Use constrained variable bitrate encoding
--hard-cbr Use hard constant bitrate encoding
--comp n Encoding complexity (0-10, default: 10 (slowest))
--framesize n Maximum frame size in milliseconds
(2.5, 5, 10, 20, 40, 60, default: 20)
--expect-loss Percentage packet loss to expect (default: 0)
--downmix-mono Downmix to mono
--downmix-stereo Downmix to stereo (if >2 channels)
--max-delay n Maximum container delay in milliseconds
(0-1000, default: 1000)
Diagnostic options:
--serial n Forces a specific stream serial number
--save-range file Saves check values for every frame to a file
--set-ctl-int x=y Pass the encoder control x with value y (advanced)
Preface with s: to direct the ctl to multistream s
This may be used multiple times
Metadata options:
--comment Add the given string as an extra comment
This may be used multiple times
--artist Author of this track
--title Title for this track
--album Album or collection this track belongs to
--date Date for this track
--genre Genre for this track
--picture Album art for this track
More than one --picture option can be specified.
Either a FILENAME for the picture file or a more
complete SPECIFICATION form can be used. The
SPECIFICATION is a string whose parts are
separated by | (pipe) characters. Some parts may
be left empty to invoke default values. A
FILENAME is just shorthand for "||||FILENAME".
The format of SPECIFICATION is
[TYPE]|[MIME-TYPE]|[DESCRIPTION]|[WIDTHxHEIGHT
xDEPTH[/COLORS]]|FILENAME
TYPE is an optional number from one of:
0: Other
1: 32x32 pixel 'file icon' (PNG only)
2: Other file icon
3: Cover (front)
4: Cover (back)
5: Leaflet page
6: Media (e.g., label side of a CD)
7: Lead artist/lead performer/soloist
8: Artist/performer
9: Conductor
10: Band/Orchestra
11: Composer
12: Lyricist/text writer
13: Recording location
14: During recording
15: During performance
16: Movie/video screen capture
17: A bright colored fish
18: Illustration
19: Band/artist logotype
20: Publisher/studio logotype
The default is 3 (front cover). There may only be
one picture each of type 1 and 2 in a file.
MIME-TYPE is optional. If left blank, it will be
detected from the file. For best compatibility
with players, use pictures with a MIME-TYPE of
image/jpeg or image/png. The MIME-TYPE can also
be --> to mean that FILENAME is actually a URL to
an image, though this use is discouraged. The
file at the URL will not be fetched. The URL
itself is stored in the metadata.
DESCRIPTION is optional. The default is an empty
string.
The next part specifies the resolution and color
information. If the MIME-TYPE is image/jpeg,
image/png, or image/gif, you can usually leave
this empty and they can be detected from the
file. Otherwise, you must specify the width in
pixels, height in pixels, and color depth in
bits-per-pixel. If the image has indexed colors
you should also specify the number of colors
used. If possible, these are checked against the
file for accuracy.
FILENAME is the path to the picture file to be
imported, or the URL if the MIME-TYPE is -->.
--padding n Extra bytes to reserve for metadata (default: 512)
--discard-comments Don't keep metadata when transcoding
--discard-pictures Don't keep pictures when transcoding
Input options:
--raw Raw input
--raw-bits n Set bits/sample for raw input (default: 16)
--raw-rate n Set sampling rate for raw input (default: 48000)
--raw-chan n Set number of channels for raw input (default: 2)
--raw-endianness n 1 for bigendian, 0 for little (defaults to 0)
--ignorelength Always ignore the datalength in Wave headers
Les meilleures commandes Opus Codec sous DOS/Windows Command seraient:
Pour la lib 1.3, la plus petite taille de fichier (qualité de la bande):
Opusenc a.wav a.opus --bitrate 24 --framesize 40 --discard-comments --discard-pictures
Vous serez:
a- à 24 kbits ont toujours une sortie sonique de 16 kHz (stéréo de 32 kHz), sur une très petite taille. Toute sortie plus petite et Sonic tombera à 11 kHz
b- Augmenter la taille de la trame (économiser quelques bits de données (environ 6%), sans perte de qualité perceptible)
c- Supprimez les informations inutiles sur les balises et couvrez les images qui agrandissent uniquement la taille du fichier.
Pour la lib 1.3, la transmission en continu (qualité proche du CD) utilise '--bitrate 52' au lieu de '24'.
La valeur par défaut dans 1.2 est 48 kbits, mais si vous utilisez 52 dans 1.3, avec 'framesize' défini sur 40, la taille de votre fichier est égale, mais le nombre d'artefacts audibles est bien moindre.
52 kbits avec une taille de trame de 40, on peut dire que sa qualité est égale à 160 kbits MP3, à moins de 1/3 de la taille; tandis que 48 kbits sur 1,2 équivaut à 128 kbits MP3, ou seulement 2,5 fois plus petit.
Pour une qualité presque identique, vous aurez besoin de 80 à 96 kbits/s. Je l’utilise rarement, car je veux que mon audio soit aussi petit que possible.
Plus de 96kbits, ce n’est bon que pour l’édition, et on ne peut pas entendre de façon audible la différence entre le fichier original et le fichier encodé Opus.
Cela étant dit, je ne sais pas encore comment tout cela fonctionne sous Linux.