This past week or so, I've put together an internal test stream for AllDay DJ 3. This is mainly to prove it's up to the challenge. Also, it means I can run this on a headless (no monitor) system in a rack that I don't need for things like coursework. I can also get the music on any computer in the house then - very useful!
So, let's talk through the components, starting with the system itself. Well, it's your off the shelf Linux box. The one I'm using currently runs Gentoo (not my choice) but I have also done this with a stable Debian system.
Basic system in place, let's get our audio playing. A silent radio station is useless!
I installed PostgreSQL, a VNC server and Sun Java 6. This is enough to get AllDay DJ 3 ticking over. My music library (now categorised and rather broad spectrum) and some jingles I knocked together were loaded. At this point, I have a playout system pushing audio out to the sound card and sounding a bit like a radio station. The music choice got a bit of a mixed response from friends helping with the project. :P
Now, we've got our audio - how do we get it to the audience of one (me!). Well, that requires streaming. There's two components to this - the streaming source and the streaming server.
If you're not up with the terminology: the streaming source (as I've called it), is the piece of software that captures the audio then sends it to the streaming server. The streaming server then supplies copies of this stream to the listener.
Being a Linux box, I went open source. Initially I used Darkice as the source software and Icecast as the server software. Simply tell darkice to use the "Stereo Mix" as a source. It worked and I got an MP3 stream direct to my desktop.
However, it sounded a bit lifeless, especially compared to what you hear on the dial. Time to add some audio processing.
Now, I don't own a compressor and whatnot that I could plug into the audio stream. Also, it kills the idea of using the "Stereo Mix" source if I have to use external kit. To top it off, most audio processing kit can't be adjusted remotely.
What I needed was a software solution. Thankfully one exists. It means I have to move from an MP3 stream to an OGG stream. That's not a huge issue.
The solution is to make use of ecasound and ices. Both are tools that I had not heard of before until recently but due to the stdin/stdout support, they can be tied together without the need for another sound card - useful!
Now the command line I used to launch the internal stream is:
ecasound -i alsahw,0,0 -o stdout -eca:10,0.01,1,1 -ea:500 | ices /etc/ices2/ices.xml
This tells ecasound to take take audio from the first alsa sound card (set to record from "Stereo Mix" using alsamixer). The "-o stdout" bit tells ecasound to spew out to the ices streaming source software.
The next parts of the ecasound command are the inteseting parts.
"-eca:10,0.01,1,1" is the compressor settings. It means knee at 10%, attack of 0.01s then use a 1:1 ratio (I just want everything level / heavily compressed to start with, I'll adjust later). "-ea:500" just means amplify 500% (or 5x).
The final part of the command tells "ices" to launch with the correct config file. This has details of my server and to take an audio stream from stdin.
The suprising result of all this is that it possible to run an radio station from a Linux box. All be it one that streams on a closed network.
No comments:
Post a Comment