1 /*- 2 * Copyright (c) 2001-2011 The FreeBSD Project. 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24 * SUCH DAMAGE. 25 * 26 * $FreeBSD$ 27 */ 28 29 #ifndef _COMPLEX_H 30 #define _COMPLEX_H 31 32 #include <sys/cdefs.h> 33 34 #ifdef __GNUC__ 35 #define _Complex_I ((float _Complex)1.0i) 36 #endif 37 38 #ifdef __generic 39 _Static_assert(__generic(_Complex_I, float _Complex, 1, 0), 40 "_Complex_I must be of type float _Complex"); 41 #endif 42 43 #define complex _Complex 44 #define I _Complex_I 45 46 #if __STDC_VERSION__ >= 201112L 47 #ifdef __clang__ 48 #define CMPLX(x, y) ((double complex){ x, y }) 49 #define CMPLXF(x, y) ((float complex){ x, y }) 50 #define CMPLXL(x, y) ((long double complex){ x, y }) 51 #else 52 #define CMPLX(x, y) __builtin_complex((double)(x), (double)(y)) 53 #define CMPLXF(x, y) __builtin_complex((float)(x), (float)(y)) 54 #define CMPLXL(x, y) __builtin_complex((long double)(x), (long double)(y)) 55 #endif 56 #endif 57 58 __BEGIN_DECLS 59 60 /* 7.3.5 Trigonometric functions */ 61 /* 7.3.5.1 The cacos functions */ 62 double complex cacos(double complex __z) __INTRODUCED_IN(23); 63 float complex cacosf(float complex __z) __INTRODUCED_IN(23); 64 long double complex cacosl(long double complex __z) __RENAME_LDBL(cacos, 23, 26); 65 /* 7.3.5.2 The casin functions */ 66 double complex casin(double complex __z) __INTRODUCED_IN(23); 67 float complex casinf(float complex __z) __INTRODUCED_IN(23); 68 long double complex casinl(long double complex __z) __RENAME_LDBL(casin, 23, 26); 69 /* 7.3.5.1 The catan functions */ 70 double complex catan(double complex __z) __INTRODUCED_IN(23); 71 float complex catanf(float complex __z) __INTRODUCED_IN(23); 72 long double complex catanl(long double complex __z) __RENAME_LDBL(catan, 23, 26); 73 /* 7.3.5.1 The ccos functions */ 74 double complex ccos(double complex __z) __INTRODUCED_IN(23); 75 float complex ccosf(float complex __z) __INTRODUCED_IN(23); 76 long double complex ccosl(long double complex __z) __RENAME_LDBL(ccos, 23, 26); 77 /* 7.3.5.1 The csin functions */ 78 double complex csin(double complex __z) __INTRODUCED_IN(23); 79 float complex csinf(float complex __z) __INTRODUCED_IN(23); 80 long double complex csinl(long double complex __z) __RENAME_LDBL(csin, 23, 26); 81 /* 7.3.5.1 The ctan functions */ 82 double complex ctan(double complex __z) __INTRODUCED_IN(23); 83 float complex ctanf(float complex __z) __INTRODUCED_IN(23); 84 long double complex ctanl(long double complex __z) __RENAME_LDBL(ctan, 23, 26); 85 86 /* 7.3.6 Hyperbolic functions */ 87 /* 7.3.6.1 The cacosh functions */ 88 double complex cacosh(double complex __z) __INTRODUCED_IN(23); 89 float complex cacoshf(float complex __z) __INTRODUCED_IN(23); 90 long double complex cacoshl(long double complex __z) __RENAME_LDBL(cacosh, 23, 26); 91 /* 7.3.6.2 The casinh functions */ 92 double complex casinh(double complex __z) __INTRODUCED_IN(23); 93 float complex casinhf(float complex __z) __INTRODUCED_IN(23); 94 long double complex casinhl(long double complex __z) __RENAME_LDBL(casinh, 23, 26); 95 /* 7.3.6.3 The catanh functions */ 96 double complex catanh(double complex __z) __INTRODUCED_IN(23); 97 float complex catanhf(float complex __z) __INTRODUCED_IN(23); 98 long double complex catanhl(long double complex __z) __RENAME_LDBL(catanh, 23, 26); 99 /* 7.3.6.4 The ccosh functions */ 100 double complex ccosh(double complex __z) __INTRODUCED_IN(23); 101 float complex ccoshf(float complex __z) __INTRODUCED_IN(23); 102 long double complex ccoshl(long double complex __z) __RENAME_LDBL(ccosh, 23, 26); 103 /* 7.3.6.5 The csinh functions */ 104 double complex csinh(double complex __z) __INTRODUCED_IN(23); 105 float complex csinhf(float complex __z) __INTRODUCED_IN(23); 106 long double complex csinhl(long double complex __z) __RENAME_LDBL(csinh, 23, 26); 107 /* 7.3.6.6 The ctanh functions */ 108 double complex ctanh(double complex __z) __INTRODUCED_IN(23); 109 float complex ctanhf(float complex __z) __INTRODUCED_IN(23); 110 long double complex ctanhl(long double complex __z) __RENAME_LDBL(ctanh, 23, 26); 111 112 /* 7.3.7 Exponential and logarithmic functions */ 113 /* 7.3.7.1 The cexp functions */ 114 double complex cexp(double complex __z) __INTRODUCED_IN(23); 115 float complex cexpf(float complex __z) __INTRODUCED_IN(23); 116 long double complex cexpl(long double complex __z) __RENAME_LDBL(cexp, 23, 26); 117 /* 7.3.7.2 The clog functions */ 118 double complex clog(double complex __z) __INTRODUCED_IN(26); 119 float complex clogf(float complex __z) __INTRODUCED_IN(26); 120 long double complex clogl(long double complex __z) __RENAME_LDBL(clog, 26, 26); 121 122 /* 7.3.8 Power and absolute-value functions */ 123 /* 7.3.8.1 The cabs functions */ 124 double cabs(double complex __z) __INTRODUCED_IN(23); 125 float cabsf(float complex __z) __INTRODUCED_IN(23); 126 long double cabsl(long double complex __z) __INTRODUCED_IN_32(21) __INTRODUCED_IN_64(23) /*__RENAME_LDBL(cabs)*/; 127 /* 7.3.8.2 The cpow functions */ 128 double complex cpow(double complex __x, double complex __z) __INTRODUCED_IN(26); 129 float complex cpowf(float complex __x, float complex __z) __INTRODUCED_IN(26); 130 long double complex cpowl(long double complex __x, long double complex __z) __RENAME_LDBL(cpow, 26, 26); 131 /* 7.3.8.3 The csqrt functions */ 132 double complex csqrt(double complex __z) __INTRODUCED_IN(23); 133 float complex csqrtf(float complex __z) __INTRODUCED_IN(23); 134 long double complex csqrtl(long double complex __z) __INTRODUCED_IN_32(21) __INTRODUCED_IN_64(23) /*__RENAME_LDBL(csqrt)*/; 135 136 /* 7.3.9 Manipulation functions */ 137 /* 7.3.9.1 The carg functions */ 138 double carg(double complex __z) __INTRODUCED_IN(23); 139 float cargf(float complex __z) __INTRODUCED_IN(23); 140 long double cargl(long double complex __z) __RENAME_LDBL(carg, 23, 23); 141 /* 7.3.9.2 The cimag functions */ 142 double cimag(double complex __z) __INTRODUCED_IN(23); 143 float cimagf(float complex __z) __INTRODUCED_IN(23); 144 long double cimagl(long double complex __z) __RENAME_LDBL(cimag, 23, 23); 145 /* 7.3.9.3 The conj functions */ 146 double complex conj(double complex __z) __INTRODUCED_IN(23); 147 float complex conjf(float complex __z) __INTRODUCED_IN(23); 148 long double complex conjl(long double complex __z) __RENAME_LDBL(conj, 23, 23); 149 /* 7.3.9.4 The cproj functions */ 150 double complex cproj(double complex __z) __INTRODUCED_IN(23); 151 float complex cprojf(float complex __z) __INTRODUCED_IN(23); 152 long double complex cprojl(long double complex __z) __INTRODUCED_IN_32(21) __INTRODUCED_IN_64(23) /*__RENAME_LDBL(cproj)*/; 153 /* 7.3.9.5 The creal functions */ 154 double creal(double complex __z) __INTRODUCED_IN(23); 155 float crealf(float complex __z) __INTRODUCED_IN(23); 156 long double creall(long double complex __z) __RENAME_LDBL(creal, 23, 23); 157 158 __END_DECLS 159 160 #endif 161