Annotation of OpenXM_contrib2/windows/mpir/x64/mpc.h, Revision 1.1
1.1 ! ohara 1: /* mpc.h -- Include file for mpc.
! 2:
! 3: Copyright (C) 2002, 2003, 2004, 2005, 2007, 2008, 2009, 2010, 2011, 2012, 2014, 2015 INRIA
! 4:
! 5: This file is part of GNU MPC.
! 6:
! 7: GNU MPC is free software; you can redistribute it and/or modify it under
! 8: the terms of the GNU Lesser General Public License as published by the
! 9: Free Software Foundation; either version 3 of the License, or (at your
! 10: option) any later version.
! 11:
! 12: GNU MPC is distributed in the hope that it will be useful, but WITHOUT ANY
! 13: WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
! 14: FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
! 15: more details.
! 16:
! 17: You should have received a copy of the GNU Lesser General Public License
! 18: along with this program. If not, see http://www.gnu.org/licenses/ .
! 19: */
! 20:
! 21: #ifndef __MPC_H
! 22: #define __MPC_H
! 23:
! 24: #include "gmp.h"
! 25: #include "mpfr.h"
! 26:
! 27: /* Backwards compatibility with mpfr<3.0.0 */
! 28: #ifndef mpfr_exp_t
! 29: #define mpfr_exp_t mp_exp_t
! 30: #endif
! 31:
! 32: /* Define MPC version number */
! 33: #define MPC_VERSION_MAJOR 1
! 34: #define MPC_VERSION_MINOR 0
! 35: #define MPC_VERSION_PATCHLEVEL 3
! 36: #define MPC_VERSION_STRING "1.0.3"
! 37:
! 38: /* Macros dealing with MPC VERSION */
! 39: #define MPC_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
! 40: #define MPC_VERSION \
! 41: MPC_VERSION_NUM(MPC_VERSION_MAJOR,MPC_VERSION_MINOR,MPC_VERSION_PATCHLEVEL)
! 42:
! 43: /* Check if stdint.h/inttypes.h is included */
! 44: #if defined (INTMAX_C) && defined (UINTMAX_C)
! 45: #define _MPC_H_HAVE_INTMAX_T 1
! 46: #endif
! 47:
! 48: /* Return values */
! 49:
! 50: /* Transform negative to 2, positive to 1, leave 0 unchanged */
! 51: #define MPC_INEX_POS(inex) (((inex) < 0) ? 2 : ((inex) == 0) ? 0 : 1)
! 52: /* Transform 2 to negative, 1 to positive, leave 0 unchanged */
! 53: #define MPC_INEX_NEG(inex) (((inex) == 2) ? -1 : ((inex) == 0) ? 0 : 1)
! 54:
! 55: /* The global inexact flag is made of (real flag) + 4 * (imaginary flag), where
! 56: each of the real and imaginary inexact flag are:
! 57: 0 when the result is exact (no rounding error)
! 58: 1 when the result is larger than the exact value
! 59: 2 when the result is smaller than the exact value */
! 60: #define MPC_INEX(inex_re, inex_im) \
! 61: (MPC_INEX_POS(inex_re) | (MPC_INEX_POS(inex_im) << 2))
! 62: #define MPC_INEX_RE(inex) MPC_INEX_NEG((inex) & 3)
! 63: #define MPC_INEX_IM(inex) MPC_INEX_NEG((inex) >> 2)
! 64:
! 65: /* For functions computing two results, the return value is
! 66: inexact1+16*inexact2, which is 0 iif both results are exact. */
! 67: #define MPC_INEX12(inex1, inex2) (inex1 | (inex2 << 4))
! 68: #define MPC_INEX1(inex) (inex & 15)
! 69: #define MPC_INEX2(inex) (inex >> 4)
! 70:
! 71: /* Definition of rounding modes */
! 72:
! 73: /* a complex rounding mode is just a pair of two real rounding modes
! 74: we reserve four bits for a real rounding mode. */
! 75: typedef int mpc_rnd_t;
! 76:
! 77: #define MPC_RND(r1,r2) (((int)(r1)) + ((int)(r2) << 4))
! 78: #define MPC_RND_RE(x) ((mpfr_rnd_t)((x) & 0x0F))
! 79: #define MPC_RND_IM(x) ((mpfr_rnd_t)((x) >> 4))
! 80:
! 81: #define MPC_RNDNN MPC_RND (GMP_RNDN,GMP_RNDN)
! 82: #define MPC_RNDNZ MPC_RND (GMP_RNDN,GMP_RNDZ)
! 83: #define MPC_RNDNU MPC_RND (GMP_RNDN,GMP_RNDU)
! 84: #define MPC_RNDND MPC_RND (GMP_RNDN,GMP_RNDD)
! 85:
! 86: #define MPC_RNDZN MPC_RND (GMP_RNDZ,GMP_RNDN)
! 87: #define MPC_RNDZZ MPC_RND (GMP_RNDZ,GMP_RNDZ)
! 88: #define MPC_RNDZU MPC_RND (GMP_RNDZ,GMP_RNDU)
! 89: #define MPC_RNDZD MPC_RND (GMP_RNDZ,GMP_RNDD)
! 90:
! 91: #define MPC_RNDUN MPC_RND (GMP_RNDU,GMP_RNDN)
! 92: #define MPC_RNDUZ MPC_RND (GMP_RNDU,GMP_RNDZ)
! 93: #define MPC_RNDUU MPC_RND (GMP_RNDU,GMP_RNDU)
! 94: #define MPC_RNDUD MPC_RND (GMP_RNDU,GMP_RNDD)
! 95:
! 96: #define MPC_RNDDN MPC_RND (GMP_RNDD,GMP_RNDN)
! 97: #define MPC_RNDDZ MPC_RND (GMP_RNDD,GMP_RNDZ)
! 98: #define MPC_RNDDU MPC_RND (GMP_RNDD,GMP_RNDU)
! 99: #define MPC_RNDDD MPC_RND (GMP_RNDD,GMP_RNDD)
! 100:
! 101:
! 102: /* Definitions of types and their semantics */
! 103:
! 104: typedef struct {
! 105: mpfr_t re;
! 106: mpfr_t im;
! 107: }
! 108: __mpc_struct;
! 109:
! 110: typedef __mpc_struct mpc_t[1];
! 111: typedef __mpc_struct *mpc_ptr;
! 112: typedef const __mpc_struct *mpc_srcptr;
! 113:
! 114: /* Support for WINDOWS DLL, see
! 115: http://lists.gforge.inria.fr/pipermail/mpc-discuss/2011-November/000990.html;
! 116: when building the DLL, export symbols, otherwise behave as GMP */
! 117: #if defined (__MPC_LIBRARY_BUILD) && __GMP_LIBGMP_DLL
! 118: #define __MPC_DECLSPEC __GMP_DECLSPEC_EXPORT
! 119: #else
! 120: #define __MPC_DECLSPEC __GMP_DECLSPEC
! 121: #endif
! 122:
! 123: #if defined (__cplusplus)
! 124: extern "C" {
! 125: #endif
! 126:
! 127: __MPC_DECLSPEC int mpc_add (mpc_ptr, mpc_srcptr, mpc_srcptr, mpc_rnd_t);
! 128: __MPC_DECLSPEC int mpc_add_fr (mpc_ptr, mpc_srcptr, mpfr_srcptr, mpc_rnd_t);
! 129: __MPC_DECLSPEC int mpc_add_si (mpc_ptr, mpc_srcptr, long int, mpc_rnd_t);
! 130: __MPC_DECLSPEC int mpc_add_ui (mpc_ptr, mpc_srcptr, unsigned long int, mpc_rnd_t);
! 131: __MPC_DECLSPEC int mpc_sub (mpc_ptr, mpc_srcptr, mpc_srcptr, mpc_rnd_t);
! 132: __MPC_DECLSPEC int mpc_sub_fr (mpc_ptr, mpc_srcptr, mpfr_srcptr, mpc_rnd_t);
! 133: __MPC_DECLSPEC int mpc_fr_sub (mpc_ptr, mpfr_srcptr, mpc_srcptr, mpc_rnd_t);
! 134: __MPC_DECLSPEC int mpc_sub_ui (mpc_ptr, mpc_srcptr, unsigned long int, mpc_rnd_t);
! 135: __MPC_DECLSPEC int mpc_ui_ui_sub (mpc_ptr, unsigned long int, unsigned long int, mpc_srcptr, mpc_rnd_t);
! 136: __MPC_DECLSPEC int mpc_mul (mpc_ptr, mpc_srcptr, mpc_srcptr, mpc_rnd_t);
! 137: __MPC_DECLSPEC int mpc_mul_fr (mpc_ptr, mpc_srcptr, mpfr_srcptr, mpc_rnd_t);
! 138: __MPC_DECLSPEC int mpc_mul_ui (mpc_ptr, mpc_srcptr, unsigned long int, mpc_rnd_t);
! 139: __MPC_DECLSPEC int mpc_mul_si (mpc_ptr, mpc_srcptr, long int, mpc_rnd_t);
! 140: __MPC_DECLSPEC int mpc_mul_i (mpc_ptr, mpc_srcptr, int, mpc_rnd_t);
! 141: __MPC_DECLSPEC int mpc_sqr (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 142: __MPC_DECLSPEC int mpc_div (mpc_ptr, mpc_srcptr, mpc_srcptr, mpc_rnd_t);
! 143: __MPC_DECLSPEC int mpc_pow (mpc_ptr, mpc_srcptr, mpc_srcptr, mpc_rnd_t);
! 144: __MPC_DECLSPEC int mpc_pow_fr (mpc_ptr, mpc_srcptr, mpfr_srcptr, mpc_rnd_t);
! 145: __MPC_DECLSPEC int mpc_pow_ld (mpc_ptr, mpc_srcptr, long double, mpc_rnd_t);
! 146: __MPC_DECLSPEC int mpc_pow_d (mpc_ptr, mpc_srcptr, double, mpc_rnd_t);
! 147: __MPC_DECLSPEC int mpc_pow_si (mpc_ptr, mpc_srcptr, long, mpc_rnd_t);
! 148: __MPC_DECLSPEC int mpc_pow_ui (mpc_ptr, mpc_srcptr, unsigned long, mpc_rnd_t);
! 149: __MPC_DECLSPEC int mpc_pow_z (mpc_ptr, mpc_srcptr, mpz_srcptr, mpc_rnd_t);
! 150: __MPC_DECLSPEC int mpc_div_fr (mpc_ptr, mpc_srcptr, mpfr_srcptr, mpc_rnd_t);
! 151: __MPC_DECLSPEC int mpc_fr_div (mpc_ptr, mpfr_srcptr, mpc_srcptr, mpc_rnd_t);
! 152: __MPC_DECLSPEC int mpc_div_ui (mpc_ptr, mpc_srcptr, unsigned long int, mpc_rnd_t);
! 153: __MPC_DECLSPEC int mpc_ui_div (mpc_ptr, unsigned long int, mpc_srcptr, mpc_rnd_t);
! 154: __MPC_DECLSPEC int mpc_div_2ui (mpc_ptr, mpc_srcptr, unsigned long int, mpc_rnd_t);
! 155: __MPC_DECLSPEC int mpc_mul_2ui (mpc_ptr, mpc_srcptr, unsigned long int, mpc_rnd_t);
! 156: __MPC_DECLSPEC int mpc_div_2si (mpc_ptr, mpc_srcptr, long int, mpc_rnd_t);
! 157: __MPC_DECLSPEC int mpc_mul_2si (mpc_ptr, mpc_srcptr, long int, mpc_rnd_t);
! 158: __MPC_DECLSPEC int mpc_conj (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 159: __MPC_DECLSPEC int mpc_neg (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 160: __MPC_DECLSPEC int mpc_norm (mpfr_ptr, mpc_srcptr, mpfr_rnd_t);
! 161: __MPC_DECLSPEC int mpc_abs (mpfr_ptr, mpc_srcptr, mpfr_rnd_t);
! 162: __MPC_DECLSPEC int mpc_sqrt (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 163: __MPC_DECLSPEC int mpc_set (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 164: __MPC_DECLSPEC int mpc_set_d (mpc_ptr, double, mpc_rnd_t);
! 165: __MPC_DECLSPEC int mpc_set_d_d (mpc_ptr, double, double, mpc_rnd_t);
! 166: __MPC_DECLSPEC int mpc_set_ld (mpc_ptr, long double, mpc_rnd_t);
! 167: __MPC_DECLSPEC int mpc_set_ld_ld (mpc_ptr, long double, long double, mpc_rnd_t);
! 168: __MPC_DECLSPEC int mpc_set_f (mpc_ptr, mpf_srcptr, mpc_rnd_t);
! 169: __MPC_DECLSPEC int mpc_set_f_f (mpc_ptr, mpf_srcptr, mpf_srcptr, mpc_rnd_t);
! 170: __MPC_DECLSPEC int mpc_set_fr (mpc_ptr, mpfr_srcptr, mpc_rnd_t);
! 171: __MPC_DECLSPEC int mpc_set_fr_fr (mpc_ptr, mpfr_srcptr, mpfr_srcptr, mpc_rnd_t);
! 172: __MPC_DECLSPEC int mpc_set_q (mpc_ptr, mpq_srcptr, mpc_rnd_t);
! 173: __MPC_DECLSPEC int mpc_set_q_q (mpc_ptr, mpq_srcptr, mpq_srcptr, mpc_rnd_t);
! 174: __MPC_DECLSPEC int mpc_set_si (mpc_ptr, long int, mpc_rnd_t);
! 175: __MPC_DECLSPEC int mpc_set_si_si (mpc_ptr, long int, long int, mpc_rnd_t);
! 176: __MPC_DECLSPEC int mpc_set_ui (mpc_ptr, unsigned long int, mpc_rnd_t);
! 177: __MPC_DECLSPEC int mpc_set_ui_ui (mpc_ptr, unsigned long int, unsigned long int, mpc_rnd_t);
! 178: __MPC_DECLSPEC int mpc_set_z (mpc_ptr, mpz_srcptr, mpc_rnd_t);
! 179: __MPC_DECLSPEC int mpc_set_z_z (mpc_ptr, mpz_srcptr, mpz_srcptr, mpc_rnd_t);
! 180: __MPC_DECLSPEC void mpc_swap (mpc_ptr, mpc_ptr);
! 181: __MPC_DECLSPEC int mpc_fma (mpc_ptr, mpc_srcptr, mpc_srcptr, mpc_srcptr, mpc_rnd_t);
! 182:
! 183: __MPC_DECLSPEC void mpc_set_nan (mpc_ptr);
! 184:
! 185: __MPC_DECLSPEC int mpc_real (mpfr_ptr, mpc_srcptr, mpfr_rnd_t);
! 186: __MPC_DECLSPEC int mpc_imag (mpfr_ptr, mpc_srcptr, mpfr_rnd_t);
! 187: __MPC_DECLSPEC int mpc_arg (mpfr_ptr, mpc_srcptr, mpfr_rnd_t);
! 188: __MPC_DECLSPEC int mpc_proj (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 189: __MPC_DECLSPEC int mpc_cmp (mpc_srcptr, mpc_srcptr);
! 190: __MPC_DECLSPEC int mpc_cmp_si_si (mpc_srcptr, long int, long int);
! 191: __MPC_DECLSPEC int mpc_exp (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 192: __MPC_DECLSPEC int mpc_log (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 193: __MPC_DECLSPEC int mpc_log10 (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 194: __MPC_DECLSPEC int mpc_sin (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 195: __MPC_DECLSPEC int mpc_cos (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 196: __MPC_DECLSPEC int mpc_sin_cos (mpc_ptr, mpc_ptr, mpc_srcptr, mpc_rnd_t, mpc_rnd_t);
! 197: __MPC_DECLSPEC int mpc_tan (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 198: __MPC_DECLSPEC int mpc_sinh (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 199: __MPC_DECLSPEC int mpc_cosh (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 200: __MPC_DECLSPEC int mpc_tanh (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 201: __MPC_DECLSPEC int mpc_asin (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 202: __MPC_DECLSPEC int mpc_acos (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 203: __MPC_DECLSPEC int mpc_atan (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 204: __MPC_DECLSPEC int mpc_asinh (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 205: __MPC_DECLSPEC int mpc_acosh (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 206: __MPC_DECLSPEC int mpc_atanh (mpc_ptr, mpc_srcptr, mpc_rnd_t);
! 207: __MPC_DECLSPEC void mpc_clear (mpc_ptr);
! 208: __MPC_DECLSPEC int mpc_urandom (mpc_ptr, gmp_randstate_t);
! 209: __MPC_DECLSPEC void mpc_init2 (mpc_ptr, mpfr_prec_t);
! 210: __MPC_DECLSPEC void mpc_init3 (mpc_ptr, mpfr_prec_t, mpfr_prec_t);
! 211: __MPC_DECLSPEC mpfr_prec_t mpc_get_prec (mpc_srcptr x);
! 212: __MPC_DECLSPEC void mpc_get_prec2 (mpfr_prec_t *pr, mpfr_prec_t *pi, mpc_srcptr x);
! 213: __MPC_DECLSPEC void mpc_set_prec (mpc_ptr, mpfr_prec_t);
! 214: __MPC_DECLSPEC const char * mpc_get_version (void);
! 215:
! 216: __MPC_DECLSPEC int mpc_strtoc (mpc_ptr, const char *, char **, int, mpc_rnd_t);
! 217: __MPC_DECLSPEC int mpc_set_str (mpc_ptr, const char *, int, mpc_rnd_t);
! 218: __MPC_DECLSPEC char * mpc_get_str (int, size_t, mpc_srcptr, mpc_rnd_t);
! 219: __MPC_DECLSPEC void mpc_free_str (char *);
! 220:
! 221: /* declare certain functions only if appropriate headers have been included */
! 222: #ifdef _MPC_H_HAVE_INTMAX_T
! 223: __MPC_DECLSPEC int mpc_set_sj (mpc_ptr, intmax_t, mpc_rnd_t);
! 224: __MPC_DECLSPEC int mpc_set_uj (mpc_ptr, uintmax_t, mpc_rnd_t);
! 225: __MPC_DECLSPEC int mpc_set_sj_sj (mpc_ptr, intmax_t, intmax_t, mpc_rnd_t);
! 226: __MPC_DECLSPEC int mpc_set_uj_uj (mpc_ptr, uintmax_t, uintmax_t, mpc_rnd_t);
! 227: #endif
! 228:
! 229: #ifdef _Complex_I
! 230: __MPC_DECLSPEC int mpc_set_dc (mpc_ptr, double _Complex, mpc_rnd_t);
! 231: __MPC_DECLSPEC int mpc_set_ldc (mpc_ptr, long double _Complex, mpc_rnd_t);
! 232: __MPC_DECLSPEC double _Complex mpc_get_dc (mpc_srcptr, mpc_rnd_t);
! 233: __MPC_DECLSPEC long double _Complex mpc_get_ldc (mpc_srcptr, mpc_rnd_t);
! 234: #endif
! 235:
! 236: #ifdef _GMP_H_HAVE_FILE
! 237: __MPC_DECLSPEC int mpc_inp_str (mpc_ptr, FILE *, size_t *, int, mpc_rnd_t);
! 238: __MPC_DECLSPEC size_t mpc_out_str (FILE *, int, size_t, mpc_srcptr, mpc_rnd_t);
! 239: #endif
! 240:
! 241: #if defined (__cplusplus)
! 242: }
! 243: #endif
! 244:
! 245: #define mpc_realref(x) ((x)->re)
! 246: #define mpc_imagref(x) ((x)->im)
! 247:
! 248: #define mpc_cmp_si(x, y) \
! 249: ( mpc_cmp_si_si ((x), (y), 0l) )
! 250: #define mpc_ui_sub(x, y, z, r) mpc_ui_ui_sub (x, y, 0ul, z, r)
! 251:
! 252: /*
! 253: Define a fake mpfr_set_fr so that, for instance, mpc_set_fr_z would
! 254: be defined as follows:
! 255: mpc_set_fr_z (mpc_t rop, mpfr_t x, mpz_t y, mpc_rnd_t rnd)
! 256: MPC_SET_X_Y (fr, z, rop, x, y, rnd)
! 257: */
! 258: #ifndef mpfr_set_fr
! 259: #define mpfr_set_fr mpfr_set
! 260: #endif
! 261: #define MPC_SET_X_Y(real_t, imag_t, z, real_value, imag_value, rnd) \
! 262: { \
! 263: int _inex_re, _inex_im; \
! 264: _inex_re = (mpfr_set_ ## real_t) (mpc_realref (z), (real_value), MPC_RND_RE (rnd)); \
! 265: _inex_im = (mpfr_set_ ## imag_t) (mpc_imagref (z), (imag_value), MPC_RND_IM (rnd)); \
! 266: return MPC_INEX (_inex_re, _inex_im); \
! 267: }
! 268:
! 269: #endif /* ifndef __MPC_H */
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>