Mathias Linux Music Page
News
Introduction
Software Used
Pitfalls
Resources
The Results
Thanks
Hit no:
30627 since 031013
News
05-03-08
Ehehehh.... There's not much happening on this page, that's for sure.
Watch out for the oooold info around here, everything is used on your own risk...
Mostly, I'm coding (at work or home) or sleeping or trying to make some music once in a while.
Life is good, but tinnitus sucks. Wear ear-protection! The newest musical stuff can be found
on the Computerville page. I haven't done all the music at that place.
MusE has become a really neat little beast. Hoping to be able to go to LAC in Karlruhe, Germany, in April.
03-11-06 New
ideas up on the Lunar
Shuttle Disaster page. MusE 0.6.2 released!
03-10-12 New
mix of "Computerville" up on the Lunar
Shuttle Disaster page.
03-10-11 Finally
back! A long time ago, I was hacked, and in my attempts to reinstall
everything I manage to fry my server. After that, I've gotten stuck in a
programming project (on my spare time. what I do on the rest of the time
is another story...). I've been working on improving the softsynth
version of Fluidsynth for MusE (originally written by Bob Ham and
others, but I guess I've rewritten most of it now). Mostly to help
myself, but others will benefit of it as well, I hope, but now, finally,
the same old stuff is up on a totally different place. Hope you'll find
anything useful here.
03-08-03 Got the
time to sit down and play a little. An alpha version of a tune that
probably will be called "Little Girl" is up on the Lunar Shuttle Disaster page.
03-07-21 Mother nature threw a
few lightning-bolts over our town resulting in a few fried switches,
telephone-networks, [insert your favourite sensitive electronical
equipment here], but we're up and running again.
Introduction
Welcome to Mathias Linux Music Page. I like music, and
Linux, and when combining those two the result can actually be quite
enjoyable. Of course, a whole bunch of software is needed to produce
anything audible at all. The good news is that a whole lot of software
is right now being developed that makes this possible.
Right now I'm on a crusade. A crusade to prove that it is possible to
produce something that's not only audible, but actually comparable to
the proprietary program suites that have been around for quite a while
(Cubase, ProTools etc...). NOTE: I did NOT say that the actual software
used for producing the music are comparable to the proprietary ones. I
still think there's a long way to go before that would be true. But,
they've actually come a long road. And it IS possible to use them. And
the final result IS comparable (I guess a studio techician will disagree
with that, but not the average listener).
Yes, there are lots of pitfalls on the road to producing something
enjoyable. I'm going to add some tips and tricks that might help you out
of weird problems (that I've been stuck in myself). Hope they might be
of any use.
The software used
My work is based on MusE, ZynAddSubFX, Fluidsynth, Jack, various LADSPA-plugins and JAM. I'm using Mandrake Linux 9.1 and a very friendly guy called Thac has put up a whole bunch of packages with audio-apps, ready to install. Most of them has worked very well for me. Thac's RPMS are definitely a must for the Mandrake Audio User. A low latency-kernel is a must (I just installed Thac's RPM and it went in just fine. Can't burn any cds using it though, and NVIDIA's display driver won't work with it. I guess I need to compile a kernel more tailored to my needs, but what the hey, it's working great for audio (and I'm too lazy to compile a kernel right now).)
Pitfalls
...or: the mystifying little things that sometimes fixes the problems.
Jack
Shut down artsd before starting up Jack, it saves you
trouble (someone told me one could have both running at the same time,
but I don't know what that should be good for, and I don't know if that
is true either. I'm happy with just running Jack, though :-). I found an
applet called Kickarts (can't find the link) that comes in handy when
turning on and off artsd. I'm mostly starting jack with jackd -R -d alsa
-d hw:0 -p 512 -r 48000 (I'm using an SB Live). There is also graphical
frontend for Jack, qjackctl,
if you prefer that. I had some trouble in my experiences with it
though, and prefer to use it the console way.
ZynAddSubFX
I didn't manage to get Thac's RPM-version of ZynAdd to
work (it should be fixed now, I hope). It had something to do with the
links to the fftw-libs.
I downloaded the source to ZynAdd (which doesn't include any
autoconf-generated Makefile) and had to manually change the libraries
which to link ZynAdd to. I switched from dfftw to sfftw, and it worked.
I must say I am very impressed with the sound of this synth, it
produces a really neat, warm sound. There is, however, one big problem
with this synth, and that is that it's not realtime safe. The
midithread, and the jack-thread accesses the same object, both locking
the same object when accessing it. One particular outcome of this is
that different period values in jack (the -p switch) results in timing
issues of various size. E.g. small period results (-p 512) in lesser
mismatch in timing whereas larger period (-p 2048) results in timing
errors that makes the result unbearable to listen to. I really hope to
get to investigate this issue further in the future (or that the author
manages to implement a workaround). ZynAdd has also been very stable on
me, although the realtime issues makes it tough to use it with other
CPU-intensive software.
The master FX-buses is a very nice feature too. It has
one rather peculiar oddity though. When running Jack in realtime mode
(which I always do...) loading a master-synth file most often causes it
to be zombiefied. It's a bit of a gamble to manage to get it to load (I
usually copy the mas_zyn-files to /mnt/ramfs, and still it gets tough
when having a couple of channels. Success rate is about 1/10. I think
ZynAdd doesn't use a separate thread for loading/various init-routines,
which might be a way to fix the problem).
Remember to connect ZynAdd to jack's alsa_pcm with [insert your
favourite jackconnect tool here], or else you won't hear much of what's
coming out, since this is not done by default! (I've hardcoded the
jack-outputs in the code myself, but it shouldn't be difficult to get
the default values from jack itself, but... I really hope to get time to
fix this in the future, as well).
MusE
I'm using MusE in realtime mode (muse -R).
I had problems getting MusE to connect to Jack (which is a must if you
want to use any other synths than the built in ones (which don't work
very well yet, in my opinion).
I thought the problem was with Jack, but it appeared to be the
"startup-tune" (~/.musePrj) that was messing up things. Eager as I am I
wanted to try it out before running it with Jack. MusE looks for Jack
first, if it doesn't find Jack it settles for alsa instead. MusE opens
the last saved file when starting (thus starting with the configuration
that goes for that tune, which in my case was Alsa). Removing ~/.musePrj
and restarting MusE with Jack running made it use Jack instead, which
solved the problem. Removing ~/.musePrj seems to remove a lot of
trouble. Always try this first whenever MusE goes weird at you.
If you're using qt-3.1.2 and are having problems with uic when
compiling, you can try to change the line in widgets/appearancebase.ui
from:
!DOCTYPE UI>UI version="3.2" stdsetdef="1">
to
!DOCTYPE UI> UI version="3.1" stdsetdef="1">
This problem is fixed in the CVS now.
LADSPA
Using LADSPA plugins in MusE is gambling with high
odds. Some plugins use stereo input and others mono. Using a
stereo-input plugin on a mono-track (and vice versa) most oftenly
crashes MusE. Even if you do get the plugin to work, other problems
might be lurking, and it might not be easy to find out which plugin it
is that causes the problems. I plan to write a list of plugins that I've
been using that seem to be working, in the future.
Fluidsynth
I had some very strange errors while using Fluidsynth. When playing everything worked OK, but after stopping, it got zombiefied by Jack after a few seconds. I noticed it had something to do with the reverb (when turning it off everything worked OK). I've heard/read something about problems with various reverbs. When the audio level goes to zero calculations get tricky (it's called a denormal-problem I think). Installing fluidsynth from CVS solved the problem.
JAM
This neat mastering tool really blew my mind. The fun
thing is that I've got the impression that the developers have only
worked on it for a short time. The only major pitfall I had was that I
had problems downloading it (couldn't get CVS-access on Sourceforge!
They say it's overloaded now and then). Here is a tgz-archive
for the interested (thanks to Jan Depner).
Ehmm, thinking of it, I had one other pitfall with this baby, and it
was a few xruns. Not sure whether this had to do with my system, various
other software packages (like MusE) or JAM itself. They got less
frequent though, when I used Ecasound as input to JAM instead of MusE.
It's a real thriller mixing down when you've got half a minute or two
before you're through the song (am I going to get an xrun now? am I
going to get an xrun now?? waaah! I got one! ....do it all over again).
I should probably try to optimize my system a bit, but there's always so
many things you need to do... :-)
Resources
I've made a few ZynAdd-patches. You can find them here.
The Results
Now, what do you think? Is this stuff worth the trouble
of setting the gear up? Take a listen to my upcoming project "Lunar
Shuttle Disaster" and make your own opinion. I have to say it's a really
nice feeling to know the result is completely made with free software.
Thanks...
...goes to all OSS software developers.
Special thanks go to Robert Jonsson, Paul Nasca and Werner Schweer.
Mail me here