Annotation of OpenXM_contrib/gmp/gmp.h, Revision 1.1
1.1 ! maekawa 1: /* gmp.h -- Definitions for GNU multiple precision functions.
! 2:
! 3: Copyright (C) 1991, 1993, 1994, 1995, 1996 Free Software Foundation, Inc.
! 4:
! 5: This file is part of the GNU MP Library.
! 6:
! 7: The GNU MP Library is free software; you can redistribute it and/or modify
! 8: it under the terms of the GNU Library General Public License as published by
! 9: the Free Software Foundation; either version 2 of the License, or (at your
! 10: option) any later version.
! 11:
! 12: The GNU MP Library is distributed in the hope that it will be useful, but
! 13: WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
! 14: or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
! 15: License for more details.
! 16:
! 17: You should have received a copy of the GNU Library General Public License
! 18: along with the GNU MP Library; see the file COPYING.LIB. If not, write to
! 19: the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
! 20: MA 02111-1307, USA. */
! 21:
! 22: #ifndef __GMP_H__
! 23:
! 24: #ifndef __GNU_MP__
! 25: #define __GNU_MP__ 2
! 26: #define __need_size_t
! 27: #include <stddef.h>
! 28: #undef __need_size_t
! 29:
! 30: #if defined (__STDC__) || defined (__cplusplus)
! 31: #define __gmp_const const
! 32: #else
! 33: #define __gmp_const
! 34: #endif
! 35:
! 36: #if defined (__GNUC__)
! 37: #define __gmp_inline __inline__
! 38: #else
! 39: #define __gmp_inline
! 40: #endif
! 41:
! 42: #ifndef _EXTERN_INLINE
! 43: #ifdef __GNUC__
! 44: #define _EXTERN_INLINE extern __inline__
! 45: #else
! 46: #define _EXTERN_INLINE static
! 47: #endif
! 48: #endif
! 49:
! 50: #ifdef _SHORT_LIMB
! 51: typedef unsigned int mp_limb_t;
! 52: typedef int mp_limb_signed_t;
! 53: #else
! 54: #ifdef _LONG_LONG_LIMB
! 55: typedef unsigned long long int mp_limb_t;
! 56: typedef long long int mp_limb_signed_t;
! 57: #else
! 58: typedef unsigned long int mp_limb_t;
! 59: typedef long int mp_limb_signed_t;
! 60: #endif
! 61: #endif
! 62:
! 63: typedef mp_limb_t * mp_ptr;
! 64: typedef __gmp_const mp_limb_t * mp_srcptr;
! 65: typedef long int mp_size_t;
! 66: typedef long int mp_exp_t;
! 67:
! 68: #ifndef __MP_SMALL__
! 69: typedef struct
! 70: {
! 71: int _mp_alloc; /* Number of *limbs* allocated and pointed
! 72: to by the D field. */
! 73: int _mp_size; /* abs(SIZE) is the number of limbs
! 74: the last field points to. If SIZE
! 75: is negative this is a negative
! 76: number. */
! 77: mp_limb_t *_mp_d; /* Pointer to the limbs. */
! 78: } __mpz_struct;
! 79: #else
! 80: typedef struct
! 81: {
! 82: short int _mp_alloc; /* Number of *limbs* allocated and pointed
! 83: to by the D field. */
! 84: short int _mp_size; /* abs(SIZE) is the number of limbs
! 85: the last field points to. If SIZE
! 86: is negative this is a negative
! 87: number. */
! 88: mp_limb_t *_mp_d; /* Pointer to the limbs. */
! 89: } __mpz_struct;
! 90: #endif
! 91: #endif /* __GNU_MP__ */
! 92:
! 93: /* User-visible types. */
! 94: typedef __mpz_struct MP_INT;
! 95: typedef __mpz_struct mpz_t[1];
! 96:
! 97: /* Structure for rational numbers. Zero is represented as 0/any, i.e.
! 98: the denominator is ignored. Negative numbers have the sign in
! 99: the numerator. */
! 100: typedef struct
! 101: {
! 102: __mpz_struct _mp_num;
! 103: __mpz_struct _mp_den;
! 104: #if 0
! 105: int _mp_num_alloc; /* Number of limbs allocated
! 106: for the numerator. */
! 107: int _mp_num_size; /* The absolute value of this field is the
! 108: length of the numerator; the sign is the
! 109: sign of the entire rational number. */
! 110: mp_ptr _mp_num; /* Pointer to the numerator limbs. */
! 111: int _mp_den_alloc; /* Number of limbs allocated
! 112: for the denominator. */
! 113: int _mp_den_size; /* Length of the denominator. (This field
! 114: should always be positive.) */
! 115: mp_ptr _mp_den; /* Pointer to the denominator limbs. */
! 116: #endif
! 117: } __mpq_struct;
! 118:
! 119: typedef __mpq_struct MP_RAT;
! 120: typedef __mpq_struct mpq_t[1];
! 121:
! 122: typedef struct
! 123: {
! 124: int _mp_prec; /* Max precision, in number of `mp_limb_t's.
! 125: Set by mpf_init and modified by
! 126: mpf_set_prec. The area pointed to
! 127: by the `d' field contains `prec' + 1
! 128: limbs. */
! 129: int _mp_size; /* abs(SIZE) is the number of limbs
! 130: the last field points to. If SIZE
! 131: is negative this is a negative
! 132: number. */
! 133: mp_exp_t _mp_exp; /* Exponent, in the base of `mp_limb_t'. */
! 134: mp_limb_t *_mp_d; /* Pointer to the limbs. */
! 135: } __mpf_struct;
! 136:
! 137: /* typedef __mpf_struct MP_FLOAT; */
! 138: typedef __mpf_struct mpf_t[1];
! 139:
! 140: /* Types for function declarations in gmp files. */
! 141: /* ??? Should not pollute user name space with these ??? */
! 142: typedef __gmp_const __mpz_struct *mpz_srcptr;
! 143: typedef __mpz_struct *mpz_ptr;
! 144: typedef __gmp_const __mpf_struct *mpf_srcptr;
! 145: typedef __mpf_struct *mpf_ptr;
! 146: typedef __gmp_const __mpq_struct *mpq_srcptr;
! 147: typedef __mpq_struct *mpq_ptr;
! 148:
! 149: #ifndef _PROTO
! 150: #if defined (__STDC__) || defined (__cplusplus)
! 151: #define _PROTO(x) x
! 152: #else
! 153: #define _PROTO(x) ()
! 154: #endif
! 155: #endif
! 156:
! 157: #ifndef __MPN
! 158: #if defined (__STDC__) || defined (__cplusplus)
! 159: #define __MPN(x) __mpn_##x
! 160: #else
! 161: #define __MPN(x) __mpn_/**/x
! 162: #endif
! 163: #endif
! 164:
! 165: #if defined (FILE) || defined (H_STDIO) || defined (_H_STDIO) \
! 166: || defined (_STDIO_H) || defined (_STDIO_H_) || defined (__STDIO_H__) \
! 167: || defined (_STDIO_INCLUDED)
! 168: #define _GMP_H_HAVE_FILE 1
! 169: #endif
! 170:
! 171: void mp_set_memory_functions _PROTO ((void *(*) (size_t),
! 172: void *(*) (void *, size_t, size_t),
! 173: void (*) (void *, size_t)));
! 174: extern __gmp_const int mp_bits_per_limb;
! 175:
! 176: /**************** Integer (i.e. Z) routines. ****************/
! 177:
! 178: #if defined (__cplusplus)
! 179: extern "C" {
! 180: #endif
! 181: void *_mpz_realloc _PROTO ((mpz_ptr, mp_size_t));
! 182:
! 183: void mpz_abs _PROTO ((mpz_ptr, mpz_srcptr));
! 184: void mpz_add _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 185: void mpz_add_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 186: void mpz_and _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 187: void mpz_array_init _PROTO ((mpz_ptr, mp_size_t, mp_size_t));
! 188: void mpz_cdiv_q _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 189: unsigned long int mpz_cdiv_q_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 190: void mpz_cdiv_qr _PROTO ((mpz_ptr, mpz_ptr, mpz_srcptr, mpz_srcptr));
! 191: unsigned long int mpz_cdiv_qr_ui _PROTO ((mpz_ptr, mpz_ptr, mpz_srcptr, unsigned long int));
! 192: void mpz_cdiv_r _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 193: unsigned long int mpz_cdiv_r_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 194: unsigned long int mpz_cdiv_ui _PROTO ((mpz_srcptr, unsigned long int));
! 195: void mpz_clear _PROTO ((mpz_ptr));
! 196: void mpz_clrbit _PROTO ((mpz_ptr, unsigned long int));
! 197: int mpz_cmp _PROTO ((mpz_srcptr, mpz_srcptr));
! 198: int mpz_cmp_si _PROTO ((mpz_srcptr, signed long int));
! 199: int mpz_cmp_ui _PROTO ((mpz_srcptr, unsigned long int));
! 200: void mpz_com _PROTO ((mpz_ptr, mpz_srcptr));
! 201: void mpz_divexact _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 202: void mpz_fac_ui _PROTO ((mpz_ptr, unsigned long int));
! 203: void mpz_fdiv_q _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 204: void mpz_fdiv_q_2exp _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 205: unsigned long int mpz_fdiv_q_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 206: void mpz_fdiv_qr _PROTO ((mpz_ptr, mpz_ptr, mpz_srcptr, mpz_srcptr));
! 207: unsigned long int mpz_fdiv_qr_ui _PROTO ((mpz_ptr, mpz_ptr, mpz_srcptr, unsigned long int));
! 208: void mpz_fdiv_r _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 209: void mpz_fdiv_r_2exp _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 210: unsigned long int mpz_fdiv_r_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 211: unsigned long int mpz_fdiv_ui _PROTO ((mpz_srcptr, unsigned long int));
! 212: void mpz_gcd _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 213: unsigned long int mpz_gcd_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 214: void mpz_gcdext _PROTO ((mpz_ptr, mpz_ptr, mpz_ptr, mpz_srcptr, mpz_srcptr));
! 215: double mpz_get_d _PROTO ((mpz_srcptr));
! 216: /* signed */ long int mpz_get_si _PROTO ((mpz_srcptr));
! 217: char *mpz_get_str _PROTO ((char *, int, mpz_srcptr));
! 218: unsigned long int mpz_get_ui _PROTO ((mpz_srcptr));
! 219: mp_limb_t mpz_getlimbn _PROTO ((mpz_srcptr, mp_size_t));
! 220: unsigned long int mpz_hamdist _PROTO ((mpz_srcptr, mpz_srcptr));
! 221: void mpz_init _PROTO ((mpz_ptr));
! 222: #ifdef _GMP_H_HAVE_FILE
! 223: size_t mpz_inp_binary _PROTO ((mpz_ptr, FILE *));
! 224: size_t mpz_inp_raw _PROTO ((mpz_ptr, FILE *));
! 225: size_t mpz_inp_str _PROTO ((mpz_ptr, FILE *, int));
! 226: #endif
! 227: void mpz_init_set _PROTO ((mpz_ptr, mpz_srcptr));
! 228: void mpz_init_set_d _PROTO ((mpz_ptr, double));
! 229: void mpz_init_set_si _PROTO ((mpz_ptr, signed long int));
! 230: int mpz_init_set_str _PROTO ((mpz_ptr, const char *, int));
! 231: void mpz_init_set_ui _PROTO ((mpz_ptr, unsigned long int));
! 232: int mpz_invert _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 233: void mpz_ior _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 234: int mpz_jacobi _PROTO ((mpz_srcptr, mpz_srcptr));
! 235: int mpz_legendre _PROTO ((mpz_srcptr, mpz_srcptr));
! 236: void mpz_mod _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 237: void mpz_mul _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 238: void mpz_mul_2exp _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 239: void mpz_mul_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 240: void mpz_neg _PROTO ((mpz_ptr, mpz_srcptr));
! 241: #ifdef _GMP_H_HAVE_FILE
! 242: size_t mpz_out_binary _PROTO ((FILE *, mpz_srcptr));
! 243: size_t mpz_out_raw _PROTO ((FILE *, mpz_srcptr));
! 244: size_t mpz_out_str _PROTO ((FILE *, int, mpz_srcptr));
! 245: #endif
! 246: int mpz_perfect_square_p _PROTO ((mpz_srcptr));
! 247: unsigned long int mpz_popcount _PROTO ((mpz_srcptr));
! 248: void mpz_pow_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 249: void mpz_powm _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr, mpz_srcptr));
! 250: void mpz_powm_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int, mpz_srcptr));
! 251: int mpz_probab_prime_p _PROTO ((mpz_srcptr, int));
! 252: void mpz_random _PROTO ((mpz_ptr, mp_size_t));
! 253: void mpz_random2 _PROTO ((mpz_ptr, mp_size_t));
! 254: unsigned long int mpz_scan0 _PROTO ((mpz_srcptr, unsigned long int));
! 255: unsigned long int mpz_scan1 _PROTO ((mpz_srcptr, unsigned long int));
! 256: void mpz_set _PROTO ((mpz_ptr, mpz_srcptr));
! 257: void mpz_set_d _PROTO ((mpz_ptr, double));
! 258: void mpz_set_f _PROTO ((mpz_ptr, mpf_srcptr));
! 259: void mpz_set_q _PROTO ((mpz_ptr, mpq_srcptr));
! 260: void mpz_set_si _PROTO ((mpz_ptr, signed long int));
! 261: int mpz_set_str _PROTO ((mpz_ptr, const char *, int));
! 262: void mpz_set_ui _PROTO ((mpz_ptr, unsigned long int));
! 263: void mpz_setbit _PROTO ((mpz_ptr, unsigned long int));
! 264: size_t mpz_size _PROTO ((mpz_srcptr));
! 265: size_t mpz_sizeinbase _PROTO ((mpz_srcptr, int));
! 266: void mpz_sqrt _PROTO ((mpz_ptr, mpz_srcptr));
! 267: void mpz_sqrtrem _PROTO ((mpz_ptr, mpz_ptr, mpz_srcptr));
! 268: void mpz_sub _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 269: void mpz_sub_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 270: void mpz_tdiv_q _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 271: void mpz_tdiv_q_2exp _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 272: void mpz_tdiv_q_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 273: void mpz_tdiv_qr _PROTO ((mpz_ptr, mpz_ptr, mpz_srcptr, mpz_srcptr));
! 274: void mpz_tdiv_qr_ui _PROTO ((mpz_ptr, mpz_ptr, mpz_srcptr, unsigned long int));
! 275: void mpz_tdiv_r _PROTO ((mpz_ptr, mpz_srcptr, mpz_srcptr));
! 276: void mpz_tdiv_r_2exp _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 277: void mpz_tdiv_r_ui _PROTO ((mpz_ptr, mpz_srcptr, unsigned long int));
! 278: void mpz_ui_pow_ui _PROTO ((mpz_ptr, unsigned long int, unsigned long int));
! 279:
! 280: /**************** Rational (i.e. Q) routines. ****************/
! 281:
! 282: void mpq_init _PROTO ((mpq_ptr));
! 283: void mpq_clear _PROTO ((mpq_ptr));
! 284: void mpq_set _PROTO ((mpq_ptr, mpq_srcptr));
! 285: void mpq_set_ui _PROTO ((mpq_ptr, unsigned long int, unsigned long int));
! 286: void mpq_set_si _PROTO ((mpq_ptr, signed long int, unsigned long int));
! 287: void mpq_set_z _PROTO ((mpq_ptr, mpz_srcptr));
! 288: void mpq_add _PROTO ((mpq_ptr, mpq_srcptr, mpq_srcptr));
! 289: void mpq_sub _PROTO ((mpq_ptr, mpq_srcptr, mpq_srcptr));
! 290: void mpq_mul _PROTO ((mpq_ptr, mpq_srcptr, mpq_srcptr));
! 291: void mpq_div _PROTO ((mpq_ptr, mpq_srcptr, mpq_srcptr));
! 292: void mpq_neg _PROTO ((mpq_ptr, mpq_srcptr));
! 293: int mpq_cmp _PROTO ((mpq_srcptr, mpq_srcptr));
! 294: int mpq_cmp_ui _PROTO ((mpq_srcptr, unsigned long int, unsigned long int));
! 295: int mpq_equal _PROTO ((mpq_srcptr, mpq_srcptr));
! 296: void mpq_inv _PROTO ((mpq_ptr, mpq_srcptr));
! 297: void mpq_set_num _PROTO ((mpq_ptr, mpz_srcptr));
! 298: void mpq_set_den _PROTO ((mpq_ptr, mpz_srcptr));
! 299: void mpq_get_num _PROTO ((mpz_ptr, mpq_srcptr));
! 300: void mpq_get_den _PROTO ((mpz_ptr, mpq_srcptr));
! 301: double mpq_get_d _PROTO ((mpq_srcptr));
! 302: void mpq_canonicalize _PROTO ((mpq_ptr));
! 303:
! 304: /**************** Float (i.e. F) routines. ****************/
! 305:
! 306: void mpf_abs _PROTO ((mpf_ptr, mpf_srcptr));
! 307: void mpf_add _PROTO ((mpf_ptr, mpf_srcptr, mpf_srcptr));
! 308: void mpf_add_ui _PROTO ((mpf_ptr, mpf_srcptr, unsigned long int));
! 309: void mpf_clear _PROTO ((mpf_ptr));
! 310: int mpf_cmp _PROTO ((mpf_srcptr, mpf_srcptr));
! 311: int mpf_cmp_si _PROTO ((mpf_srcptr, signed long int));
! 312: int mpf_cmp_ui _PROTO ((mpf_srcptr, unsigned long int));
! 313: void mpf_div _PROTO ((mpf_ptr, mpf_srcptr, mpf_srcptr));
! 314: void mpf_div_2exp _PROTO ((mpf_ptr, mpf_srcptr, unsigned long int));
! 315: void mpf_div_ui _PROTO ((mpf_ptr, mpf_srcptr, unsigned long int));
! 316: void mpf_dump _PROTO ((mpf_srcptr));
! 317: int mpf_eq _PROTO ((mpf_srcptr, mpf_srcptr, unsigned long int));
! 318: double mpf_get_d _PROTO ((mpf_srcptr));
! 319: unsigned long int mpf_get_prec _PROTO ((mpf_srcptr));
! 320: char *mpf_get_str _PROTO ((char *, mp_exp_t *, int, size_t, mpf_srcptr));
! 321: void mpf_init _PROTO ((mpf_ptr));
! 322: void mpf_init2 _PROTO ((mpf_ptr, unsigned long int));
! 323: #ifdef _GMP_H_HAVE_FILE
! 324: size_t mpf_inp_str _PROTO ((mpf_ptr, FILE *, int));
! 325: #endif
! 326: void mpf_init_set _PROTO ((mpf_ptr, mpf_srcptr));
! 327: void mpf_init_set_d _PROTO ((mpf_ptr, double));
! 328: void mpf_init_set_si _PROTO ((mpf_ptr, signed long int));
! 329: int mpf_init_set_str _PROTO ((mpf_ptr, const char *, int));
! 330: void mpf_init_set_ui _PROTO ((mpf_ptr, unsigned long int));
! 331: void mpf_mul _PROTO ((mpf_ptr, mpf_srcptr, mpf_srcptr));
! 332: void mpf_mul_2exp _PROTO ((mpf_ptr, mpf_srcptr, unsigned long int));
! 333: void mpf_mul_ui _PROTO ((mpf_ptr, mpf_srcptr, unsigned long int));
! 334: void mpf_neg _PROTO ((mpf_ptr, mpf_srcptr));
! 335: #ifdef _GMP_H_HAVE_FILE
! 336: size_t mpf_out_str _PROTO ((FILE *, int, size_t, mpf_srcptr));
! 337: #endif
! 338: void mpf_random2 _PROTO ((mpf_ptr, mp_size_t, mp_exp_t));
! 339: void mpf_reldiff _PROTO ((mpf_ptr, mpf_srcptr, mpf_srcptr));
! 340: void mpf_set _PROTO ((mpf_ptr, mpf_srcptr));
! 341: void mpf_set_d _PROTO ((mpf_ptr, double));
! 342: void mpf_set_default_prec _PROTO ((unsigned long int));
! 343: void mpf_set_prec _PROTO ((mpf_ptr, unsigned long int));
! 344: void mpf_set_prec_raw _PROTO ((mpf_ptr, unsigned long int));
! 345: void mpf_set_q _PROTO ((mpf_ptr, mpq_srcptr));
! 346: void mpf_set_si _PROTO ((mpf_ptr, signed long int));
! 347: int mpf_set_str _PROTO ((mpf_ptr, const char *, int));
! 348: void mpf_set_ui _PROTO ((mpf_ptr, unsigned long int));
! 349: void mpf_set_z _PROTO ((mpf_ptr, mpz_srcptr));
! 350: size_t mpf_size _PROTO ((mpf_srcptr));
! 351: void mpf_sqrt _PROTO ((mpf_ptr, mpf_srcptr));
! 352: void mpf_sqrt_ui _PROTO ((mpf_ptr, unsigned long int));
! 353: void mpf_sub _PROTO ((mpf_ptr, mpf_srcptr, mpf_srcptr));
! 354: void mpf_sub_ui _PROTO ((mpf_ptr, mpf_srcptr, unsigned long int));
! 355: void mpf_ui_div _PROTO ((mpf_ptr, unsigned long int, mpf_srcptr));
! 356: void mpf_ui_sub _PROTO ((mpf_ptr, unsigned long int, mpf_srcptr));
! 357: #if defined (__cplusplus)
! 358: }
! 359: #endif
! 360: /************ Low level positive-integer (i.e. N) routines. ************/
! 361:
! 362: /* This is ugly, but we need to make usr calls reach the prefixed function. */
! 363: #define mpn_add __MPN(add)
! 364: #define mpn_add_1 __MPN(add_1)
! 365: #define mpn_add_n __MPN(add_n)
! 366: #define mpn_addmul_1 __MPN(addmul_1)
! 367: #define mpn_bdivmod __MPN(bdivmod)
! 368: #define mpn_cmp __MPN(cmp)
! 369: #define mpn_divmod_1 __MPN(divmod_1)
! 370: #define mpn_divrem __MPN(divrem)
! 371: #define mpn_divrem_1 __MPN(divrem_1)
! 372: #define mpn_dump __MPN(dump)
! 373: #define mpn_gcd __MPN(gcd)
! 374: #define mpn_gcd_1 __MPN(gcd_1)
! 375: #define mpn_gcdext __MPN(gcdext)
! 376: #define mpn_get_str __MPN(get_str)
! 377: #define mpn_hamdist __MPN(hamdist)
! 378: #define mpn_lshift __MPN(lshift)
! 379: #define mpn_mod_1 __MPN(mod_1)
! 380: #define mpn_mul __MPN(mul)
! 381: #define mpn_mul_1 __MPN(mul_1)
! 382: #define mpn_mul_n __MPN(mul_n)
! 383: #define mpn_perfect_square_p __MPN(perfect_square_p)
! 384: #define mpn_popcount __MPN(popcount)
! 385: #define mpn_preinv_mod_1 __MPN(preinv_mod_1)
! 386: #define mpn_random2 __MPN(random2)
! 387: #define mpn_rshift __MPN(rshift)
! 388: #define mpn_scan0 __MPN(scan0)
! 389: #define mpn_scan1 __MPN(scan1)
! 390: #define mpn_set_str __MPN(set_str)
! 391: #define mpn_sqrtrem __MPN(sqrtrem)
! 392: #define mpn_sub __MPN(sub)
! 393: #define mpn_sub_1 __MPN(sub_1)
! 394: #define mpn_sub_n __MPN(sub_n)
! 395: #define mpn_submul_1 __MPN(submul_1)
! 396: #define mpn_udiv_w_sdiv __MPN(udiv_w_sdiv)
! 397:
! 398: #if defined (__cplusplus)
! 399: extern "C" {
! 400: #endif
! 401: mp_limb_t mpn_add _PROTO ((mp_ptr, mp_srcptr, mp_size_t, mp_srcptr,mp_size_t));
! 402: mp_limb_t mpn_add_1 _PROTO ((mp_ptr, mp_srcptr, mp_size_t, mp_limb_t));
! 403: mp_limb_t mpn_add_n _PROTO ((mp_ptr, mp_srcptr, mp_srcptr, mp_size_t));
! 404: mp_limb_t mpn_addmul_1 _PROTO ((mp_ptr, mp_srcptr, mp_size_t, mp_limb_t));
! 405: mp_limb_t mpn_bdivmod _PROTO ((mp_ptr, mp_ptr, mp_size_t, mp_srcptr, mp_size_t, unsigned long int));
! 406: int mpn_cmp _PROTO ((mp_srcptr, mp_srcptr, mp_size_t));
! 407: mp_limb_t mpn_divmod_1 _PROTO ((mp_ptr, mp_srcptr, mp_size_t, mp_limb_t));
! 408: mp_limb_t mpn_divrem _PROTO ((mp_ptr, mp_size_t, mp_ptr, mp_size_t, mp_srcptr, mp_size_t));
! 409: mp_limb_t mpn_divrem_1 _PROTO ((mp_ptr, mp_size_t, mp_srcptr, mp_size_t, mp_limb_t));
! 410: void mpn_dump _PROTO ((mp_srcptr, mp_size_t));
! 411: mp_size_t mpn_gcd _PROTO ((mp_ptr, mp_ptr, mp_size_t, mp_ptr, mp_size_t));
! 412: mp_limb_t mpn_gcd_1 _PROTO ((mp_srcptr, mp_size_t, mp_limb_t));
! 413: mp_size_t mpn_gcdext _PROTO ((mp_ptr, mp_ptr, mp_ptr, mp_size_t, mp_ptr, mp_size_t));
! 414: size_t mpn_get_str _PROTO ((unsigned char *, int, mp_ptr, mp_size_t));
! 415: unsigned long int mpn_hamdist _PROTO ((mp_srcptr, mp_srcptr, mp_size_t));
! 416: mp_limb_t mpn_lshift _PROTO ((mp_ptr, mp_srcptr, mp_size_t, unsigned int));
! 417: mp_limb_t mpn_mod_1 _PROTO ((mp_srcptr, mp_size_t, mp_limb_t));
! 418: mp_limb_t mpn_mul _PROTO ((mp_ptr, mp_srcptr, mp_size_t, mp_srcptr, mp_size_t));
! 419: mp_limb_t mpn_mul_1 _PROTO ((mp_ptr, mp_srcptr, mp_size_t, mp_limb_t));
! 420: void mpn_mul_n _PROTO ((mp_ptr, mp_srcptr, mp_srcptr, mp_size_t));
! 421: int mpn_perfect_square_p _PROTO ((mp_srcptr, mp_size_t));
! 422: unsigned long int mpn_popcount _PROTO ((mp_srcptr, mp_size_t));
! 423: mp_limb_t mpn_preinv_mod_1 _PROTO ((mp_srcptr, mp_size_t, mp_limb_t, mp_limb_t));
! 424: void mpn_random2 _PROTO ((mp_ptr, mp_size_t));
! 425: mp_limb_t mpn_rshift _PROTO ((mp_ptr, mp_srcptr, mp_size_t, unsigned int));
! 426: unsigned long int mpn_scan0 _PROTO ((mp_srcptr, unsigned long int));
! 427: unsigned long int mpn_scan1 _PROTO ((mp_srcptr, unsigned long int));
! 428: mp_size_t mpn_set_str _PROTO ((mp_ptr, const unsigned char *, size_t, int));
! 429: mp_size_t mpn_sqrtrem _PROTO ((mp_ptr, mp_ptr, mp_srcptr, mp_size_t));
! 430: mp_limb_t mpn_sub _PROTO ((mp_ptr, mp_srcptr, mp_size_t, mp_srcptr,mp_size_t));
! 431: mp_limb_t mpn_sub_1 _PROTO ((mp_ptr, mp_srcptr, mp_size_t, mp_limb_t));
! 432: mp_limb_t mpn_sub_n _PROTO ((mp_ptr, mp_srcptr, mp_srcptr, mp_size_t));
! 433: mp_limb_t mpn_submul_1 _PROTO ((mp_ptr, mp_srcptr, mp_size_t, mp_limb_t));
! 434: #if defined (__cplusplus)
! 435: }
! 436: #endif
! 437:
! 438: #if defined (__GNUC__) || defined (_FORCE_INLINES)
! 439: _EXTERN_INLINE mp_limb_t
! 440: #if defined (__STDC__) || defined (__cplusplus)
! 441: mpn_add_1 (register mp_ptr res_ptr,
! 442: register mp_srcptr s1_ptr,
! 443: register mp_size_t s1_size,
! 444: register mp_limb_t s2_limb)
! 445: #else
! 446: mpn_add_1 (res_ptr, s1_ptr, s1_size, s2_limb)
! 447: register mp_ptr res_ptr;
! 448: register mp_srcptr s1_ptr;
! 449: register mp_size_t s1_size;
! 450: register mp_limb_t s2_limb;
! 451: #endif
! 452: {
! 453: register mp_limb_t x;
! 454:
! 455: x = *s1_ptr++;
! 456: s2_limb = x + s2_limb;
! 457: *res_ptr++ = s2_limb;
! 458: if (s2_limb < x)
! 459: {
! 460: while (--s1_size != 0)
! 461: {
! 462: x = *s1_ptr++ + 1;
! 463: *res_ptr++ = x;
! 464: if (x != 0)
! 465: goto fin;
! 466: }
! 467:
! 468: return 1;
! 469: }
! 470:
! 471: fin:
! 472: if (res_ptr != s1_ptr)
! 473: {
! 474: mp_size_t i;
! 475: for (i = 0; i < s1_size - 1; i++)
! 476: res_ptr[i] = s1_ptr[i];
! 477: }
! 478: return 0;
! 479: }
! 480:
! 481: _EXTERN_INLINE mp_limb_t
! 482: #if defined (__STDC__) || defined (__cplusplus)
! 483: mpn_add (register mp_ptr res_ptr,
! 484: register mp_srcptr s1_ptr,
! 485: register mp_size_t s1_size,
! 486: register mp_srcptr s2_ptr,
! 487: register mp_size_t s2_size)
! 488: #else
! 489: mpn_add (res_ptr, s1_ptr, s1_size, s2_ptr, s2_size)
! 490: register mp_ptr res_ptr;
! 491: register mp_srcptr s1_ptr;
! 492: register mp_size_t s1_size;
! 493: register mp_srcptr s2_ptr;
! 494: register mp_size_t s2_size;
! 495: #endif
! 496: {
! 497: mp_limb_t cy_limb = 0;
! 498:
! 499: if (s2_size != 0)
! 500: cy_limb = mpn_add_n (res_ptr, s1_ptr, s2_ptr, s2_size);
! 501:
! 502: if (s1_size - s2_size != 0)
! 503: cy_limb = mpn_add_1 (res_ptr + s2_size,
! 504: s1_ptr + s2_size,
! 505: s1_size - s2_size,
! 506: cy_limb);
! 507: return cy_limb;
! 508: }
! 509:
! 510: _EXTERN_INLINE mp_limb_t
! 511: #if defined (__STDC__) || defined (__cplusplus)
! 512: mpn_sub_1 (register mp_ptr res_ptr,
! 513: register mp_srcptr s1_ptr,
! 514: register mp_size_t s1_size,
! 515: register mp_limb_t s2_limb)
! 516: #else
! 517: mpn_sub_1 (res_ptr, s1_ptr, s1_size, s2_limb)
! 518: register mp_ptr res_ptr;
! 519: register mp_srcptr s1_ptr;
! 520: register mp_size_t s1_size;
! 521: register mp_limb_t s2_limb;
! 522: #endif
! 523: {
! 524: register mp_limb_t x;
! 525:
! 526: x = *s1_ptr++;
! 527: s2_limb = x - s2_limb;
! 528: *res_ptr++ = s2_limb;
! 529: if (s2_limb > x)
! 530: {
! 531: while (--s1_size != 0)
! 532: {
! 533: x = *s1_ptr++;
! 534: *res_ptr++ = x - 1;
! 535: if (x != 0)
! 536: goto fin;
! 537: }
! 538:
! 539: return 1;
! 540: }
! 541:
! 542: fin:
! 543: if (res_ptr != s1_ptr)
! 544: {
! 545: mp_size_t i;
! 546: for (i = 0; i < s1_size - 1; i++)
! 547: res_ptr[i] = s1_ptr[i];
! 548: }
! 549: return 0;
! 550: }
! 551:
! 552: _EXTERN_INLINE mp_limb_t
! 553: #if defined (__STDC__) || defined (__cplusplus)
! 554: mpn_sub (register mp_ptr res_ptr,
! 555: register mp_srcptr s1_ptr,
! 556: register mp_size_t s1_size,
! 557: register mp_srcptr s2_ptr,
! 558: register mp_size_t s2_size)
! 559: #else
! 560: mpn_sub (res_ptr, s1_ptr, s1_size, s2_ptr, s2_size)
! 561: register mp_ptr res_ptr;
! 562: register mp_srcptr s1_ptr;
! 563: register mp_size_t s1_size;
! 564: register mp_srcptr s2_ptr;
! 565: register mp_size_t s2_size;
! 566: #endif
! 567: {
! 568: mp_limb_t cy_limb = 0;
! 569:
! 570: if (s2_size != 0)
! 571: cy_limb = mpn_sub_n (res_ptr, s1_ptr, s2_ptr, s2_size);
! 572:
! 573: if (s1_size - s2_size != 0)
! 574: cy_limb = mpn_sub_1 (res_ptr + s2_size,
! 575: s1_ptr + s2_size,
! 576: s1_size - s2_size,
! 577: cy_limb);
! 578: return cy_limb;
! 579: }
! 580: #endif /* __GNUC__ */
! 581:
! 582: /* Allow faster testing for negative, zero, and positive. */
! 583: #define mpz_sgn(Z) ((Z)->_mp_size < 0 ? -1 : (Z)->_mp_size > 0)
! 584: #define mpf_sgn(F) ((F)->_mp_size < 0 ? -1 : (F)->_mp_size > 0)
! 585: #define mpq_sgn(Q) ((Q)->_mp_num._mp_size < 0 ? -1 : (Q)->_mp_num._mp_size > 0)
! 586:
! 587: /* Allow direct user access to numerator and denominator of a mpq_t object. */
! 588: #define mpq_numref(Q) (&((Q)->_mp_num))
! 589: #define mpq_denref(Q) (&((Q)->_mp_den))
! 590:
! 591: /* When using GCC, optimize certain common comparisons. */
! 592: #if defined (__GNUC__)
! 593: #define mpz_cmp_ui(Z,UI) \
! 594: (__builtin_constant_p (UI) && (UI) == 0 \
! 595: ? mpz_sgn (Z) : mpz_cmp_ui (Z,UI))
! 596: #define mpz_cmp_si(Z,UI) \
! 597: (__builtin_constant_p (UI) && (UI) == 0 ? mpz_sgn (Z) \
! 598: : __builtin_constant_p (UI) && (UI) > 0 ? mpz_cmp_ui (Z,UI) \
! 599: : mpz_cmp_si (Z,UI))
! 600: #define mpq_cmp_ui(Q,NUI,DUI) \
! 601: (__builtin_constant_p (NUI) && (NUI) == 0 \
! 602: ? mpq_sgn (Q) : mpq_cmp_ui (Q,NUI,DUI))
! 603: #endif
! 604:
! 605: #define mpn_divmod(qp,np,nsize,dp,dsize) mpn_divrem (qp,0,np,nsize,dp,dsize)
! 606: #if 0
! 607: #define mpn_divmod_1(qp,np,nsize,dlimb) mpn_divrem_1 (qp,0,np,nsize,dlimb)
! 608: #endif
! 609:
! 610: /* Compatibility with GMP 1. */
! 611: #define mpz_mdiv mpz_fdiv_q
! 612: #define mpz_mdivmod mpz_fdiv_qr
! 613: #define mpz_mmod mpz_fdiv_r
! 614: #define mpz_mdiv_ui mpz_fdiv_q_ui
! 615: #define mpz_mdivmod_ui(q,r,n,d) \
! 616: ((r == 0) ? mpz_fdiv_q_ui (q,n,d) : mpz_fdiv_qr_ui (q,r,n,d))
! 617: #define mpz_mmod_ui(r,n,d) \
! 618: ((r == 0) ? mpz_fdiv_ui (n,d) : mpz_fdiv_r_ui (r,n,d))
! 619:
! 620: /* Useful synonyms, but not quite compatible with GMP 1. */
! 621: #define mpz_div mpz_fdiv_q
! 622: #define mpz_divmod mpz_fdiv_qr
! 623: #define mpz_div_ui mpz_fdiv_q_ui
! 624: #define mpz_divmod_ui mpz_fdiv_qr_ui
! 625: #define mpz_mod_ui mpz_fdiv_r_ui
! 626: #define mpz_div_2exp mpz_fdiv_q_2exp
! 627: #define mpz_mod_2exp mpz_fdiv_r_2exp
! 628:
! 629: #define __GNU_MP_VERSION 2
! 630: #define __GNU_MP_VERSION_MINOR 0
! 631: #define __GMP_H__
! 632: #endif /* __GMP_H__ */
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>