Using qaac under Linux... (2024)

This is a page that aims to promote and facilitate the use of the great AAC/ALAC commandline encoder qaac under a Linux environment. qaacis a Windows application: a 'CLI QuickTime AAC/ALAC encoder' that usesCoreAudioToolbox and Apple AAC to produce the best AAC quality availabletoday, a quality which is otherwise not normally available in a Linux environment.This page provides a simple copy and paste approach to an installationthat can otherwise be somewhat complex. As well I have included instructionson basic command line usage so that once the installation is complete, GentleReader, you can launch straight into encoding...

Installation...

One fundamental fact of qaac is that it is a native Windows application so under Linux you will need to install the Wine package appropriate for your distro. You will also need both the 7z file archiver and the unzip utility. Once these are all installed you would be best to spend a littlequality time with the application winecfg to get your Wineinstallation running exactly as you would like.

From here you will need both the qaac application zip file as well asa modern copy of iTunes from which we will extract the appropriate dll filesthat qaac needs. The following single command makes a build directory,downloads and then unzips qaac to the appropriate location. The syntaxpresupposes that your wine prefix is the default ~/.wine, if it is not you will need to adjust the output path:

mkdir $HOME/qaac_build && cd $HOME/qaac_build && \wget https://github.com/nu774/qaac/releases/download/v2.77/qaac_2.77.zip && \unzip -j qaac_2.77.zip 'qaac_2.77/x86/*' -d ~/.wine/drive_c/qaac/

The next single command downloads the 195MiB 32bit iTunesinstallation file and extracts the Apple Application Support msi fileneeded by qaac. Note that I have placed a gzipped copy of the 32bit iTunessetup archive on my own web site, and given the syntax to download thisbelow. The file can alternatively be sourced directly from the Apple sitehere... if this makes you, Gentle Reader, feel a little safer!

cd $HOME/qaac_build && \wget https://andrews-corner.org/downloads/iTunesSetup.exe.gz && \gunzip iTunesSetup.exe.gz && \7z e -y iTunesSetup.exe AppleApplicationSupport.msi

Rather than fully install the Apple Installation Support msi file we are going to extract what we need from it. The author of qaac at one stagehad a very nice Windows batch file called makeportable.bat which extracted all the relevant dlls and packaged them nicely (under Windows). Ihave shamelessly copied his syntax to the following native Linux syntax which extracts the required dll files, renames them appropriatelyand then moves them to the qaac directory. Again this is a single command that can be copied and pasted into your Terminal window:

cd $HOME/qaac_build && \7z e -y AppleApplicationSupport.msi \ -i'!*AppleApplicationSupport_ASL.dll' \ -i'!*AppleApplicationSupport_CoreAudioToolbox.dll' \ -i'!*AppleApplicationSupport_CoreFoundation.dll' \ -i'!*AppleApplicationSupport_icudt*.dll' \ -i'!*AppleApplicationSupport_libdispatch.dll' \ -i'!*AppleApplicationSupport_libicu*.dll' \ -i'!*AppleApplicationSupport_objc.dll' \ -i'!F_CENTRAL_msvc?100*' && \for j in *.dll; do mv -v $j $(echo $j | sed 's/AppleApplicationSupport_//g'); done && \for j in F_CENTRAL_msvcr100*; do mv -v "$j" msvcr100.dll; done && \for j in F_CENTRAL_msvcp100*; do mv -v "$j" msvcp100.dll; done && \mv -v *.dll ~/.wine/drive_c/qaac/ && \rm -v AppleApplicationSupport.msi

Now that is pretty cool I think and I thank the qaac developer for showing the way here! Now to extend qaac a little in terms of media file types it can read directly. The developer has carefully detailed the individual steps required on the qaac installation page but for you, Gentle Reader, I have already assembled the required dlls and placed them in a download section of this website. (Note that my offerings,updated to the newest versions at the end of 2022, are for the 32bitqaac.) The following is a single command:

cd $HOME/qaac_build && \wget http://www.andrews-corner.org/downloads/x32DLLs_20221229.zip && \unzip -j x32DLLs_20221229.zip 'x32DLLs_20221229/*' -d ~/.wine/drive_c/qaac/

And now your copy of qaac can take take several new import formats on top of those supported by the Apple's CoreAudioToolbox 7.10.9.0! All thatremains now is to make an alias in either your ~/.bashrcfile or in the usual file that you use for such aliases, so that you canrun qaac (and the Open Source refalac) more easily. I include here as wella line to turn off some painful Wine debugging messages:

# So I can launch qaac or refalac with a single command:alias qaac='wine ~/.wine/drive_c/qaac/qaac.exe'alias refalac='wine ~/.wine/drive_c/qaac/refalac.exe'# Turn off a few pesky warnings (well, actually all of them!):export WINEDEBUG=-all

And now you should be able to run qaac directly from the commandline (once you have sourced your ~/.bashrc file appropriately of course) and a good test is to run the following:

andrew@ilium~$ qaac --checkqaac 2.77, CoreAudioToolbox 7.10.9.0libsoxconvolver 0.1.0libsoxr-0.1.3libsndfile-1.0.25libFLAC 1.4.2wavpackdll 5.6.0tak_deco_lib 2.3.3 compatibleandrew@ilium~$ 

All done and when I repeated these steps in December 2022 with a fastcomputer and a good broadband speed the whole installation took only5 minutes! Next I will describe the command line usage of qaac and showhow to import multiple flac files with a bash 'for' loop:

Commandline usage...

Before launching straight into the command line usage of qaac let usclear up some confusion about AAC encoding in general. Currently (August2019) for our purposes there are 4 recognised forms of AAC encodingavailable for Linux. Note that not all options are available toqaac, options such as sample rate and bitrate for example. Run the commandqaac --formats to see which specific options areallowed.

  1. AAC-LC: Otherwise known as "MPEG AAC Low Complexity", this is AAC encoding which produces excellent sound at bitrates up to 256 kbit/s per channel and sampling rates from 8 to 96 kHz. This is the form of AAC that most will use for computer playback, use in iTunes, mobile phones etc. qaac produces AAC-LC files.
  2. HE-AAC: Otherwise known as "High Efficiency AAC". This is AAC encoding which produces excellent encoding at lower bitrates: 48 to 64 kbit/s Stereo and sampling rate 24 to 96 kHz. This is specifically designed for low bitrate streaming from TV or radio and can be used by those keen to have quality files at low bitrates. It uses AAC-LC and adds in a technique called Spectral band replication (SBR). Also known as HE-AAC v1. qaac produces HE-AAC files.
  3. HE-AAC v2: Otherwise known as "High Efficiency AAC version 2". This is the successor to the original HE-AAC and aims to produce quality AAC at 24 to 32 kbit/s Stereo and sampling rate 24 to 96 kHz. It adds in a technique called Parametric Stereo (PS). qaac does not produce HE-AAC v2 files.
  4. xHE-AAC: Otherwise known as "Extended High Efficiency AAC", or some may even use the more umbrellaterm Unified Speech and Audio Coding (USAC). This is the most recentaddition to the AAC family and it aims to unify speech and musicencoding primarily for broadcast with high quality encoding at lowbitrates. There is now an encoder:exhale which producesplayable xHE-AAC files under Linux. Exciting times!

qaac also has the added bonus of producing Apple Lossless Audio Codec (alac) files by either using qaac itself or by using "refalac", an encoder based on the Open Source reference implementation of alac released by Apple. The biggest advantage of refalac is that it does not require any extra Apple libraries to function. Now to demonstrate some of the commandline requirements for each output of qaac, I use my favourite wav file to demonstrate and you are welcome to download and use it as well for testing:

wget samples.mplayerhq.hu/A-codecs/lossless/luckynight.wav.bz2 && \bzip2 -dkv luckynight.wav.bz2

Consider as well looking at the words of the qaac developer on the subject of encoding with qaac.

AAC-LC...

If you are not completely sure where you AAC files will end up being used then AAC Low Complexity (AAC-LC) is what you probably should be using. My own practice is to use qaac's True Variable Bitrate (tvbr) option and at the very least this will make a good start in your own exploration of qaac. The tvbr settings take an integer betwen 0-127 which map to the following settings. I have constructed a fairly crude test with a sample wav file to show what the average bitrate will be:

AAC True VBR mode
tvbr setting09182736455463738291100109118127
Overall Bitrate in kbps44.451.258.065.771.587.6102114131150190232269305346
Testing with this file: qaac --tvbr <n> luckynight.wav

But experiment a little and see what sounds better on your system and go with that rather than simply following the bitrate numbers alone. Toconvert our input file to AAC-LC and also add in some meta data you shouldtry something like the following:

qaac --tvbr 100 --quality 2 --verbose \ --band "Treasure Quest Soundtrack" \ --artist "Jody Marie Gnant" \ --track "9" \ --title "Lucky Night" \ --genre "Soundtrack" \ --date "1995" \ --comment "Testing qaac encoding..." \ -o luckynight.m4a \ luckynight.wav

That is usually enough for me but there are many more options that I will leave for you, Gentle Reader, to explore. Have a look at qaac --help to then explore the options for Constrained Variable Bitrate mode (CVBR), Average Bitrate mode (ABR) and Constant Bitrate Mode (CBR) encoding. But now to the exciting world of High Efficiency AAC encoding with qaac!

HE-AAC...

For the most part you will not need High-Efficiency AAC (HE-AAC) encoding as AAC-LC would normally be adequate for most playbackneeds. However if you would like to produce high quality, low bitrateAAC files this is the mode you are after. To produce a decentquality HE-AAC file with qaac, as well as adding in some meta data,something like the following should suffice:

qaac --cvbr 48k --he --quality 2 --ignorelength --verbose \ --band "Treasure Quest Soundtrack" \ --artist "Jody Marie Gnant" \ --track "9" \ --title "Lucky Night" \ --genre "Soundtrack" \ --date "1995" \ --comment "Testing qaac encoding..." \ -o luckynight.m4a \ luckynight.wav

There are many more options to explore with HE-AAC and I encourage you again to look at qaac --help and both read and experiment!Now to have a look at qaac and ALAC encoding.

Apple Lossless Audio Codec (ALAC)...

Encoding with alac under qaac is easy, in part because there are not that many commandline options to worry about! Perhaps the biggest choice is whether to use the closed source CoreAudio or the Open Source refalac.To use the CoreAudio version simply run the following to encode to alacas well as adding in some meta tags:

qaac --alac --verbose \ --band "Treasure Quest Soundtrack" \ --artist "Jody Marie Gnant" \ --track "9" \ --title "Lucky Night" \ --genre "Soundtrack" \ --date "1995" \ --comment "Testing qaac encoding..." \ -o luckynight.m4a \ luckynight.wav

It really could not be much easier could it? If you would like to go full Open Source simply substitute refalac for qaac in the above commandline and you will not only still have a great encodebut you will have a slight self-righteous glow as well!

Importing from other formats..

If you have loaded the extra 32bit dlls you will now have the abilityto import from multiple other audio formats as well as wav. On my own systemI have used this import facility with several very large collections of flacaudio files which I have converted to alac and suitably tagged using thefollowing code snippet:

mkdir converted && \for f in *.flac; do title=$(metaflac --show-tag=title "$f" | cut -d '=' -f 2) artist=$(metaflac --show-tag=artist "$f" | cut -d '=' -f 2) album=$(metaflac --show-tag=album "$f" | cut -d '=' -f 2) date=$(metaflac --show-tag=date "$f" | cut -d '=' -f 2) track=$(metaflac --show-tag=tracknumber "$f" | cut -d '=' -f 2) genre=$(metaflac --show-tag=genre "$f" | cut -d '=' -f 2) wine ~/.wine/drive_c/qaac/qaac.exe --alac --verbose \ --title "$title" --artist "$artist" --album "$album" \ --date "$date" --track "$track" --genre "$genre" --comment "" \ --artwork cover.jpg \ "$f" -o converted/"${f%.flac}.m4a"done

Note the embedding here for a suitable cover art image. Works very nicely on my system and then the resulting files are then ready for playbackwith a nice piece of album art showing! I have just now tested this syntaxand this conversion and I can tell you Gentle Reader that I loveseeing a nice command line running so beautifully!

Importing unusual formats...

Courtesy of the CoreAudio AudioFile interface as well as courtesy ofthe extra 32bit dlls there are not that many files that qaac cannotimport and convert. However these files do exist and fortunatelythere is a nice 'work around' for these files using FFmpeg. I give anexample here with one of those pesky Windows Audio Lossless file which can be so difficult to work with:

ffmpeg -i luckynight.wma -f wav - | \qaac --cvbr 48k --he --quality 2 --ignorelength --verbose \ --band "Treasure Quest Soundtrack" \ --artist "Jody Marie Gnant" \ --track "9" \ --title "Lucky Night" \ --genre "Soundtrack" \ --date "1995" \ --comment "Testing qaac encoding..." \ -o luckynight.m4a \ -

And there, we have tamed a Windows Lossless Audio file and safelyrendered it to a more conventional HE-AAC file! If you use this commandline don't forget to keep the trailing '-' in place otherwise it willnot work at all. My suspicion is that if the power of FFmpeg is harnessedin this way there will be no audio file that cannot be convertedusing qaac.

And in conclusion...

This page represents my own exploration of the great commandline encoderqaac and my efforts to make it both easy to install and use under Linux.I hope that your own exploration of this great encoder will take you evenfurther and that you thoroughly enjoy the quality audio that you willundoubtedly produce!! Please feel free to contact mewith any errors of fact that you have found on this page, any errorsof opinion will probably remain uncorrected. In the meantime I amhaving a great time exploring Linux and the amazing command line, what aboutyou?

Using qaac under Linux... (2024)

References

Top Articles
Latest Posts
Article information

Author: Stevie Stamm

Last Updated:

Views: 5559

Rating: 5 / 5 (80 voted)

Reviews: 87% of readers found this page helpful

Author information

Name: Stevie Stamm

Birthday: 1996-06-22

Address: Apt. 419 4200 Sipes Estate, East Delmerview, WY 05617

Phone: +342332224300

Job: Future Advertising Analyst

Hobby: Leather crafting, Puzzles, Leather crafting, scrapbook, Urban exploration, Cabaret, Skateboarding

Introduction: My name is Stevie Stamm, I am a colorful, sparkling, splendid, vast, open, hilarious, tender person who loves writing and wants to share my knowledge and understanding with you.