Go to file
2020-04-08 15:31:30 +01:00
cxx
devel
doc MPIR.Net CompareTo updated to use mpf_cmp_z for mixed float/int comparisons 2019-06-24 17:48:13 -04:00
fft
mpf Corrected mpf_get_2exp_d on Win64 when the exponent in limbs fits in mp_bit_cnt but the exponent in bits (as returned by this API) does not 2019-06-28 12:18:19 -04:00
mpir.net Switched MPIR.Net HugeInt.ToDouble(out exp) method to use mpz_get_2exp_d instead of mpz_get_d_2exp 2019-06-28 14:51:15 -04:00
mpn maintain alignment of mpn/x86_64w assembler code with that in the Linux/GCC repository 2019-11-24 23:20:09 +00:00
mpq
mpz Only add functions mpz_get_2exp_d and mpf_get_2exp_d on Windows 2018-02-27 10:00:55 +00:00
msvc a further attempt to get continuous integration to work 2020-04-08 15:26:18 +01:00
printf
scanf
tests Corrected mpf_get_2exp_d on Win64 when the exponent in limbs fits in mp_bit_cnt but the exponent in bits (as returned by this API) does not 2019-06-28 12:18:19 -04:00
tune add a missing export declaration 2020-03-15 16:51:04 +00:00
.gdbinit
.gitattributes
.gitignore Merge branch 'master' of github.com:wbhart/mpir 2018-02-26 17:20:48 +00:00
.travis.yml add missing macro (and revert test mod of .travis.yml) 2018-02-28 15:12:24 +00:00
acinclude.m4 Split haswell CPUs into separate haswell and haswellavx architectures as was done with skylake 2018-07-13 15:24:17 +02:00
appveyor.yml Merge branch 'master' of github.com:BrianGladman/mpir 2020-04-08 15:31:30 +01:00
assert.c
AUTHORS
autogen.sh
ChangeLog
cl_int.bat
clwrap
compat.c maintain alignment of mpn/x86_64w assembler code with that in the Linux/GCC repository 2019-11-24 23:20:09 +00:00
config.guess
config.in
config.sub
configfsf.guess
configfsf.sub
configure.ac maintain alignment of mpn/x86_64w assembler code with that in the Linux/GCC repository 2019-11-24 23:20:09 +00:00
configure.yasm
COPYING
COPYING.LIB
cpuid.c Split haswell CPUs into separate haswell and haswellavx architectures as was done with skylake 2018-07-13 15:24:17 +02:00
errno.c
extract-dbl.c
gmp-h.in Merge remote-tracking branch 'remotes/origin/brian_master' 2018-09-28 22:35:27 +02:00
gmp-impl.h add a missing export declaration 2020-03-15 16:51:04 +00:00
gpl-2.0.txt
INSTALL Prepare for merge from Brian. 2018-09-28 22:33:19 +02:00
INSTALL.autoconf
invalid.c
lgpl-2.1.txt
longlong_post.h
longlong_pre.h
Makefile.am Merge branch 'master' of github.com:wbhart/mpir 2018-09-28 23:32:34 +01:00
memory.c
mp_bpl.c
mp_clz_tab.c
mp_dv_tab.c
mp_get_fns.c
mp_minv_tab.c
mp_set_fns.c
mpirxx.h Merge remote-tracking branch 'remotes/origin/brian_master' 2018-09-28 22:35:27 +02:00
NEWS
nextprime.c
primesieve.c
randbui.c
randclr.c
randdef.c
randiset.c
randlc2s.c
randlc2x.c
randmt.c
randmt.h
randmts.c
randmui.c
rands.c
randsd.c
randsdui.c
README
strip_fPIC.sh
tal-debug.c
tal-notreent.c
tal-reent.c
version.c
yasm_mac.inc.fat
yasm_mac.inc.nofat
yasm_macwin.inc.fat
yasm_macwin.inc.nofat
ylwrap

Copyright 1991, 1996, 1999, 2000 Free Software Foundation, Inc.

Copyright 2008, 2009 William Hart

This file is part of the MPIR Library.

The MPIR Library is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 3 of the License, or (at your
option) any later version.

The MPIR Library is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
License for more details.

You should have received a copy of the GNU Lesser General Public License
along with the MPIR Library; see the file COPYING.LIB.  If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301, USA.






			THE MPIR LIBRARY

MPIR is a fork of the GNU Multi Precision library (GMP -- see http://gmplib.org)

MPIR is a library for arbitrary precision arithmetic, operating on signed
integers, rational numbers, and floating point numbers.  It has a rich set of
functions, and the functions have a regular interface.

MPIR is designed to be as fast as possible, both for small operands and huge
operands.  The speed is achieved by using fullwords as the basic arithmetic
type, by using fast algorithms, with carefully optimized assembly code for the
most common inner loops for lots of CPUs, and by a general emphasis on speed
(instead of simplicity or elegance).

GMP/MPIR is believed to be faster than any other similar library.  Its advantage
increases with operand sizes for certain operations, since MPIR in many
cases has asymptotically faster algorithms.

MPIR is free software and may be freely copied on the terms contained in the
files COPYING.LIB and COPYING (most of MPIR is under the former, some under
the latter).



			OVERVIEW OF MPIR

There are four classes of functions in MPIR.

 1. Signed integer arithmetic functions (mpz).  These functions are intended
    to be easy to use, with their regular interface.  The associated type is
    `mpz_t'.

 2. Rational arithmetic functions (mpq).  For now, just a small set of
    functions necessary for basic rational arithmetics.  The associated type
    is `mpq_t'.

 3. Floating-point arithmetic functions (mpf).  If the C type `double'
    doesn't give enough precision for your application, declare your
    variables as `mpf_t' instead, set the precision to any number desired,
    and call the functions in the mpf class for the arithmetic operations.

 4. Positive-integer, hard-to-use, very low overhead functions are in the
    mpn class.  No memory management is performed.  The caller must ensure
    enough space is available for the results.  The set of functions is not
    regular, nor is the calling interface.  These functions accept input
    arguments in the form of pairs consisting of a pointer to the least
    significant word, and an integral size telling how many limbs (= words)
    the pointer points to.

    Almost all calculations, in the entire package, are made by calling these
    low-level functions.

For more information on how to use MPIR, please refer to the documentation.
It is composed from the file mpir.texi, and can be displayed on the screen or
printed.  How to do that, as well how to build the library, is described in
the INSTALL file in this directory.



			REPORTING BUGS

If you find a bug in the library, please make sure to tell us about it!

You should first check the MPIR web pages at http://www.mpir.org/. There will 
be patches for all known serious bugs there.

Report bugs to our development list: http://groups.google.com/group/mpir-devel.  
What information is needed in a good bug report is described in the manual.  
The same address can be used for suggesting modifications and enhancements.




----------------
Local variables:
mode: text
fill-column: 78
End: