A Note From the Author of aRts

In a recent post to kde-core-devel Stefan Westerfeld, author of the KDE multimedia framework aRts, announced that he would no longer be maintaining it. He has written a note on further development of aRts explaining some of the problems with aRts' design decisions. aRts was a pioneering system and a major help in bringing multimedia to Free Software, thanks to Stefan for making it happen.

Dot Categories: 

Comments

by Andre Somers (not verified)

Although there recently has been a mood that Arts should be dumped, I think we still owe Stefan a big Thank you! Arts has powered the multimedia in KDE for many years, and though it has it's problems, it isn't that bad at all. Sure, it may get replaced by something more modern and fit to the broad desktop-usage that is envisioned for KDE, but in the meantime, it has served us well. Thank you Stefan!

by muesli (not verified)

absolutely! thanks!

besides the current arts ranting... it's still able to provide stuff no other piece of software in this area achieved, yet. but as stefan explained, it's a sound-serving-decoding-coffee-cooking-doing-everything solution, which is hard to maintain. thanks for all your effort!

anyways, i'm looking forward to kde4, i'm sure we'll come up with a nice multimedia backend framework (i'm buzz-wording today *g*) by that time.

regards,
muesli

by charles (not verified)

What applications are at the frontline to replace aRTs in KDE. Where can one get info? What does that mean for future KDE multimedia development? I heard the the "analyzer lag" in amaroK was due to aRTS. What are aRTS's other problems?

by superstoned (not verified)

read some other topic here on the dot...

but to give a short answer:
-info: search the dot and google
-future: well, another solution has to be found...
-yep, arts isnt that fast, so the lag was due to arts.
-read the doc and the comments on the web. mostly: high latency, hi processor use, hard to work on.
-so KDE (and the whole FSworld) is looking for a replacement. NNM (or was it NMM?), MAS and Gstreamer seem to be in the picture. amarok and juk already support gstreamer, amarok also supports both other soundservers.

by charles samuels (not verified)

no, that lag is not due to arts, because arts is not "not that fast"

There's always going to be an inherent latency when you're pumping audio from software to the sound card's dma buffers on a non-realtime multitasking operating system. The way to solve that problem is to add a delay between the decoder and the visualisation that's equal to that of the decoder and the speakers. aRts cannot be held to blame if the application doesn't do that.

-Charles

by superstoned (not verified)

ok, I stand corrected :D

but why has it so much higher latency than other players? and why does it skip so often?

by charles samuels (not verified)

The latency is completely configurable between "as little as possible" to "as much as reasonably possible" And certainly less than XMMS does. I've seen players that take a bit to respond after a pause or seek, arts doesn't do this to any noticeable amount.

"It skips" so often because mpeglib (our default mp3 decoder in KDE <=3.2) didn't buffer disk accesses very well and couldn't read the mp3 data quickly enough from the disk, decoding it or sending it to the sound card wasn't the problem, but Linux 2.4's disk IO is incredibly bad (it's far worse than even I think it is!). It's much much much better in Linux 2.6.

We solved this problem by getting a new decoding plugin "aKode" (which does Vorbis, MP3, and also musepack), and buffers disk access much more. Furthermore, it does some magic calls to the kernel that say "I'm going to read in order, so buffer all you can, and unbuffer it as soon as I read it." These things pretty much have eliminated the problem entirely.

It helps to also have a preemptive kernel, SCSI harddrives, ...

-charles

by superstoned (not verified)

well, I haven't had any problems lately, exept for amarok, which seems to keep arts output open, blocking most other applications. but thats my main problem, now. the high cpu use and skipping have been fixed, mostly. the only problem I have with arts is that some apps can't use it natively so I have to use artsdsp (but alas, it works that way).

by charles samuels (not verified)

That would be another bug in amaroK (which, btw, I long ago fixed in noatun). Amarok has to use arts correctly so that it releases /dev/dsp. Report a bug.

When I press stop in noatun, arts will release /dev/dsp shortly thereafter (as per how I've configured it).

by Ian Monroe (not verified)

Keep in mind, that like arts itself, amaroK lacks a maintainer for its arts plugin.

by Melchior FRANZ (not verified)

> arts isnt that fast, so the lag was due to arts

The problem is, that aRts' scope function always reads from the start of the sound buffer. So, if have a big buffer configured because you want to prevent skips (see kcontrol/Sound & Multimedia/Sound System/Skip prevention/Sound Buffer) then you get for several frames the same scope data delivered again and again. aRts isn't slow at that. It serves the same old and stale scope data quickly. It just *seems* as if it were slow. If you make the sound buffer as small as possible, then you'll see that there's no noticeable lag any more. One could probably have worked around that, but the sparse documentation didn't offer an apparent solution.

by Darkelve (not verified)

Don't be sad by the way arts is being treated now, it really made a difference and served a noble purpose.

by Patrick Stinson (not verified)

I have been developing a DJ application for a few years, and have found the biggest problems to be in using driver abstractions - alsa, jack, oss, and arts. aRts has always been a reliable test bed that I can fall back on when the others don't work. After a year of using the native alsa API, I'v fallen back on arts again to get my app working. Latency is a problem with arts, but My application code needs to be profiled right now, not the driver code!

Thanks!

by Anonymous Coward (not verified)

Netcraft confirms it, aRts is dead. Finally the old horse is dying, most end users hate aRts, it gives nothing but trouble and latency.

Though i agree that it was a good idea, it needs to be replaced with something else from scratch, maybe gstreamer.

Here's looking to kde 3.4

by Jason Keirstead (not verified)

... is split into two seperate components - a library for KDE that handles all the multimedia stuff, and a sound server, and that the library *can* or *can not* use the sound server based on the user's choice.

I mean, I fully understand why a sound server is needed for people without hardware mixing, but for all of us who do, having to run a sound server to provide mixing capabilities inferior to those of our card is nonsense.

Jep, i think thats the way to go. Which would make arts a thin layer on systems which support mixing and a little thicker layer on systems where this is not possible.

by jambo (not verified)

For Software mixing you can use Alsa dmix, there is no need for a Soundserver to do that.

by Evan "JabberWok... (not verified)

Cool. How do I install ALSA on my Solaris Sparcstations?

by c0p0n (not verified)

with an axe?

by Anon (not verified)

Who on earth listens to audio on a sparcstation?
Get a radio. It has more computing power, too.

by standsolid (not verified)
by standsolid (not verified)

oops didn't read the "Solaris" part. but still...

by theorz (not verified)

The problem I have with dmix is that it does not work very well. It can only do two channels. It makes my audio sound bad (from what I have read this is to do with my sound drivers). It seems to randomly crash. It is hard to setup (anything more than just works is hard). It seems to have compatibility issues with apps.

The most worrying thing about dmix is how slow its development seems to be going. It was introduced in alsa 0.9.0 on 2003-03-02. It has only recently got to the usable state in alsa 1.0.6. And even now it has so many problems. This to me says that it A) is really hard to develop and debug, or B) it is not well maintained. Neither are good things.

Some of these new sound servers like polyaudio work great today. It does provide other neat features like network transparency, playing music across multiple devices, and plugins. But the main thing is that it works.

To me the best would be to use something like gstreamer throughout kde. That way the default audio sink and kde does not have to bind itself to any one solution. The people with good soundcards can use an alsa sink, the terminal people can use a network transparent sound server, and the people who don't use linux can use whatever they need to for mixing.

by Alexey Morozov (not verified)

What people think about polypaudio (http://0pointer.de/lennart/projects/polypaudio/)?

by mETz (not verified)

ahh yeah, and it will decode mp3, ogg, flac etc. and of course it will give me an equalizer, various ways to pipe my sound-output to somewhere else and all this with an easy to use API.
Uhm... wait, no, that's arts, not dmix.

by ahoi (not verified)

AFAIK NetBSD will get in kernel sound mixing soon. Combine that with clonable audio devices and you don't need any sound daemon anymore.

by ajs (not verified)

ALSA's dmix plugin provides this in userspace, which is far better than putting non-kernel related code into the kernel.

This solution would also seem to fit the bill. OSS is obsolete.

by Robert Wallner (not verified)

Jack ( http://jackit.sourceforge.net ) was designed from the ground up with professional audio work in mind. I use arts' jack plugin, but a better idea would be to interface directly to jack.

by mikeyd (not verified)

It's designed for professional audio work, not desktop use and network streaming. Different goals need different solutions.

by mozai (not verified)

Jack Output?
Should be fairly easy with
http://bio2jack.sourceforge.net/

by linus_baltimore (not verified)

I just have to say I think everyone that is demeaning aRts is insane... I have used aRts continuously for years and i would say at most i have one minor problem every several months. Take that in comparison with the rate at which stupid comments surface here and I'd happily take my chances with aRts.

In addition, it's frustrating to see people parrot back the *exact same problems* he has already mentioned in such a disparaging way. Perhaps it isn't all-things-to-all-people, but it is free software.

In any event many thanks! I will continue to enjoy the use of aRts while I look forward to a very bright F&OS future.