Chief Delphi

Chief Delphi (http://www.chiefdelphi.com/forums/index.php)
-   Extra Discussion (http://www.chiefdelphi.com/forums/forumdisplay.php?f=68)
-   -   paper: CORDIC Trigonometric Math Library (http://www.chiefdelphi.com/forums/showthread.php?t=58262)

Pat Fairbank 25-07-2007 21:08

paper: CORDIC Trigonometric Math Library
 
Thread created automatically to discuss a document in CD-Media.

CORDIC Trigonometric Math Library by Pat Fairbank

Pat Fairbank 25-07-2007 21:10

Re: paper: CORDIC Trigonometric Math Library
 
I felt like doing some programming, so I updated the CORDIC math library I posted a few years ago.

I made a few changes such as returning both the sine and cosine values instead of throwing one away (since CORDIC calculates both at once), and downgrading from 24-bit math to 16-bit math in the interest of speed. However, the biggest change is that the library is now written in PIC assembly instead of C, since I was curious to see if there was any speed advantage to be had.

I did some speed testing by calling the function as many times as possible in one Process_Data_From_Master_uP() loop before the RC crashed. The assembly implementation of the sin_cos() function took 4500 calls to crash while the C implementation took 1800 calls; the atan2_sqrt() function took 4700 and 1900, respectively. So it seems that the assembly implementation is about 2.5 times faster than the C implementation.

Any questions or comments are welcome.

Pat Fairbank 22-01-2008 22:00

Re: paper: CORDIC Trigonometric Math Library
 
I just uploaded a second revision to the trig library. There was a bug in the way the previous versions were handling the C function calls in assembly - the software stack wasn't being manipulated properly, with the result that the trig functions would work as expected when called from a function that didn't have local variables, but would return strange values when called from a function that did.

So if you're using the library and are seeing strange return values, you probably have an older version and need to update to Revision 2.

comphappy 09-02-2008 00:15

Re: paper: CORDIC Trigonometric Math Library
 
EDIT: Ignore this post, I can not delete it

neutrino15 09-02-2008 00:54

Re: paper: CORDIC Trigonometric Math Library
 
What is the advantage to using this vs a lookup table to the desired degree of accuracy?

How much more accurate and slow is the built in <math.h>?

Uberbots 09-02-2008 01:11

Re: paper: CORDIC Trigonometric Math Library
 
Quote:

Originally Posted by neutrino15 (Post 695004)
What is the advantage to using this vs a lookup table to the desired degree of accuracy?

How much more accurate and slow is the built in <math.h>?

Well, the math.h implementation can be called ~100 times per second (speed test that was posted on CD at some point this month), and this function takes a half second for 4500 calls (a half second being the max time a loop can execute before the OI says it 'crashed')

so id say its about... 90x faster?

someone call me on this if my math is wrong.

comphappy 09-02-2008 01:36

Re: paper: CORDIC Trigonometric Math Library
 
Ok i just found out what is needed to get this code to compile with the new 3.02 or higher compiler,
you need to replace all instances of AARGB3 with the new definition of __AARGB3
you can see the reference to this naming change here:
http://ww1.microchip.com/downloads/e...03-README.html
ref (27624)


All times are GMT -5. The time now is 11:35.

Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Copyright © Chief Delphi