github.com/aergoio/aergo@v1.3.1/libtool/src/gmp-6.1.2/README (about) 1 Copyright 1991, 1996, 1999, 2000, 2007 Free Software Foundation, Inc. 2 3 This file is part of the GNU MP Library. 4 5 The GNU MP Library is free software; you can redistribute it and/or modify 6 it under the terms of either: 7 8 * the GNU Lesser General Public License as published by the Free 9 Software Foundation; either version 3 of the License, or (at your 10 option) any later version. 11 12 or 13 14 * the GNU General Public License as published by the Free Software 15 Foundation; either version 2 of the License, or (at your option) any 16 later version. 17 18 or both in parallel, as here. 19 20 The GNU MP Library is distributed in the hope that it will be useful, but 21 WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 22 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 23 for more details. 24 25 You should have received copies of the GNU General Public License and the 26 GNU Lesser General Public License along with the GNU MP Library. If not, 27 see https://www.gnu.org/licenses/. 28 29 30 31 32 33 34 THE GNU MP LIBRARY 35 36 37 GNU MP is a library for arbitrary precision arithmetic, operating on signed 38 integers, rational numbers, and floating point numbers. It has a rich set of 39 functions, and the functions have a regular interface. 40 41 GNU MP is designed to be as fast as possible, both for small operands and huge 42 operands. The speed is achieved by using fullwords as the basic arithmetic 43 type, by using fast algorithms, with carefully optimized assembly code for the 44 most common inner loops for lots of CPUs, and by a general emphasis on speed 45 (instead of simplicity or elegance). 46 47 GNU MP is believed to be faster than any other similar library. Its advantage 48 increases with operand sizes for certain operations, since GNU MP in many 49 cases has asymptotically faster algorithms. 50 51 GNU MP is free software and may be freely copied on the terms contained in the 52 files COPYING* (see the manual for information on which license(s) applies to 53 which components of GNU MP). 54 55 56 57 OVERVIEW OF GNU MP 58 59 There are four classes of functions in GNU MP. 60 61 1. Signed integer arithmetic functions (mpz). These functions are intended 62 to be easy to use, with their regular interface. The associated type is 63 `mpz_t'. 64 65 2. Rational arithmetic functions (mpq). For now, just a small set of 66 functions necessary for basic rational arithmetics. The associated type 67 is `mpq_t'. 68 69 3. Floating-point arithmetic functions (mpf). If the C type `double' 70 doesn't give enough precision for your application, declare your 71 variables as `mpf_t' instead, set the precision to any number desired, 72 and call the functions in the mpf class for the arithmetic operations. 73 74 4. Positive-integer, hard-to-use, very low overhead functions are in the 75 mpn class. No memory management is performed. The caller must ensure 76 enough space is available for the results. The set of functions is not 77 regular, nor is the calling interface. These functions accept input 78 arguments in the form of pairs consisting of a pointer to the least 79 significant word, and an integral size telling how many limbs (= words) 80 the pointer points to. 81 82 Almost all calculations, in the entire package, are made by calling these 83 low-level functions. 84 85 For more information on how to use GNU MP, please refer to the documentation. 86 It is composed from the file doc/gmp.texi, and can be displayed on the screen 87 or printed. How to do that, as well how to build the library, is described in 88 the INSTALL file in this directory. 89 90 91 92 REPORTING BUGS 93 94 If you find a bug in the library, please make sure to tell us about it! 95 96 You should first check the GNU MP web pages at https://gmplib.org/, under 97 "Status of the current release". There will be patches for all known serious 98 bugs there. 99 100 Report bugs to gmp-bugs@gmplib.org. What information is needed in a useful bug 101 report is described in the manual. The same address can be used for suggesting 102 modifications and enhancements. 103 104 105 106 107 ---------------- 108 Local variables: 109 mode: text 110 fill-column: 78 111 End: