469,326 Members | 1,645 Online
Bytes | Developer Community
New Post

Home Posts Topics Members FAQ

Post your question to a community of 469,326 developers. It's quick & easy.

math.h trig functions questions (and some forgotten high school math)

Do the trig functions in math.h work in degrees, radians or what? For
some reason it doesn't say which in "man math.h"

IIRC the arctan of a slope gives the angle. So, shouldn't atanf((float)1)
return 45 or .7something (degrees or radians) instead of some negative
number?

--
Mark Healey
marknews(at)healeyonline(dot)com

May 21 '06 #1
7 2900
Mark Healey <di*@spammer.die> writes:
Do the trig functions in math.h work in degrees, radians or what? For
some reason it doesn't say which in "man math.h" IIRC the arctan of a slope gives the angle. So, shouldn't atanf((float)1)
return 45 or .7something (degrees or radians) instead of some negative
number?

If on a Unix/Linux system - man 3 sin

--
Chris.
May 21 '06 #2
On Sun, 21 May 2006 03:43:36 GMT, Mark Healey <di*@spammer.die> wrote
in comp.lang.c:
Do the trig functions in math.h work in degrees, radians or what? For
some reason it doesn't say which in "man math.h"

IIRC the arctan of a slope gives the angle. So, shouldn't atanf((float)1)
return 45 or .7something (degrees or radians) instead of some negative
number?


Doesn't your C reference book tell you? All C trigonometric functions
work in radians. If you want to work in degrees, you need to provide
functions or macros to do the conversions back and forth.

--
Jack Klein
Home: http://JK-Technology.Com
FAQs for
comp.lang.c http://c-faq.com/
comp.lang.c++ http://www.parashift.com/c++-faq-lite/
alt.comp.lang.learn.c-c++
http://www.contrib.andrew.cmu.edu/~a...FAQ-acllc.html
May 21 '06 #3
Mark Healey <di*@spammer.die> writes:
Do the trig functions in math.h work in degrees, radians or what? For
some reason it doesn't say which in "man math.h"

IIRC the arctan of a slope gives the angle. So, shouldn't atanf((float)1)
return 45 or .7something (degrees or radians) instead of some negative
number?


Some negative number?

This program:

#include <stdio.h>
#include <math.h>
int main(void)
{
printf("atanf((float)1.0) = %f\n", atanf((float)1.0));
return 0;
}

gives me:

atanf((float)1.0) = 0.785398

Did you remember the "#include <math.h>"? Did you make sure to link
in the math library (on a Unix-like system, you might need a "-lm"
option).

--
Keith Thompson (The_Other_Keith) ks***@mib.org <http://www.ghoti.net/~kst>
San Diego Supercomputer Center <*> <http://users.sdsc.edu/~kst>
We must do something. This is something. Therefore, we must do this.
May 21 '06 #4

"Keith Thompson" <ks***@mib.org> wrote in message
news:ln************@nuthaus.mib.org...
Mark Healey <di*@spammer.die> writes:
Do the trig functions in math.h work in degrees, radians or what? For
some reason it doesn't say which in "man math.h"

IIRC the arctan of a slope gives the angle. So, shouldn't
atanf((float)1)
return 45 or .7something (degrees or radians) instead of some negative
number?


Some negative number?

This program:

#include <stdio.h>
#include <math.h>
int main(void)
{
printf("atanf((float)1.0) = %f\n", atanf((float)1.0));
return 0;
}

gives me:

atanf((float)1.0) = 0.785398

Did you remember the "#include <math.h>"? Did you make sure to link
in the math library (on a Unix-like system, you might need a "-lm"
option).


And would atanf be in there, in particular one that accepts a float as
opposed to double? joe
May 21 '06 #5
"Joe Smith" <gr**********@netzero.net> writes:
"Keith Thompson" <ks***@mib.org> wrote in message
news:ln************@nuthaus.mib.org...
Mark Healey <di*@spammer.die> writes:
Do the trig functions in math.h work in degrees, radians or what? For
some reason it doesn't say which in "man math.h"

IIRC the arctan of a slope gives the angle. So, shouldn't
atanf((float)1)
return 45 or .7something (degrees or radians) instead of some negative
number?


Some negative number?

This program:

#include <stdio.h>
#include <math.h>
int main(void)
{
printf("atanf((float)1.0) = %f\n", atanf((float)1.0));
return 0;
}

gives me:

atanf((float)1.0) = 0.785398

Did you remember the "#include <math.h>"? Did you make sure to link
in the math library (on a Unix-like system, you might need a "-lm"
option).


And would atanf be in there, in particular one that accepts a float as
opposed to double? joe


Possibly not, since atanf was added in C99 -- but if atanf weren't in
the library, that wouldn't explain the OP's result of "some negative
number".

--
Keith Thompson (The_Other_Keith) ks***@mib.org <http://www.ghoti.net/~kst>
San Diego Supercomputer Center <*> <http://users.sdsc.edu/~kst>
We must do something. This is something. Therefore, we must do this.
May 22 '06 #6

"Keith Thompson" <ks***@mib.org> wrote in message
news:ln************@nuthaus.mib.org...
"Joe Smith" <gr**********@netzero.net> writes:
"Keith Thompson" <ks***@mib.org> wrote in message
news:ln************@nuthaus.mib.org...
Mark Healey <di*@spammer.die> writes:
Do the trig functions in math.h work in degrees, radians or what? For
some reason it doesn't say which in "man math.h"

IIRC the arctan of a slope gives the angle. So, shouldn't
atanf((float)1)
return 45 or .7something (degrees or radians) instead of some negative
number?

Some negative number?

This program:

#include <stdio.h>
#include <math.h>
int main(void)
{
printf("atanf((float)1.0) = %f\n", atanf((float)1.0));
return 0;
}

gives me:

atanf((float)1.0) = 0.785398

Did you remember the "#include <math.h>"? Did you make sure to link
in the math library (on a Unix-like system, you might need a "-lm"
option).


And would atanf be in there, in particular one that accepts a float as
opposed to double? joe


Possibly not, since atanf was added in C99 -- but if atanf weren't in
the library, that wouldn't explain the OP's result of "some negative
number".

I'm surprised that my implementation, circa ten years old, has it. joe

#ifdef _M_MRX000

/* MIPS fast prototypes for float */
/* ANSI C, 4.5 Mathematics */

/* 4.5.2 Trigonometric functions */

_CRTIMP float __cdecl acosf( float );
_CRTIMP float __cdecl asinf( float );
_CRTIMP float __cdecl atanf( float );
_CRTIMP float __cdecl atan2f( float , float );
_CRTIMP float __cdecl cosf( float );
_CRTIMP float __cdecl sinf( float );
_CRTIMP float __cdecl tanf( float );
May 22 '06 #7
Joe Smith wrote:
"Keith Thompson" <ks***@mib.org> wrote in message
news:ln************@nuthaus.mib.org...
"Joe Smith" <gr**********@netzero.net> writes:
"Keith Thompson" <ks***@mib.org> wrote in message
news:ln************@nuthaus.mib.org...
Mark Healey <di*@spammer.die> writes:
> Do the trig functions in math.h work in degrees, radians or what? For
> some reason it doesn't say which in "man math.h"
>
> IIRC the arctan of a slope gives the angle. So, shouldn't
> atanf((float)1)
> return 45 or .7something (degrees or radians) instead of some negative
> number?
Some negative number?

This program:

#include <stdio.h>
#include <math.h>
int main(void)
{
printf("atanf((float)1.0) = %f\n", atanf((float)1.0));
return 0;
}

gives me:

atanf((float)1.0) = 0.785398

Did you remember the "#include <math.h>"? Did you make sure to link
in the math library (on a Unix-like system, you might need a "-lm"
option).
And would atanf be in there, in particular one that accepts a float as
opposed to double? joe

Possibly not, since atanf was added in C99 -- but if atanf weren't in
the library, that wouldn't explain the OP's result of "some negative
number".

I'm surprised that my implementation, circa ten years old, has it. joe

#ifdef _M_MRX000

/* MIPS fast prototypes for float */
/* ANSI C, 4.5 Mathematics */

/* 4.5.2 Trigonometric functions */

_CRTIMP float __cdecl acosf( float );
_CRTIMP float __cdecl asinf( float );
_CRTIMP float __cdecl atanf( float );
_CRTIMP float __cdecl atan2f( float , float );
_CRTIMP float __cdecl cosf( float );
_CRTIMP float __cdecl sinf( float );
_CRTIMP float __cdecl tanf( float );

The math functions for float data type were reserved and made optional
in C89, and mandatory in C99. This seems to have produced some
confusion as to whether restricting a compiler to C89 mode, (gcc
default), may suppress the float functions, or break them, as in some
MSVC versions. Clearly, the provision for them in C89 was produced by
strong demand and intention of certain vendors to provide them.
May 22 '06 #8

This discussion thread is closed

Replies have been disabled for this discussion.

Similar topics

16 posts views Thread by Frank Millman | last post: by
17 posts views Thread by cwdjrxyz | last post: by
4 posts views Thread by John B. | last post: by
92 posts views Thread by Dave Rudolf | last post: by
110 posts views Thread by Gregory Pietsch | last post: by
15 posts views Thread by Morgan Cheng | last post: by
reply views Thread by kirby.urner | last post: by
reply views Thread by Jon Harrop | last post: by
reply views Thread by Gurmeet2796 | last post: by
reply views Thread by mdpf | last post: by
reply views Thread by listenups61195 | last post: by
By using this site, you agree to our Privacy Policy and Terms of Use.