| The printed resolution from the Csound "print" statement is not the same as the actual resolution, which is much higher. Yes, the printf opcode will help.
The actual resolution should be the same as for the type of the audio sample variable. For "float" Csound, that is a 32-bit, single-precision floating point number. It has 24 bits of precision in the mantissa. For "double" Csound, that is a 64-bit, double-precision floating point number in the mantissa. It has 52 bits of precision. For each decimal digit, there is between 3 and 4 bits. So, there are 7 digits of precision for "float" and 16 digits of precision for "double."
For each multiplication or division, depending on whether the operands are integers, rational numbers, repeating decimals, or irrational decimals, there may or may not be rounding error in the result. If there is rounding error, it is at most 1 bit of lost precision per operation (in addition to any rounding in the binary representation of rational or real numbers).
For float samples, if the signal stays within the mantissa, the signal to noise ratio is 6.02 times 24, or 144 dB. At worst, each operation will create 6.02 dB of additional noise due to rounding error. Our ears have an effective dynamic range of 120 to 130 dB, but we like our music compressed to a dynamic range of AT MOST 60 dB (and usually much less, say 20 dB). That gives us (144 - 60) / 6.02 = about 10 worst-case operations before we could possibly hear any degradation. In practice, we have several times that many operations before we hear any degradation or noise.
For double samples, if the signal stays within the mantissa, the signal to noise ratio is 6.02 times 52, or 313 dB. At worst, each operation will create 6.02 dB of additional noise due to rounding error. That gives us (313 - 60) / 6.02 = about 42, in practice several times that, of operations before there is any audible degradation or noise.
But if you trace the number of arithmetic operations in typical Csound instruments or other software synthesizers, the very complex instruments definitely are pushing into the range of audible degradation on good monitors with float, so it is no surprise that in some cases blindfold, controlled ABX testing confirms _occasional_ audible differences between music synthesized with float Csound versus the same music synthesized with double Csound. Equally, it is no surprise that there are easily audible differences between digital and analog implementations of the same synthesis algorithms.
Obviously, there is a good deal more "digital signal processing headroom" with double Csound, and therefore it should be used for all music rendered for critical listening. The float version should only be used where its speed advantage of about 15% is critical for real-time performance.
Hope this helps,
Mike
-----Original Message-----
>From: Adam
>Sent: May 25, 2008 9:36 AM
>To: csound@lists.bath.ac.uk
>Subject: [Csnd] precision
>
>
>May be a simple or silly question, but; what precision can I expect from
>simple i-rate divides ? To the right of the decimal point. As I can't seem
>to get below 0.001
>
>I can't find any mention of precision or resolution, in the manual.
>And feel I should really be knowing what to expect.
>
>I am using the -f csound package, which I understand to be 32-bit.
>Not the -d double precision.
>
>With the 32 package, can I get below 0.001 ?
>
>Could it be that further precision is there, but using the print ivar
>statement is inappropriate, and printf would help?
>
>Any help/clarification much appreciated.
>
>
>
>Send bugs reports to this list.
>To unsubscribe, send email sympa@lists.bath.ac.uk with body "unsubscribe csound"
|