Archive for the ‘audio’ Category

MPD Stream lossless flac or wav

April 1, 2014

Modern networks are so fast and disk space so abundant and cheap that compressing a music collection to mp3, vorbis or similar now seems mostly pointless even for streaming, especially at home. Even away from home and streaming via ssh tunnels there is often no need for compression. I spent ages looking for a way to stream lossless audio and finally realised it was right under my nose and already running in the form of my mpd server. Lesson learned: Read The Fine Manual but don’t believe everything it says or assume it complete!

The mpd man page and typical example mpd.conf are out of date. For example mpd.conf states that streamed output must be vorbis or mp3. This is no longer the case. Run mpd –version to see a list of supported encoders. My mpd server (Debian Wheezy) shows:

Encoder plugins:
null vorbis lame wave flac

(If you compile mpd yourself you can include extra lossy encoders such as twolame, opus and shine).

so I set up my mpd server to stream lossless audio. If your audio collection is flac derived from CD (44100Hz 16-bit PCM with 2 channels) then you can use an output like this one:

audio_output {
type "httpd"
name "FLAC Stream"
encoder "flac"
port "8000"
format "44100:16:2"

(format must be defined for flac streams)

If you have a variety of formats and don’t want changes in bit depth or sample rate then you can choose to output to raw pcm wav like this:

audio_output {
type "httpd"
name "pcm wav Stream"
encoder "wave"
port "8000"

As this is raw (headerless) pcm some players won’t play it, or will require a format to be defined (sox’s play command is like this). Fortunately mplayer or mplayer2 will play back a raw pcm stream without issue. This means it integrates easily into your local alsa/pulse/jack setup, so you can direct the audio to any predefined software devices such as equalisers, crossfeeds, mixers, or direct to hardware devices such as USB DAC or onboard spdif and so on. Of course you can also use mplayer’s built in audio filters and/or numerous applications which have mplayer as a backend.

To play without stuttering or dropping out on track changes you can use something like:

mplayer -idle -cache 2048 your-mpd-host:8000

VLC will also play back these kinds of headerless streams.

On Android devices MPDroid supports streaming, and if you have an Android device with good multimedia support it might support both flac and raw pcm. My old (2010 vintage) Archos 43 and 28 Internet Tablets handle this really well and MPDroid passes the audio off to the devices’ DSP so it is relatively undemanding on the battery.

Automatically convert tracks or entire directories to Ogg, MP3, Flac, M4A (Nero or FAAC), with tags.

May 26, 2012

Edit: New version uses multiple parallel processes for huge performance gain on dual/multicore processor systems, and on single core systems it’s recommended to run the new version with “PROCESSES=2” (see below) for proportionately similar benefit.

foma:  [f]lac [o]gg [m]p3 [a]ac

foma will convert any audio track (or the audio track from a video file) to any of Ogg Vorbis, MP3, Flac, or M4A.  It writes the tags to the new files.  You can choose to convert the files in situ, or to output them to a different directory.  It never overwrites any audio file.  If you input files it will convert the files ; if you input a directory it will create a new identically named directory (either as a nested subdirectory, or to your specified output destination) and then find and convert all the contained audio files to the new directory, writing the metadata and also an extended .m3u playlist, and copy over any images.  Optionally it will then run replaygain on the new directory.  foma can handle multiple files or directories, or a mix of files and directories, as input.  It’s very easy to use as a simple command,  or as an -exec or -execdir find command, or as  file manager context menu item/custom action.

Original foma:

Updated for multicore:

This is also usable for single core machines: change “PROCESSES=5” to “PROCESSES=2”.  If you do only want one process running then use the original script.

foma decodes with ffmpeg,  so you can convert audio from any file that ffmpeg understands.

It encodes using flac, oggenc,  lame,  faac or neroaacenc.

It tags using metaflac, vorbiscomment,  (m)id3v2, neroaactag/mp4tags.

It runs replaygain using metaflac, vorbisgain, mp3gain or aacgain.

It writes an extended m3u playlist using just ffmpeg’s metadata output and some shell commands.

After completing a directory conversion foma can automatically update your mpd library.

foma never overwrites your existing audio or image files (it will overwrite .m3u files).  If any target conversions already exist then they are skipped and a log appended to ~/foma.log.

foma script is short, modular and well commented so you can easily understand what it does and why.  It’s simple to add,  remove or modify encoders or taggers.  For example you might prefer to completely remove calls to Nero’s proprietary tools, or perhaps  add musepack or wavpack encoding and tagging.

Q: Why not just use ffmpeg without calling external encoders?

A: ffmpeg is great for decoding audio and grabbing metadata but it doesn’t support all encoders, or all the options of each supported encoder, and it can have trouble writing tags with some formats.  For example my installed version of ffmpeg loses all metadata at the writing stage on converting from ogg (libvorbis) to m4a (libfaac), though flac to m4a works fine.  With some formats you might find that writing  some metadata fields you want to use is unsupported and the data has been discarded.

I also want to strip replaygain data when converting to a lossy format because almost every lossy codec slightly raises the levels*.  Not only does this render the copied replaygain data inaccurate,  on a few tracks this will take a brickwall loudness mix into clipping.

By using ffmpeg to decode to PCM WAV then it’s possible to use any encoder that can read from STDIN or a named pipe. In this case it means neroAacEnc is scripted for automated/batch conversions but you could just as well do the same with whatever new encoder comes along, or with other encoders which are unsupported or incompletely supported in free software operating systems (ape and tak come to mind).

Q: Isn’t this an awful lot slower than just using ffmpeg or oggenc or whatever?

edit: following was for the original script.  foma is now massively faster than ffmpeg or oggenc or any other script or application which doesn’t run multiple parallel decode/encode processes.

A: Even with the extra metadata handling this script completes (on my 32-bit Debian stable system) almost as quickly as performing the same conversion with the ffmpeg binary; the time penalty is only about 5%).  I was also surprised to find that this script can be faster than the K.I.S.S**  solution, for example `oggenc -q 4 file.flac` is slower than `foma file.flac` every time.   ***On a less positive note if I perform the same conversion on the same machine running Windows XP SP3 32-bit using foobar2k as a frontend for oggenc.exe then the conversion takes only about 70% of the time as ffmpeg in Debian (edit:  I had another look at this and foobar achives its good performance by running two processes in parallel;  the Windows oggenc binaries don’t really perform any differently to those compiled using GCC, so the following sentence is redundant).  It may finally be time to head over to  or and bow down before the power of the teenagers||greysuits…..

*The only lossy format I’ve encountered which has no effect on the levels is lossy/hybrid wavpack but for compatibility and convenience reasons it’s not a codec I use for lossy compression.

**UNIX mantra: Keep It Simple, Stupid!

***No longer true.  New foma with parallel processes now easily outperforms other methods in Debian and in Windows XP.

Automatically create extm3u (extended .m3u) playlist in GNU/Linux

May 22, 2012

I couldn’t find a satisfactory command line method to create extended .m3u playlists in Debian.  The best is a perl script which you can find at  It’s really good and very quick but only supports mp3, ogg and flac files.  I modified it to also support mp4/m4a and submitted a patch but the author wasn’t interested enough to respond.  In any case I want a tool that will support numerous audio formats so I wrote a bash script which uses normal GNU utilities such as awk and bc along with ffprobe (part of ffmpeg) and consequently can write an extended .m3u for any files that (your installed version of)  ffmpeg supports. The script can be found at

20 March 2013: New version at supports opus codec files and has a fix for problem with wrong track duration (introduced by recent changes in ffmpeg/ffprobe)
21 April 2014: New version at same link as above, now works with locales which use , for decimal divider. Thanks to Tina Keil.

22 December 2015: updated version at same link to support relative paths, thanks to Dave.

9 January 2016 removed problematic relative paths function.

I’ll just post the usage/options here so you can see what it does (it isn’t complicated):

bashplaylist [options] {-o out} <directory>

-p  writes the file names in .m3u with full path
(default is simple file name without path)

-r  recurses through subdirectories and writes file names with
full path

-o <output directory>  (default is target directory)

bashplaylist finds the audio files in the directory, parses
the metadata, then writes an extended .m3u playlist

bashplaylist understands the same files as  your
installed version of ffmpeg.

If bashplaylist fails please check output directory exists
and is writeable.

#june 07 2012 edited script to remove unwanted / in regex which prevented ogg files from being parsed

Debian GNU/Linux: Split Lossless Audio with Cue

May 1, 2012

I wanted the simplest possible way to split cue+lossless into individual flacs, all named and tagged from the cue file.  There are some good scripts out there but I really don’t want to have to remember anything at all in terms of options and I don’t want any output format other than flac.  I’ve written a small script that does exactly what I want.

It detects cue sheet character encoding and if it’s anything other than UTF-8 it automatically writes a new UTF-8 cue sheet so that the final file names and tags retain their diacritic marks and non-Latin characters.

It discards unwanted pregap output.

It works well with find so it’s easy to use it recursively and/or for multiple cue+lossless files.  It works equally well as a file manager context menu entry and will run fine without needing a terminal.  This is a nice feature for Thunar custom actions.

It doesn’t modify, overwrite or delete existing files.

It works with any lossless file supported by shntool, which means just about anything.

It’s short  and simple so easily modified if desired.

This is a happy feeling non-judgemental script:  there are no options or settings or configuration files so if it doesn’t work it probably isn’t your fault, leaving you free to relax and move onto doing something else.

It’s as easy to use as `cue2flacs my_cuesheet.cue`


`find <path> -iname “*.cue” -execdir cue2flacs “{}” \+`


`for i in *.cue ; do cue2flacs “$i” ; done`

edit:  an improved version of this script is at

The improvement is in detection of character encoding which is vastly better now due to using python-chardet, so writing a new utf8 cue sheet should work every time now.