From Fedora Project Wiki
 
(9 intermediate revisions by the same user not shown)
Line 1: Line 1:
==Real Time Audio Production:Taking it a Step Further==
==Real Time Audio Production:Taking it a Step Further==


Ok, so you have installed a real time kernel and you are beginning to understand how it works, but you feel that something is still compromising your low latency objectives.  Maybe you are running JACK(JACK Audio Connection Kit) and you are are experiencing a large amount of XRUNs(inconsistencies).  Or, maybe you just want see how low of a latency is possible on your hardware.  Well, keep in mind that your latency is affected by everything from the cache in your CPU to the device driver for your sound card.  This test will scan your system and perform a number of checks. The checks are intended to help you achieve minimal latencies while lowering the possibility of experiencing an XRUN.
Ok, so you have installed a real time kernel and you are beginning to understand how it works, but you feel that something is still compromising your low latency objectives.  Maybe you are running JACK(JACK Audio Connection Kit) and you are experiencing an unusual amount of dropouts and inconsistencies.  Or, maybe you just want push the boundaries and determine the  lowest latency that is possible on your hardware.  Well, keep in mind that your latency is affected by everything from the cache in your CPU to the device driver for your sound card.  That said, the following guide is intended to help you achieve minimal latencies with an acceptable amount of predictability.  This way, your computer will act as a tool for your audio production needs as opposed to a hindrance to your creativity. 
 
Note: If you are having trouble getting JACK Audio Connection Kit to start at all, try running it in Soft Mode.  Open JACK, look under Setup Parameters and put a check in the box to mark Soft Mode as being on.


==Checking Your Configuration==
==Checking Your Configuration==
    
    
This first program was shown to me by raboof in the #opensourcemusicians channel on irc.freenode.net.  As far as I know, he wrote this program without any help.
This program was written by [http://arnout.engelen.eu/index.php/Main_Page Arnout Engelen].  
This is a real time configuration quick scan.  You can download it from [http://code.google.com/p/realtimeconfigquickscan/ this link].


Follow the instructions on the site or you can use my instructions.  Notice that my instructions will run the command line version as opposed to the GUI version and that the GUI version is still experimental.   
(Note to the wary):This program will '''only''' scan your computer for optimized real time settings.  It will '''not change''' anything on your computer.  It is also not necessary to have a real time kernel installed to run this script.   
   
You can download it from [http://code.google.com/p/realtimeconfigquickscan/ this link] and
follow the instructions on the site or you can use my instructions that are provided below.  Notice that my instructions will run the command line version as opposed to the GUI version and that the GUI version is still experimental.   


To install this program, you will need to install mercurial. So, from a terminal, do
1. To install this program, you will need to install mercurial. So, from a terminal, do
<pre> su -c 'yum install mercurial'</pre>  
<pre> su -c 'yum install mercurial'</pre>  


 
2. Download the program:
1. Download the program:
<pre>hg clone https://realtimeconfigquickscan.googlecode.com/hg/ realtimeconfigquickscan</pre>
<pre>hg clone https://realtimeconfigquickscan.googlecode.com/hg/ realtimeconfigquickscan</pre>


2. Navigate to the ~/realtimeconfigquickscan directory  
3. Navigate to the ~/realtimeconfigquickscan directory  
<pre>cd realtimeconfigquickscan/</pre>  
<pre>cd realtimeconfigquickscan/</pre>  
for the last part I choose to run the command line version as I have had better results with it.   
for the last part I choose to run the command line version as I have had better results with it.   


3.So, type <pre>./realTimeConfigQuickScan.pl</pre>  
4. So, type <pre>perl realTimeConfigQuickScan.pl</pre>  
and hit enter.
and hit enter.


Now, if the scan reports that something is not optimized, it will not only tell you, but it will give you a link to [http://wiki.linuxmusicians.com/doku.php?id=system_configuration this website], which has detailed information about the many checks that are performed with this program.  I encourage you to learn as much as you can about how your computer works.  The more you understand, the more comfortable you will be while playing and composing music on your computer.
Now, if the scan reports that something is not optimized, it will not only tell you what is wrong, but it will tell you how to fix it. Upon running the script again, you will be able to tell if you made the changes correctly or not.  I encourage you to learn as much as you can about the things you choose to alter.  The more you understand, the more comfortable you will be while playing and composing music with your computer.


Granted, all of the tests in this scan may not apply to you and your hardware, but this is where the real fun begins.  And we all know that real fun can only happen in real time.  
Granted, all of the tests in this scan may not apply to you and your hardware, but this is where the real fun begins.  And we all know that real fun can only happen in real time.  
Line 30: Line 33:
The very last thing you will likely see from the output of this scan is something like this <pre>** Set $SOUND_CARD_IRQ to the IRQ of your soundcard to enable more checks.
The very last thing you will likely see from the output of this scan is something like this <pre>** Set $SOUND_CARD_IRQ to the IRQ of your soundcard to enable more checks.
   Find your sound card's IRQ by looking at '/proc/interrupts' and lspci.</pre>
   Find your sound card's IRQ by looking at '/proc/interrupts' and lspci.</pre>
Do not be perturbed!
According to [http://arnout.engelen.eu/index.php/Main_Page Arnout Engelen], the writer of this script, this last part of the scan has only proved beneficial in one case and is not worth worrying about.  If you are interested in continuing in this direction, there is a nice script by the name of [http://ccrma.stanford.edu/planetccrma/mirror/fedora/linux/planetcore/13/x86_64/repoview/rtirq.html rtirq] that you can get from the Planet CCRMA repositories.  For more information on how that script works, I suggest visiting [http://subversion.ffado.org/wiki/IrqPriorities this website].
==On Benchmarking==
As I became more interested in the concepts of real time computing , I experimented with a few simple, yet interesting benchmark tests.  You may want to do the same.  However, be warned that the average benchmark test only tests the benchmark program itself, and our goal here is to make and/or record music using our computer.  These tests are super interesting, and you can find plenty of information about them at the  [https://rt.wiki.kernel.org/index.php/RT:Benchmarks RTwiki ].  For the most part, these tests are short and sweet and are a great way to begin learning about real time preemption.  I find the idea of splitting time up into nanoseconds very interesting and slightly incomprehensible.  But, to avoid digressing into another topic completely, your best benchmarking tool for audio purposes may be the JACK Audio Connection Kit using your preferred settings and applications.


According to raboof, the writer of this program, this last part of the scan has only proved beneficial in one case and is not worth worrying about.  For more information on IRQ priorities, I suggest checking out [http://subversion.ffado.org/wiki/IrqPriorities rtirq].  Rtirq is provided in the Planet CCRMA repositories so don't fret about compiling it.
==Real Time Computing Links==


In any case, I encourage you to run the test and post any concerns, comments, or questions you may have to [http://linuxmusicians.com/viewtopic.php?f=27&t=452&start=75&st=0&sk=t&sd=a this website]You will need to set up an account to make a post on the forum. Raboof goes by the same name(raboof) on the forum.
As you can imagine, there are many uses for real time computing.  And let's face it, the computer doesn't care if it is processing music or not. So, it becomes an issue of understanding how the kernel, the hardware, and the applications interact at the nanosecond levelTo save space and time, and to avoid repeating another wiki word for word, I will leave you with some links that further elaborate on the topic of a low latency performance objective. After all, I am just the messenger.


The scan may be different by the time you read this tutorial. As I understand it, this is an ongoing project. To check for news and changes , I suggest following [http://linuxmusicians.com/viewtopic.php?f=27&t=452&start=75&st=0&sk=t&sd=a this link] to the forum discussion.
* [https://rt.wiki.kernel.org/index.php/Main_Page RTwiki Homepage]
* [http://subversion.ffado.org/wiki/IrqPriorities IRQ Priorities]
* [http://oreilly.com/catalog/linuxkernel/chapter/ch10.html Understanding the Linux Kernel:Chapter 10 Process Scheduling]


==Tools for Benchmarking==  
==Update==


As I became more interested in the real time concepts, I experimented with a few simple, yet interesting benchmark tests.  However, the average benchmark test only tests the benchmark program itself, and our goal is to make and/or record music using our computerThese tests are interesting, and you can find more information about them [https://rt.wiki.kernel.org/index.php/RT:Benchmarks here].  For the most part, these tests are short and sweet and are a great way to begin learning about shell scripting.  But, to avoid digressing into another topic completely, your best benchmarking tool may be the JACK Audio Connection Kit using your preferred settings and applications.
Lately, I have gone back to using nothing but guitar and ampI will reserve my knowledge of this genre for future uses and recording. i.e., my guitar playing needs improvement.

Latest revision as of 22:42, 9 March 2011

Real Time Audio Production:Taking it a Step Further

Ok, so you have installed a real time kernel and you are beginning to understand how it works, but you feel that something is still compromising your low latency objectives. Maybe you are running JACK(JACK Audio Connection Kit) and you are experiencing an unusual amount of dropouts and inconsistencies. Or, maybe you just want push the boundaries and determine the lowest latency that is possible on your hardware. Well, keep in mind that your latency is affected by everything from the cache in your CPU to the device driver for your sound card. That said, the following guide is intended to help you achieve minimal latencies with an acceptable amount of predictability. This way, your computer will act as a tool for your audio production needs as opposed to a hindrance to your creativity.

Note: If you are having trouble getting JACK Audio Connection Kit to start at all, try running it in Soft Mode. Open JACK, look under Setup Parameters and put a check in the box to mark Soft Mode as being on.

Checking Your Configuration

This program was written by Arnout Engelen.

(Note to the wary):This program will only scan your computer for optimized real time settings. It will not change anything on your computer. It is also not necessary to have a real time kernel installed to run this script.

You can download it from this link and follow the instructions on the site or you can use my instructions that are provided below. Notice that my instructions will run the command line version as opposed to the GUI version and that the GUI version is still experimental.

1. To install this program, you will need to install mercurial. So, from a terminal, do

 su -c 'yum install mercurial'

2. Download the program:

hg clone https://realtimeconfigquickscan.googlecode.com/hg/ realtimeconfigquickscan

3. Navigate to the ~/realtimeconfigquickscan directory

cd realtimeconfigquickscan/

for the last part I choose to run the command line version as I have had better results with it.

4. So, type

perl realTimeConfigQuickScan.pl

and hit enter.

Now, if the scan reports that something is not optimized, it will not only tell you what is wrong, but it will tell you how to fix it. Upon running the script again, you will be able to tell if you made the changes correctly or not. I encourage you to learn as much as you can about the things you choose to alter. The more you understand, the more comfortable you will be while playing and composing music with your computer.

Granted, all of the tests in this scan may not apply to you and your hardware, but this is where the real fun begins. And we all know that real fun can only happen in real time.

The very last thing you will likely see from the output of this scan is something like this

** Set $SOUND_CARD_IRQ to the IRQ of your soundcard to enable more checks.
   Find your sound card's IRQ by looking at '/proc/interrupts' and lspci.

Do not be perturbed! According to Arnout Engelen, the writer of this script, this last part of the scan has only proved beneficial in one case and is not worth worrying about. If you are interested in continuing in this direction, there is a nice script by the name of rtirq that you can get from the Planet CCRMA repositories. For more information on how that script works, I suggest visiting this website.

On Benchmarking

As I became more interested in the concepts of real time computing , I experimented with a few simple, yet interesting benchmark tests. You may want to do the same. However, be warned that the average benchmark test only tests the benchmark program itself, and our goal here is to make and/or record music using our computer. These tests are super interesting, and you can find plenty of information about them at the RTwiki . For the most part, these tests are short and sweet and are a great way to begin learning about real time preemption. I find the idea of splitting time up into nanoseconds very interesting and slightly incomprehensible. But, to avoid digressing into another topic completely, your best benchmarking tool for audio purposes may be the JACK Audio Connection Kit using your preferred settings and applications.

Real Time Computing Links

As you can imagine, there are many uses for real time computing. And let's face it, the computer doesn't care if it is processing music or not. So, it becomes an issue of understanding how the kernel, the hardware, and the applications interact at the nanosecond level. To save space and time, and to avoid repeating another wiki word for word, I will leave you with some links that further elaborate on the topic of a low latency performance objective. After all, I am just the messenger.

Update

Lately, I have gone back to using nothing but guitar and amp. I will reserve my knowledge of this genre for future uses and recording. i.e., my guitar playing needs improvement.