source: mainline/uspace/lib/math/generic/sincos.c

Last change on this file was 83932dc9, checked in by Jiří Zárevúcky <jiri.zarevucky@…>, 7 years ago

Split up libmath functions into more files

so that they don't conflict with fdlibm during static linking.

  • Property mode set to 100644
File size: 2.6 KB
Line 
1/*
2 * Copyright (c) 2015 Jiri Svoboda
3 * Copyright (c) 2014 Martin Decky
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * - Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * - Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * - The name of the author may not be used to endorse or promote products
16 * derived from this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30/** @addtogroup libmath
31 * @{
32 */
33/** @file
34 */
35
36#include <math.h>
37#include "internal.h"
38
39/**
40 * Computes sine and cosine at the same time, which might be more efficient than
41 * computing each separately.
42 *
43 * @param x Input value.
44 * @param s Output sine value, *s = sinf(x).
45 * @param c Output cosine value, *c = cosf(x).
46 */
47void sincosf(float x, float *s, float *c)
48{
49 float base_arg = fmodf(x, 2 * M_PI);
50
51 if (base_arg < 0) {
52 *s = -__math_base_sin_32(-base_arg);
53 *c = __math_base_cos_32(-base_arg);
54 } else {
55 *s = __math_base_sin_32(base_arg);
56 *c = __math_base_cos_32(base_arg);
57 }
58}
59
60/**
61 * Computes sine and cosine at the same time, which might be more efficient than
62 * computing each separately.
63 *
64 * @param x Input value.
65 * @param s Output sine value, *s = sin(x).
66 * @param c Output cosine value, *c = cos(x).
67 */
68void sincos(double x, double *s, double *c)
69{
70 double base_arg = fmod(x, 2 * M_PI);
71
72 if (base_arg < 0) {
73 *s = -__math_base_sin_64(-base_arg);
74 *c = __math_base_cos_64(-base_arg);
75 } else {
76 *s = __math_base_sin_64(base_arg);
77 *c = __math_base_cos_64(base_arg);
78 }
79}
80
81/** @}
82 */
Note: See TracBrowser for help on using the repository browser.