Annotation of OpenXM_contrib/gmp/gmp.info-2, Revision 1.1.1.1
1.1 maekawa 1: This is Info file gmp.info, produced by Makeinfo-1.64 from the input
2: file gmp.texi.
3:
4: START-INFO-DIR-ENTRY
5: * gmp: (gmp.info). GNU Multiple Precision Arithmetic Library.
6: END-INFO-DIR-ENTRY
7:
8: This file documents GNU MP, a library for arbitrary-precision
9: arithmetic.
10:
11: Copyright (C) 1991, 1993, 1994, 1995, 1996 Free Software Foundation,
12: Inc.
13:
14: Permission is granted to make and distribute verbatim copies of this
15: manual provided the copyright notice and this permission notice are
16: preserved on all copies.
17:
18: Permission is granted to copy and distribute modified versions of
19: this manual under the conditions for verbatim copying, provided that
20: the entire resulting derived work is distributed under the terms of a
21: permission notice identical to this one.
22:
23: Permission is granted to copy and distribute translations of this
24: manual into another language, under the above conditions for modified
25: versions, except that this permission notice may be stated in a
26: translation approved by the Foundation.
27:
28:
29: File: gmp.info, Node: Floating-point Functions, Next: Low-level Functions, Prev: Rational Number Functions, Up: Top
30:
31: Floating-point Functions
32: ************************
33:
34: This is a description of the *preliminary* interface for
35: floating-point arithmetic in GNU MP 2.
36:
37: The floating-point functions expect arguments of type `mpf_t'.
38:
39: The MP floating-point functions have an interface that is similar to
40: the MP integer functions. The function prefix for floating-point
41: operations is `mpf_'.
42:
43: There is one significant characteristic of floating-point numbers
44: that has motivated a difference between this function class and other
45: MP function classes: the inherent inexactness of floating point
46: arithmetic. The user has to specify the precision of each variable. A
47: computation that assigns a variable will take place with the precision
48: of the assigned variable; the precision of variables used as input is
49: ignored.
50:
51: The precision of a calculation is defined as follows: Compute the
52: requested operation exactly (with "infinite precision"), and truncate
53: the result to the destination variable precision. Even if the user has
54: asked for a very high precision, MP will not calculate with superfluous
55: digits. For example, if two low-precision numbers of nearly equal
56: magnitude are added, the precision of the result will be limited to
57: what is required to represent the result accurately.
58:
59: The MP floating-point functions are *not* intended as a smooth
60: extension to the IEEE P754 arithmetic. Specifically, the results
61: obtained on one computer often differs from the results obtained on a
62: computer with a different word size.
63:
64: * Menu:
65:
66: * Initializing Floats::
67: * Assigning Floats::
68: * Simultaneous Float Init & Assign::
69: * Converting Floats::
70: * Float Arithmetic::
71: * Float Comparison::
72: * I/O of Floats::
73: * Miscellaneous Float Functions::
74:
75:
76: File: gmp.info, Node: Initializing Floats, Next: Assigning Floats, Up: Floating-point Functions
77:
78: Initialization and Assignment Functions
79: =======================================
80:
81: - Function: void mpf_set_default_prec (unsigned long int PREC)
82: Set the default precision to be *at least* PREC bits. All
83: subsequent calls to `mpf_init' will use this precision, but
84: previously initialized variables are unaffected.
85:
86: An `mpf_t' object must be initialized before storing the first value
87: in it. The functions `mpf_init' and `mpf_init2' are used for that
88: purpose.
89:
90: - Function: void mpf_init (mpf_t X)
91: Initialize X to 0. Normally, a variable should be initialized
92: once only or at least be cleared, using `mpf_clear', between
93: initializations. The precision of X is undefined unless a default
94: precision has already been established by a call to
95: `mpf_set_default_prec'.
96:
97: - Function: void mpf_init2 (mpf_t X, unsigned long int PREC)
98: Initialize X to 0 and set its precision to be *at least* PREC
99: bits. Normally, a variable should be initialized once only or at
100: least be cleared, using `mpf_clear', between initializations.
101:
102: - Function: void mpf_clear (mpf_t X)
103: Free the space occupied by X. Make sure to call this function for
104: all `mpf_t' variables when you are done with them.
105:
106: Here is an example on how to initialize floating-point variables:
107: {
108: mpf_t x, y;
109: mpf_init (x); /* use default precision */
110: mpf_init2 (y, 256); /* precision *at least* 256 bits */
111: ...
112: /* Unless the program is about to exit, do ... */
113: mpf_clear (x);
114: mpf_clear (y);
115: }
116:
117: The following three functions are useful for changing the precision
118: during a calculation. A typical use would be for adjusting the
119: precision gradually in iterative algorithms like Newton-Raphson, making
120: the computation precision closely match the actual accurate part of the
121: numbers.
122:
123: - Function: void mpf_set_prec (mpf_t ROP, unsigned long int PREC)
124: Set the precision of ROP to be *at least* PREC bits. Since
125: changing the precision involves calls to `realloc', this routine
126: should not be called in a tight loop.
127:
128: - Function: unsigned long int mpf_get_prec (mpf_t OP)
129: Return the precision actually used for assignments of OP.
130:
131: - Function: void mpf_set_prec_raw (mpf_t ROP, unsigned long int PREC)
132: Set the precision of ROP to be *at least* PREC bits. This is a
133: low-level function that does not change the allocation. The PREC
134: argument must not be larger that the precision previously returned
135: by `mpf_get_prec'. It is crucial that the precision of ROP is
136: ultimately reset to exactly the value returned by `mpf_get_prec'.
137:
138:
139: File: gmp.info, Node: Assigning Floats, Next: Simultaneous Float Init & Assign, Prev: Initializing Floats, Up: Floating-point Functions
140:
141: Assignment Functions
142: --------------------
143:
144: These functions assign new values to already initialized floats
145: (*note Initializing Floats::.).
146:
147: - Function: void mpf_set (mpf_t ROP, mpf_t OP)
148: - Function: void mpf_set_ui (mpf_t ROP, unsigned long int OP)
149: - Function: void mpf_set_si (mpf_t ROP, signed long int OP)
150: - Function: void mpf_set_d (mpf_t ROP, double OP)
151: - Function: void mpf_set_z (mpf_t ROP, mpz_t OP)
152: - Function: void mpf_set_q (mpf_t ROP, mpq_t OP)
153: Set the value of ROP from OP.
154:
155: - Function: int mpf_set_str (mpf_t ROP, char *STR, int BASE)
156: Set the value of ROP from the string in STR. The string is of the
157: form `M@N' or, if the base is 10 or less, alternatively `MeN'.
158: `M' is the mantissa and `N' is the exponent. The mantissa is
159: always in the specified base. The exponent is either in the
160: specified base or, if BASE is negative, in decimal.
161:
162: The argument BASE may be in the ranges 2 to 36, or -36 to -2.
163: Negative values are used to specify that the exponent is in
164: decimal.
165:
166: Unlike the corresponding `mpz' function, the base will not be
167: determined from the leading characters of the string if BASE is 0.
168: This is so that numbers like `0.23' are not interpreted as octal.
169:
170: White space is allowed in the string, and is simply ignored.
171:
172: This function returns 0 if the entire string up to the '\0' is a
173: valid number in base BASE. Otherwise it returns -1.
174:
175:
176: File: gmp.info, Node: Simultaneous Float Init & Assign, Next: Converting Floats, Prev: Assigning Floats, Up: Floating-point Functions
177:
178: Combined Initialization and Assignment Functions
179: ------------------------------------------------
180:
181: For convenience, MP provides a parallel series of initialize-and-set
182: functions which initialize the output and then store the value there.
183: These functions' names have the form `mpf_init_set...'
184:
185: Once the float has been initialized by any of the `mpf_init_set...'
186: functions, it can be used as the source or destination operand for the
187: ordinary float functions. Don't use an initialize-and-set function on
188: a variable already initialized!
189:
190: - Function: void mpf_init_set (mpf_t ROP, mpf_t OP)
191: - Function: void mpf_init_set_ui (mpf_t ROP, unsigned long int OP)
192: - Function: void mpf_init_set_si (mpf_t ROP, signed long int OP)
193: - Function: void mpf_init_set_d (mpf_t ROP, double OP)
194: Initialize ROP and set its value from OP.
195:
196: The precision of ROP will be taken from the active default
197: precision, as set by `mpf_set_default_prec'.
198:
199: - Function: int mpf_init_set_str (mpf_t ROP, char *STR, int BASE)
200: Initialize ROP and set its value from the string in STR. See
201: `mpf_set_str' above for details on the assignment operation.
202:
203: Note that ROP is initialized even if an error occurs. (I.e., you
204: have to call `mpf_clear' for it.)
205:
206: The precision of ROP will be taken from the active default
207: precision, as set by `mpf_set_default_prec'.
208:
209:
210: File: gmp.info, Node: Converting Floats, Next: Float Arithmetic, Prev: Simultaneous Float Init & Assign, Up: Floating-point Functions
211:
212: Conversion Functions
213: ====================
214:
215: - Function: double mpf_get_d (mpf_t OP)
216: Convert OP to a double.
217:
218: - Function: char * mpf_get_str (char *STR, mp_exp_t *EXPPTR, int BASE,
219: size_t N_DIGITS, mpf_t OP)
220: Convert OP to a string of digits in base BASE. The base may vary
221: from 2 to 36. Generate at most N_DIGITS significant digits, or if
222: N_DIGITS is 0, the maximum number of digits accurately
223: representable by OP.
224:
225: If STR is NULL, space for the mantissa is allocated using the
226: default allocation function, and a pointer to the string is
227: returned.
228:
229: If STR is not NULL, it should point to a block of storage enough
230: large for the mantissa, i.e., N_DIGITS + 2. The two extra bytes
231: are for a possible minus sign, and for the terminating null
232: character.
233:
234: The exponent is written through the pointer EXPPTR.
235:
236: If N_DIGITS is 0, the maximum number of digits meaningfully
237: achievable from the precision of OP will be generated. Note that
238: the space requirements for STR in this case will be impossible for
239: the user to predetermine. Therefore, you need to pass NULL for
240: the string argument whenever N_DIGITS is 0.
241:
242: The generated string is a fraction, with an implicit radix point
243: immediately to the left of the first digit. For example, the
244: number 3.1416 would be returned as "31416" in the string and 1
245: written at EXPPTR.
246:
247:
248: File: gmp.info, Node: Float Arithmetic, Next: Float Comparison, Prev: Converting Floats, Up: Floating-point Functions
249:
250: Arithmetic Functions
251: ====================
252:
253: - Function: void mpf_add (mpf_t ROP, mpf_t OP1, mpf_t OP2)
254: - Function: void mpf_add_ui (mpf_t ROP, mpf_t OP1, unsigned long int
255: OP2)
256: Set ROP to OP1 + OP2.
257:
258: - Function: void mpf_sub (mpf_t ROP, mpf_t OP1, mpf_t OP2)
259: - Function: void mpf_ui_sub (mpf_t ROP, unsigned long int OP1, mpf_t
260: OP2)
261: - Function: void mpf_sub_ui (mpf_t ROP, mpf_t OP1, unsigned long int
262: OP2)
263: Set ROP to OP1 - OP2.
264:
265: - Function: void mpf_mul (mpf_t ROP, mpf_t OP1, mpf_t OP2)
266: - Function: void mpf_mul_ui (mpf_t ROP, mpf_t OP1, unsigned long int
267: OP2)
268: Set ROP to OP1 times OP2.
269:
270: Division is undefined if the divisor is zero, and passing a zero
271: divisor to the divide functions will make these functions intentionally
272: divide by zero. This gives the user the possibility to handle
273: arithmetic exceptions in these functions in the same manner as other
274: arithmetic exceptions.
275:
276: - Function: void mpf_div (mpf_t ROP, mpf_t OP1, mpf_t OP2)
277: - Function: void mpf_ui_div (mpf_t ROP, unsigned long int OP1, mpf_t
278: OP2)
279: - Function: void mpf_div_ui (mpf_t ROP, mpf_t OP1, unsigned long int
280: OP2)
281: Set ROP to OP1/OP2.
282:
283: - Function: void mpf_sqrt (mpf_t ROP, mpf_t OP)
284: - Function: void mpf_sqrt_ui (mpf_t ROP, unsigned long int OP)
285: Set ROP to the square root of OP.
286:
287: - Function: void mpf_neg (mpf_t ROP, mpf_t OP)
288: Set ROP to -OP.
289:
290: - Function: void mpf_abs (mpf_t ROP, mpf_t OP)
291: Set ROP to the absolute value of OP.
292:
293: - Function: void mpf_mul_2exp (mpf_t ROP, mpf_t OP1, unsigned long int
294: OP2)
295: Set ROP to OP1 times 2 raised to OP2.
296:
297: - Function: void mpf_div_2exp (mpf_t ROP, mpf_t OP1, unsigned long int
298: OP2)
299: Set ROP to OP1 divided by 2 raised to OP2.
300:
301:
302: File: gmp.info, Node: Float Comparison, Next: I/O of Floats, Prev: Float Arithmetic, Up: Floating-point Functions
303:
304: Comparison Functions
305: ====================
306:
307: - Function: int mpf_cmp (mpf_t OP1, mpf_t OP2)
308: - Function: int mpf_cmp_ui (mpf_t OP1, unsigned long int OP2)
309: - Function: int mpf_cmp_si (mpf_t OP1, signed long int OP2)
310: Compare OP1 and OP2. Return a positive value if OP1 > OP2, zero
311: if OP1 = OP2, and a negative value if OP1 < OP2.
312:
313: - Function: int mpf_eq (mpf_t OP1, mpf_t OP2, unsigned long int op3)
314: Return non-zero if the first OP3 bits of OP1 and OP2 are equal,
315: zero otherwise. I.e., test of OP1 and OP2 are approximately equal.
316:
317: - Function: void mpf_reldiff (mpf_t ROP, mpf_t OP1, mpf_t OP2)
318: Compute the relative difference between OP1 and OP2 and store the
319: result in ROP.
320:
321: - Macro: int mpf_sgn (mpf_t OP)
322: Return +1 if OP > 0, 0 if OP = 0, and -1 if OP < 0.
323:
324: This function is actually implemented as a macro. It evaluates its
325: arguments multiple times.
326:
327:
328: File: gmp.info, Node: I/O of Floats, Next: Miscellaneous Float Functions, Prev: Float Comparison, Up: Floating-point Functions
329:
330: Input and Output Functions
331: ==========================
332:
333: Functions that perform input from a stdio stream, and functions that
334: output to a stdio stream. Passing a NULL pointer for a STREAM argument
335: to any of these functions will make them read from `stdin' and write to
336: `stdout', respectively.
337:
338: When using any of these functions, it is a good idea to include
339: `stdio.h' before `gmp.h', since that will allow `gmp.h' to define
340: prototypes for these functions.
341:
342: - Function: size_t mpf_out_str (FILE *STREAM, int BASE, size_t
343: N_DIGITS, mpf_t OP)
344: Output OP on stdio stream STREAM, as a string of digits in base
345: BASE. The base may vary from 2 to 36. Print at most N_DIGITS
346: significant digits, or if N_DIGITS is 0, the maximum number of
347: digits accurately representable by OP.
348:
349: In addition to the significant digits, a leading `0.' and a
350: trailing exponent, in the form `eNNN', are printed. If BASE is
351: greater than 10, `@' will be used instead of `e' as exponent
352: delimiter.
353:
354: Return the number of bytes written, or if an error occurred,
355: return 0.
356:
357: - Function: size_t mpf_inp_str (mpf_t ROP, FILE *STREAM, int BASE)
358: Input a string in base BASE from stdio stream STREAM, and put the
359: read float in ROP. The string is of the form `M@N' or, if the
360: base is 10 or less, alternatively `MeN'. `M' is the mantissa and
361: `N' is the exponent. The mantissa is always in the specified
362: base. The exponent is either in the specified base or, if BASE is
363: negative, in decimal.
364:
365: The argument BASE may be in the ranges 2 to 36, or -36 to -2.
366: Negative values are used to specify that the exponent is in
367: decimal.
368:
369: Unlike the corresponding `mpz' function, the base will not be
370: determined from the leading characters of the string if BASE is 0.
371: This is so that numbers like `0.23' are not interpreted as octal.
372:
373: Return the number of bytes read, or if an error occurred, return 0.
374:
375:
376: File: gmp.info, Node: Miscellaneous Float Functions, Prev: I/O of Floats, Up: Floating-point Functions
377:
378: Miscellaneous Functions
379: =======================
380:
381: - Function: void mpf_random2 (mpf_t ROP, mp_size_t MAX_SIZE, mp_exp_t
382: MAX_EXP)
383: Generate a random float of at most MAX_SIZE limbs, with long
384: strings of zeros and ones in the binary representation. The
385: exponent of the number is in the interval -EXP to EXP. This
386: function is useful for testing functions and algorithms, since
387: this kind of random numbers have proven to be more likely to
388: trigger corner-case bugs. Negative random numbers are generated
389: when MAX_SIZE is negative.
390:
391:
392: File: gmp.info, Node: Low-level Functions, Next: BSD Compatible Functions, Prev: Floating-point Functions, Up: Top
393:
394: Low-level Functions
395: *******************
396:
397: This chapter describes low-level MP functions, used to implement the
398: high-level MP functions, but also intended for time-critical user code.
399:
400: These functions start with the prefix `mpn_'.
401:
402: The `mpn' functions are designed to be as fast as possible, *not* to
403: provide a coherent calling interface. The different functions have
404: somewhat similar interfaces, but there are variations that make them
405: hard to use. These functions do as little as possible apart from the
406: real multiple precision computation, so that no time is spent on things
407: that not all callers need.
408:
409: A source operand is specified by a pointer to the least significant
410: limb and a limb count. A destination operand is specified by just a
411: pointer. It is the responsibility of the caller to ensure that the
412: destination has enough space for storing the result.
413:
414: With this way of specifying operands, it is possible to perform
415: computations on subranges of an argument, and store the result into a
416: subrange of a destination.
417:
418: A common requirement for all functions is that each source area
419: needs at least one limb. No size argument may be zero.
420:
421: The `mpn' functions is the base for the implementation of the `mpz_',
422: `mpf_', and `mpq_' functions.
423:
424: This example adds the number beginning at SRC1_PTR and the number
425: beginning at SRC2_PTR and writes the sum at DEST_PTR. All areas have
426: SIZE limbs.
427:
428: cy = mpn_add_n (dest_ptr, src1_ptr, src2_ptr, size)
429:
430: In the notation used here, a source operand is identified by the
431: pointer to the least significant limb, and the limb count in braces.
432: For example, {s1_ptr, s1_size}.
433:
434: - Function: mp_limb_t mpn_add_n (mp_limb_t * DEST_PTR, const mp_limb_t
435: * SRC1_PTR, const mp_limb_t * SRC2_PTR, mp_size_t SIZE)
436: Add {SRC1_PTR, SIZE} and {SRC2_PTR, SIZE}, and write the SIZE
437: least significant limbs of the result to DEST_PTR. Return carry,
438: either 0 or 1.
439:
440: This is the lowest-level function for addition. It is the
441: preferred function for addition, since it is written in assembly
442: for most targets. For addition of a variable to itself (i.e.,
443: SRC1_PTR equals SRC2_PTR, use `mpn_lshift' with a count of 1 for
444: optimal speed.
445:
446: - Function: mp_limb_t mpn_add_1 (mp_limb_t * DEST_PTR, const mp_limb_t
447: * SRC1_PTR, mp_size_t SIZE, mp_limb_t SRC2_LIMB)
448: Add {SRC1_PTR, SIZE} and SRC2_LIMB, and write the SIZE least
449: significant limbs of the result to DEST_PTR. Return carry, either
450: 0 or 1.
451:
452: - Function: mp_limb_t mpn_add (mp_limb_t * DEST_PTR, const mp_limb_t *
453: SRC1_PTR, mp_size_t SRC1_SIZE, const mp_limb_t * SRC2_PTR,
454: mp_size_t SRC2_SIZE)
455: Add {SRC1_PTR, SRC1_SIZE} and {SRC2_PTR, SRC2_SIZE}, and write the
456: SRC1_SIZE least significant limbs of the result to DEST_PTR.
457: Return carry, either 0 or 1.
458:
459: This function requires that SRC1_SIZE is greater than or equal to
460: SRC2_SIZE.
461:
462: - Function: mp_limb_t mpn_sub_n (mp_limb_t * DEST_PTR, const mp_limb_t
463: * SRC1_PTR, const mp_limb_t * SRC2_PTR, mp_size_t SIZE)
464: Subtract {SRC2_PTR, SRC2_SIZE} from {SRC1_PTR, SIZE}, and write
465: the SIZE least significant limbs of the result to DEST_PTR.
466: Return borrow, either 0 or 1.
467:
468: This is the lowest-level function for subtraction. It is the
469: preferred function for subtraction, since it is written in
470: assembly for most targets.
471:
472: - Function: mp_limb_t mpn_sub_1 (mp_limb_t * DEST_PTR, const mp_limb_t
473: * SRC1_PTR, mp_size_t SIZE, mp_limb_t SRC2_LIMB)
474: Subtract SRC2_LIMB from {SRC1_PTR, SIZE}, and write the SIZE least
475: significant limbs of the result to DEST_PTR. Return borrow,
476: either 0 or 1.
477:
478: - Function: mp_limb_t mpn_sub (mp_limb_t * DEST_PTR, const mp_limb_t *
479: SRC1_PTR, mp_size_t SRC1_SIZE, const mp_limb_t * SRC2_PTR,
480: mp_size_t SRC2_SIZE)
481: Subtract {SRC2_PTR, SRC2_SIZE} from {SRC1_PTR, SRC1_SIZE}, and
482: write the SRC1_SIZE least significant limbs of the result to
483: DEST_PTR. Return borrow, either 0 or 1.
484:
485: This function requires that SRC1_SIZE is greater than or equal to
486: SRC2_SIZE.
487:
488: - Function: void mpn_mul_n (mp_limb_t * DEST_PTR, const mp_limb_t *
489: SRC1_PTR, const mp_limb_t * SRC2_PTR, mp_size_t SIZE)
490: Multiply {SRC1_PTR, SIZE} and {SRC2_PTR, SIZE}, and write the
491: *entire* result to DEST_PTR.
492:
493: The destination has to have space for 2SIZE limbs, even if the
494: significant result might be one limb smaller.
495:
496: - Function: mp_limb_t mpn_mul_1 (mp_limb_t * DEST_PTR, const mp_limb_t
497: * SRC1_PTR, mp_size_t SIZE, mp_limb_t SRC2_LIMB)
498: Multiply {SRC1_PTR, SIZE} and SRC2_LIMB, and write the SIZE least
499: significant limbs of the product to DEST_PTR. Return the most
500: significant limb of the product.
501:
502: This is a low-level function that is a building block for general
503: multiplication as well as other operations in MP. It is written
504: in assembly for most targets.
505:
506: Don't call this function if SRC2_LIMB is a power of 2; use
507: `mpn_lshift' with a count equal to the logarithm of SRC2_LIMB
508: instead, for optimal speed.
509:
510: - Function: mp_limb_t mpn_addmul_1 (mp_limb_t * DEST_PTR, const
511: mp_limb_t * SRC1_PTR, mp_size_t SIZE, mp_limb_t SRC2_LIMB)
512: Multiply {SRC1_PTR, SIZE} and SRC2_LIMB, and add the SIZE least
513: significant limbs of the product to {DEST_PTR, SIZE} and write the
514: result to DEST_PTR DEST_PTR. Return the most significant limb of
515: the product, plus carry-out from the addition.
516:
517: This is a low-level function that is a building block for general
518: multiplication as well as other operations in MP. It is written
519: in assembly for most targets.
520:
521: - Function: mp_limb_t mpn_submul_1 (mp_limb_t * DEST_PTR, const
522: mp_limb_t * SRC1_PTR, mp_size_t SIZE, mp_limb_t SRC2_LIMB)
523: Multiply {SRC1_PTR, SIZE} and SRC2_LIMB, and subtract the SIZE
524: least significant limbs of the product from {DEST_PTR, SIZE} and
525: write the result to DEST_PTR. Return the most significant limb of
526: the product, minus borrow-out from the subtraction.
527:
528: This is a low-level function that is a building block for general
529: multiplication and division as well as other operations in MP. It
530: is written in assembly for most targets.
531:
532: - Function: mp_limb_t mpn_mul (mp_limb_t * DEST_PTR, const mp_limb_t *
533: SRC1_PTR, mp_size_t SRC1_SIZE, const mp_limb_t * SRC2_PTR,
534: mp_size_t SRC2_SIZE)
535: Multiply {SRC1_PTR, SRC1_SIZE} and {SRC2_PTR, SRC2_SIZE}, and
536: write the result to DEST_PTR. Return the most significant limb of
537: the result.
538:
539: The destination has to have space for SRC1_SIZE + SRC1_SIZE limbs,
540: even if the result might be one limb smaller.
541:
542: This function requires that SRC1_SIZE is greater than or equal to
543: SRC2_SIZE. The destination must be distinct from either input
544: operands.
545:
546: - Function: mp_size_t mpn_divrem (mp_limb_t * R1P, mp_size_t XSIZE,
547: mp_limb_t * RS2P, mp_size_t RS2SIZE, const mp_limb_t * S3P,
548: mp_size_t S3SIZE)
549: Divide {RS2P, RS2SIZE} by {S3P, S3SIZE}, and write the quotient at
550: R1P, with the exception of the most significant limb, which is
551: returned. The remainder replaces the dividend at RS2P.
552:
553: In addition to an integer quotient, XSIZE fraction limbs are
554: developed, and stored after the integral limbs. For most usages,
555: XSIZE will be zero.
556:
557: It is required that RS2SIZE is greater than or equal to S3SIZE.
558: It is required that the most significant bit of the divisor is set.
559:
560: If the quotient is not needed, pass RS2P + S3SIZE as R1P. Aside
561: from that special case, no overlap between arguments is permitted.
562:
563: Return the most significant limb of the quotient, either 0 or 1.
564:
565: The area at R1P needs to be RS2SIZE - S3SIZE + XSIZE limbs large.
566:
567: - Function: mp_limb_t mpn_divrem_1 (mp_limb_t * R1P, mp_size_t XSIZE,
568: mp_limb_t * S2P, mp_size_t S2SIZE, mp_limb_t S3LIMB)
569: Divide {S2P, S2SIZE} by S3LIMB, and write the quotient at R1P.
570: Return the remainder.
571:
572: In addition to an integer quotient, XSIZE fraction limbs are
573: developed, and stored after the integral limbs. For most usages,
574: XSIZE will be zero.
575:
576: The areas at R1P and S2P have to be identical or completely
577: separate, not partially overlapping.
578:
579: - Function: mp_size_t mpn_divmod (mp_limb_t * R1P, mp_limb_t * RS2P,
580: mp_size_t RS2SIZE, const mp_limb_t * S3P, mp_size_t S3SIZE)
581: *This interface is obsolete. It will disappear from future
582: releases. Use `mpn_divrem' in its stead.*
583:
584: - Function: mp_limb_t mpn_divmod_1 (mp_limb_t * R1P, mp_limb_t * S2P,
585: mp_size_t S2SIZE, mp_limb_t S3LIMB)
586: *This interface is obsolete. It will disappear from future
587: releases. Use `mpn_divrem_1' in its stead.*
588:
589: - Function: mp_limb_t mpn_mod_1 (mp_limb_t * S1P, mp_size_t S1SIZE,
590: mp_limb_t S2LIMB)
591: Divide {S1P, S1SIZE} by S2LIMB, and return the remainder.
592:
593: - Function: mp_limb_t mpn_preinv_mod_1 (mp_limb_t * S1P, mp_size_t
594: S1SIZE, mp_limb_t S2LIMB, mp_limb_t S3LIMB)
595: *This interface is obsolete. It will disappear from future
596: releases. Use `mpn_mod_1' in its stead.*
597:
598: - Function: mp_limb_t mpn_bdivmod (mp_limb_t * DEST_PTR, mp_limb_t *
599: S1P, mp_size_t S1SIZE, const mp_limb_t * S2P, mp_size_t
600: S2SIZE, unsigned long int D)
601: The function puts the low [D/BITS_PER_MP_LIMB] limbs of Q = {S1P,
602: S1SIZE}/{S2P, S2SIZE} mod 2^D at DEST_PTR, and returns the high D
603: mod BITS_PER_MP_LIMB bits of Q.
604:
605: {S1P, S1SIZE} - Q * {S2P, S2SIZE} mod 2^(S1SIZE*BITS_PER_MP_LIMB)
606: is placed at S1P. Since the low [D/BITS_PER_MP_LIMB] limbs of
607: this difference are zero, it is possible to overwrite the low
608: limbs at S1P with this difference, provided DEST_PTR <= S1P.
609:
610: This function requires that S1SIZE * BITS_PER_MP_LIMB >= D, and
611: that {S2P, S2SIZE} is odd.
612:
613: *This interface is preliminary. It might change incompatibly in
614: future revisions.*
615:
616: - Function: mp_limb_t mpn_lshift (mp_limb_t * DEST_PTR, const
617: mp_limb_t * SRC_PTR, mp_size_t SRC_SIZE, unsigned long int
618: COUNT)
619: Shift {SRC_PTR, SRC_SIZE} COUNT bits to the left, and write the
620: SRC_SIZE least significant limbs of the result to DEST_PTR. COUNT
621: might be in the range 1 to n - 1, on an n-bit machine. The bits
622: shifted out to the left are returned.
623:
624: Overlapping of the destination space and the source space is
625: allowed in this function, provided DEST_PTR >= SRC_PTR.
626:
627: This function is written in assembly for most targets.
628:
629: - Function: mp_limp_t mpn_rshift (mp_limb_t * DEST_PTR, const
630: mp_limb_t * SRC_PTR, mp_size_t SRC_SIZE, unsigned long int
631: COUNT)
632: Shift {SRC_PTR, SRC_SIZE} COUNT bits to the right, and write the
633: SRC_SIZE most significant limbs of the result to DEST_PTR. COUNT
634: might be in the range 1 to n - 1, on an n-bit machine. The bits
635: shifted out to the right are returned.
636:
637: Overlapping of the destination space and the source space is
638: allowed in this function, provided DEST_PTR <= SRC_PTR.
639:
640: This function is written in assembly for most targets.
641:
642: - Function: int mpn_cmp (const mp_limb_t * SRC1_PTR, const mp_limb_t *
643: SRC2_PTR, mp_size_t SIZE)
644: Compare {SRC1_PTR, SIZE} and {SRC2_PTR, SIZE} and return a
645: positive value if src1 > src2, 0 of they are equal, and a negative
646: value if src1 < src2.
647:
648: - Function: mp_size_t mpn_gcd (mp_limb_t * DEST_PTR, mp_limb_t *
649: SRC1_PTR, mp_size_t SRC1_SIZE, mp_limb_t * SRC2_PTR,
650: mp_size_t SRC2_SIZE)
651: Puts at DEST_PTR the greatest common divisor of {SRC1_PTR,
652: SRC1_SIZE} and {SRC2_PTR, SRC2_SIZE}; both source operands are
653: destroyed by the operation. The size in limbs of the greatest
654: common divisor is returned.
655:
656: {SRC1_PTR, SRC1_SIZE} must be odd, and {SRC2_PTR, SRC2_SIZE} must
657: have at least as many bits as {SRC1_PTR, SRC1_SIZE}.
658:
659: *This interface is preliminary. It might change incompatibly in
660: future revisions.*
661:
662: - Function: mp_limb_t mpn_gcd_1 (const mp_limb_t * SRC1_PTR, mp_size_t
663: SRC1_SIZE, mp_limb_t SRC2_LIMB)
664: Return the greatest common divisor of {SRC1_PTR, SRC1_SIZE} and
665: SRC2_LIMB, where SRC2_LIMB (as well as SRC1_SIZE) must be
666: different from 0.
667:
668: - Function: mp_size_t mpn_gcdext (mp_limb_t * R1P, mp_limb_t * R2P,
669: mp_limb_t * S1P, mp_size_t S1SIZE, mp_limb_t * S2P, mp_size_t
670: S2SIZE)
671: Puts at R1P the greatest common divisor of {S1P, S1SIZE} and {S2P,
672: S2SIZE}. The first cofactor is written at R2P. Both source
673: operands are destroyed by the operation. The size in limbs of the
674: greatest common divisor is returned.
675:
676: *This interface is preliminary. It might change incompatibly in
677: future revisions.*
678:
679: - Function: mp_size_t mpn_sqrtrem (mp_limb_t * R1P, mp_limb_t * R2P,
680: const mp_limb_t * SP, mp_size_t SIZE)
681: Compute the square root of {SP, SIZE} and put the result at R1P.
682: Write the remainder at R2P, unless R2P is NULL.
683:
684: Return the size of the remainder, whether R2P was NULL or non-NULL.
685: Iff the operand was a perfect square, the return value will be 0.
686:
687: The areas at R1P and SP have to be distinct. The areas at R2P and
688: SP have to be identical or completely separate, not partially
689: overlapping.
690:
691: The area at R1P needs to have space for ceil(SIZE/2) limbs. The
692: area at R2P needs to be SIZE limbs large.
693:
694: *This interface is preliminary. It might change incompatibly in
695: future revisions.*
696:
697: - Function: mp_size_t mpn_get_str (unsigned char *STR, int BASE,
698: mp_limb_t * S1P, mp_size_t S1SIZE)
699: Convert {S1P, S1SIZE} to a raw unsigned char array in base BASE.
700: The string is not in ASCII; to convert it to printable format, add
701: the ASCII codes for `0' or `A', depending on the base and range.
702: There may be leading zeros in the string.
703:
704: The area at S1P is clobbered.
705:
706: Return the number of characters in STR.
707:
708: The area at STR has to have space for the largest possible number
709: represented by a S1SIZE long limb array, plus one extra character.
710:
711: - Function: mp_size_t mpn_set_str (mp_limb_t * R1P, const char *STR,
712: size_t strsize, int BASE)
713: Convert the raw unsigned char array at STR of length STRSIZE to a
714: limb array {S1P, S1SIZE}. The base of STR is BASE.
715:
716: Return the number of limbs stored in R1P.
717:
718: - Function: unsigned long int mpn_scan0 (const mp_limb_t * S1P,
719: unsigned long int BIT)
720: Scan S1P from bit position BIT for the next clear bit.
721:
722: It is required that there be a clear bit within the area at S1P at
723: or beyond bit position BIT, so that the function has something to
724: return.
725:
726: *This interface is preliminary. It might change incompatibly in
727: future revisions.*
728:
729: - Function: unsigned long int mpn_scan1 (const mp_limb_t * S1P,
730: unsigned long int BIT)
731: Scan S1P from bit position BIT for the next set bit.
732:
733: It is required that there be a set bit within the area at S1P at or
734: beyond bit position BIT, so that the function has something to
735: return.
736:
737: *This interface is preliminary. It might change incompatibly in
738: future revisions.*
739:
740: - Function: void mpn_random2 (mp_limb_t * R1P, mp_size_t R1SIZE)
741: Generate a random number of length R1SIZE with long strings of
742: zeros and ones in the binary representation, and store it at R1P.
743:
744: The generated random numbers are intended for testing the
745: correctness of the implementation of the `mpn' routines.
746:
747: - Function: unsigned long int mpn_popcount (const mp_limb_t * S1P,
748: unsigned long int SIZE)
749: Count the number of set bits in {S1P, SIZE}.
750:
751: - Function: unsigned long int mpn_hamdist (const mp_limb_t * S1P,
752: const mp_limb_t * S2P, unsigned long int SIZE)
753: Compute the hamming distance between {S1P, SIZE} and {S2P, SIZE}.
754:
755: - Function: int mpn_perfect_square_p (const mp_limb_t * S1P, mp_size_t
756: SIZE)
757: Return non-zero iff {S1P, SIZE} is a perfect square.
758:
759:
760: File: gmp.info, Node: BSD Compatible Functions, Next: Custom Allocation, Prev: Low-level Functions, Up: Top
761:
762: Berkeley MP Compatible Functions
763: ********************************
764:
765: These functions are intended to be fully compatible with the
766: Berkeley MP library which is available on many BSD derived U*ix systems.
767:
768: The original Berkeley MP library has a usage restriction: you cannot
769: use the same variable as both source and destination in a single
770: function call. The compatible functions in GNU MP do not share this
771: restriction--inputs and outputs may overlap.
772:
773: It is not recommended that new programs are written using these
774: functions. Apart from the incomplete set of functions, the interface
775: for initializing `MINT' objects is more error prone, and the `pow'
776: function collides with `pow' in `libm.a'.
777:
778: Include the header `mp.h' to get the definition of the necessary
779: types and functions. If you are on a BSD derived system, make sure to
780: include GNU `mp.h' if you are going to link the GNU `libmp.a' to you
781: program. This means that you probably need to give the -I<dir> option
782: to the compiler, where <dir> is the directory where you have GNU `mp.h'.
783:
784: - Function: MINT * itom (signed short int INITIAL_VALUE)
785: Allocate an integer consisting of a `MINT' object and dynamic limb
786: space. Initialize the integer to INITIAL_VALUE. Return a pointer
787: to the `MINT' object.
788:
789: - Function: MINT * xtom (char *INITIAL_VALUE)
790: Allocate an integer consisting of a `MINT' object and dynamic limb
791: space. Initialize the integer from INITIAL_VALUE, a hexadecimal,
792: '\0'-terminate C string. Return a pointer to the `MINT' object.
793:
794: - Function: void move (MINT *SRC, MINT *DEST)
795: Set DEST to SRC by copying. Both variables must be previously
796: initialized.
797:
798: - Function: void madd (MINT *SRC_1, MINT *SRC_2, MINT *DESTINATION)
799: Add SRC_1 and SRC_2 and put the sum in DESTINATION.
800:
801: - Function: void msub (MINT *SRC_1, MINT *SRC_2, MINT *DESTINATION)
802: Subtract SRC_2 from SRC_1 and put the difference in DESTINATION.
803:
804: - Function: void mult (MINT *SRC_1, MINT *SRC_2, MINT *DESTINATION)
805: Multiply SRC_1 and SRC_2 and put the product in DESTINATION.
806:
807: - Function: void mdiv (MINT *DIVIDEND, MINT *DIVISOR, MINT *QUOTIENT,
808: MINT *REMAINDER)
809: - Function: void sdiv (MINT *DIVIDEND, signed short int DIVISOR, MINT
810: *QUOTIENT, signed short int *REMAINDER)
811: Set QUOTIENT to DIVIDEND/DIVISOR, and REMAINDER to DIVIDEND mod
812: DIVISOR. The quotient is rounded towards zero; the remainder has
813: the same sign as the dividend unless it is zero.
814:
815: Some implementations of these functions work differently--or not
816: at all--for negative arguments.
817:
818: - Function: void msqrt (MINT *OPERAND, MINT *ROOT, MINT *REMAINDER)
819: Set ROOT to the truncated integer part of the square root of
820: OPERAND. Set REMAINDER to OPERAND-ROOT*ROOT, (i.e., zero if
821: OPERAND is a perfect square).
822:
823: If ROOT and REMAINDER are the same variable, the results are
824: undefined.
825:
826: - Function: void pow (MINT *BASE, MINT *EXP, MINT *MOD, MINT *DEST)
827: Set DEST to (BASE raised to EXP) modulo MOD.
828:
829: - Function: void rpow (MINT *BASE, signed short int EXP, MINT *DEST)
830: Set DEST to BASE raised to EXP.
831:
832: - Function: void gcd (MINT *OPERAND1, MINT *OPERAND2, MINT *RES)
833: Set RES to the greatest common divisor of OPERAND1 and OPERAND2.
834:
835: - Function: int mcmp (MINT *OPERAND1, MINT *OPERAND2)
836: Compare OPERAND1 and OPERAND2. Return a positive value if
837: OPERAND1 > OPERAND2, zero if OPERAND1 = OPERAND2, and a negative
838: value if OPERAND1 < OPERAND2.
839:
840: - Function: void min (MINT *DEST)
841: Input a decimal string from `stdin', and put the read integer in
842: DEST. SPC and TAB are allowed in the number string, and are
843: ignored.
844:
845: - Function: void mout (MINT *SRC)
846: Output SRC to `stdout', as a decimal string. Also output a
847: newline.
848:
849: - Function: char * mtox (MINT *OPERAND)
850: Convert OPERAND to a hexadecimal string, and return a pointer to
851: the string. The returned string is allocated using the default
852: memory allocation function, `malloc' by default.
853:
854: - Function: void mfree (MINT *OPERAND)
855: De-allocate, the space used by OPERAND. *This function should
856: only be passed a value returned by `itom' or `xtom'.*
857:
858:
859: File: gmp.info, Node: Custom Allocation, Next: Contributors, Prev: BSD Compatible Functions, Up: Top
860:
861: Custom Allocation
862: *****************
863:
864: By default, the MP functions use `malloc', `realloc', and `free' for
865: memory allocation. If `malloc' or `realloc' fails, the MP library
866: terminates execution after printing a fatal error message to standard
867: error.
868:
869: For some applications, you may wish to allocate memory in other
870: ways, or you may not want to have a fatal error when there is no more
871: memory available. To accomplish this, you can specify alternative
872: memory allocation functions.
873:
874: - Function: void mp_set_memory_functions (
875: void *(*ALLOC_FUNC_PTR) (size_t),
876: void *(*REALLOC_FUNC_PTR) (void *, size_t, size_t),
877: void (*FREE_FUNC_PTR) (void *, size_t))
878: Replace the current allocation functions from the arguments. If
879: an argument is NULL, the corresponding default function is
880: retained.
881:
882: *Make sure to call this function in such a way that there are no
883: active MP objects that were allocated using the previously active
884: allocation function! Usually, that means that you have to call
885: this function before any other MP function.*
886:
887: The functions you supply should fit the following declarations:
888:
889: - Function: void * allocate_function (size_t ALLOC_SIZE)
890: This function should return a pointer to newly allocated space
891: with at least ALLOC_SIZE storage units.
892:
893: - Function: void * reallocate_function (void *PTR, size_t OLD_SIZE,
894: size_t NEW_SIZE)
895: This function should return a pointer to newly allocated space of
896: at least NEW_SIZE storage units, after copying at least the first
897: OLD_SIZE storage units from PTR. It should also de-allocate the
898: space at PTR.
899:
900: You can assume that the space at PTR was formerly returned from
901: `allocate_function' or `reallocate_function', for a request for
902: OLD_SIZE storage units.
903:
904: - Function: void deallocate_function (void *PTR, size_t SIZE)
905: De-allocate the space pointed to by PTR.
906:
907: You can assume that the space at PTR was formerly returned from
908: `allocate_function' or `reallocate_function', for a request for
909: SIZE storage units.
910:
911: (A "storage unit" is the unit in which the `sizeof' operator returns
912: the size of an object, normally an 8 bit byte.)
913:
914:
915: File: gmp.info, Node: Contributors, Next: References, Prev: Custom Allocation, Up: Top
916:
917: Contributors
918: ************
919:
920: I would like to thank Gunnar Sjoedin and Hans Riesel for their help
921: with mathematical problems, Richard Stallman for his help with design
922: issues and for revising the first version of this manual, Brian Beuning
923: and Doug Lea for their testing of early versions of the library.
924:
925: John Amanatides of York University in Canada contributed the function
926: `mpz_probab_prime_p'.
927:
928: Paul Zimmermann of Inria sparked the development of GMP 2, with his
929: comparisons between bignum packages.
930:
931: Ken Weber (Kent State University, Universidade Federal do Rio Grande
932: do Sul) contributed `mpz_gcd', `mpz_divexact', `mpn_gcd', and
933: `mpn_bdivmod', partially supported by CNPq (Brazil) grant 301314194-2.
934:
935: Per Bothner of Cygnus Support helped to set up MP to use Cygnus'
936: configure. He has also made valuable suggestions and tested numerous
937: intermediary releases.
938:
939: Joachim Hollman was involved in the design of the `mpf' interface,
940: and in the `mpz' design revisions for version 2.
941:
942: Bennet Yee contributed the functions `mpz_jacobi' and `mpz_legendre'.
943:
944: Andreas Schwab contributed the files `mpn/m68k/lshift.S' and
945: `mpn/m68k/rshift.S'.
946:
947: The development of floating point functions of GNU MP 2, were
948: supported in part by the ESPRIT-BRA (Basic Research Activities) 6846
949: project POSSO (POlynomial System SOlving).
950:
951: GNU MP 2 was finished and released by TMG Datakonsult,
952: Sodermannagatan 5, 116 23 STOCKHOLM, SWEDEN, in cooperation with the
953: IDA Center for Computing Sciences, USA.
954:
955:
956: File: gmp.info, Node: References, Prev: Contributors, Up: Top
957:
958: References
959: **********
960:
961: * Donald E. Knuth, "The Art of Computer Programming", vol 2,
962: "Seminumerical Algorithms", 2nd edition, Addison-Wesley, 1981.
963:
964: * John D. Lipson, "Elements of Algebra and Algebraic Computing", The
965: Benjamin Cummings Publishing Company Inc, 1981.
966:
967: * Richard M. Stallman, "Using and Porting GCC", Free Software
968: Foundation, 1995.
969:
970: * Peter L. Montgomery, "Modular Multiplication Without Trial
971: Division", in Mathematics of Computation, volume 44, number 170,
972: April 1985.
973:
974: * Torbjorn Granlund and Peter L. Montgomery, "Division by Invariant
975: Integers using Multiplication", in Proceedings of the SIGPLAN
976: PLDI'94 Conference, June 1994.
977:
978: * Tudor Jebelean, "An algorithm for exact division", Journal of
979: Symbolic Computation, v. 15, 1993, pp. 169-180.
980:
981: * Kenneth Weber, "The accelerated integer GCD algorithm", ACM
982: Transactions on Mathematical Software, v. 21 (March), 1995, pp.
983: 111-122.
984:
985:
986: File: gmp.info, Node: Concept Index, Up: Top
987:
988: Concept Index
989: *************
990:
991: * Menu:
992:
993: * gmp.h: MP Basics.
994: * mp.h: BSD Compatible Functions.
995: * Arithmetic functions <1>: Float Arithmetic.
996: * Arithmetic functions: Integer Arithmetic.
997: * Bit manipulation functions: Integer Logic and Bit Fiddling.
998: * BSD MP compatible functions: BSD Compatible Functions.
999: * Comparison functions: Float Comparison.
1000: * Conditions for copying GNU MP: Copying.
1001: * Conversion functions <1>: Converting Integers.
1002: * Conversion functions: Converting Floats.
1003: * Copying conditions: Copying.
1004: * Float arithmetic functions: Float Arithmetic.
1005: * Float assignment functions: Assigning Floats.
1006: * Float comparisons functions: Float Comparison.
1007: * Float functions: Floating-point Functions.
1008: * Float input and output functions: I/O of Floats.
1009: * Floating-point functions: Floating-point Functions.
1010: * Floating-point number: MP Basics.
1011: * I/O functions <1>: I/O of Floats.
1012: * I/O functions: I/O of Integers.
1013: * Initialization and assignment functions <1>: Simultaneous Float Init & Assign.
1014: * Initialization and assignment functions: Simultaneous Integer Init & Assign.
1015: * Input functions <1>: I/O of Integers.
1016: * Input functions: I/O of Floats.
1017: * Installation: Installing MP.
1018: * Integer: MP Basics.
1019: * Integer arithmetic functions: Integer Arithmetic.
1020: * Integer assignment functions: Assigning Integers.
1021: * Integer conversion functions: Converting Integers.
1022: * Integer functions: Integer Functions.
1023: * Integer input and output functions: I/O of Integers.
1024: * Limb: MP Basics.
1025: * Logical functions: Integer Logic and Bit Fiddling.
1026: * Low-level functions: Low-level Functions.
1027: * Miscellaneous float functions: Miscellaneous Float Functions.
1028: * Miscellaneous integer functions: Miscellaneous Integer Functions.
1029: * Output functions <1>: I/O of Floats.
1030: * Output functions: I/O of Integers.
1031: * Rational number: MP Basics.
1032: * Rational number functions: Rational Number Functions.
1033: * Reporting bugs: Reporting Bugs.
1034: * User-defined precision: Floating-point Functions.
1035:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>