Initial class construction
This commit is contained in:
26
Git/mingw64/share/doc/mpfr/AUTHORS
Normal file
26
Git/mingw64/share/doc/mpfr/AUTHORS
Normal file
@ -0,0 +1,26 @@
|
||||
Authors of MPFR (in chronological order of initial contribution):
|
||||
|
||||
Guillaume Hanrot Main author
|
||||
Fabrice Rouillier Original version of mul_ui.c, gmp_op.c
|
||||
Paul Zimmermann Main author
|
||||
Sylvie Boldo Original version of agm.c and log.c
|
||||
Jean-Luc Rémy Original version of zeta.c
|
||||
Emmanuel Jeandel Original version of exp3.c, const_pi.c, sincos.c
|
||||
Mathieu Dutour acos.c, asin.c, atan.c and early gamma.c
|
||||
Vincent Lefèvre Main author
|
||||
David Daney Hyperbolic and inverse hyperbolic functions, base-2
|
||||
and base-10 exponential and logarithm, factorial
|
||||
Alain Delplanque Rewritten get_str.c
|
||||
Ludovic Meunier Error function (erf.c)
|
||||
Patrick Pélissier Main author
|
||||
Laurent Fousse Original version of sum.c
|
||||
Damien Stehlé Function mpfr_get_ld_2exp
|
||||
Philippe Théveny Main author
|
||||
Sylvain Chevillard Original version of ai.c
|
||||
Charles Karney mpfr_nrandom and mpfr_erandom functions
|
||||
Fredrik Johansson New version of mpfr_const_euler
|
||||
Mickaël Gastineau MPFRbench program
|
||||
|
||||
The main authors are included in the MPFR mailing-list <mpfr@inria.fr>.
|
||||
This is the preferred way to contact us. For further information, please
|
||||
look at the MPFR web page <https://www.mpfr.org/>.
|
72
Git/mingw64/share/doc/mpfr/BUGS
Normal file
72
Git/mingw64/share/doc/mpfr/BUGS
Normal file
@ -0,0 +1,72 @@
|
||||
Copyright 1999, 2001-2019 Free Software Foundation, Inc.
|
||||
Contributed by the AriC and Caramba projects, INRIA.
|
||||
|
||||
This file is part of the GNU MPFR Library.
|
||||
|
||||
The GNU MPFR 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 GNU MPFR 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 GNU MPFR Library; see the file COPYING.LESSER. If not, see
|
||||
https://www.gnu.org/licenses/ or write to the Free Software Foundation, Inc.,
|
||||
51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
|
||||
##############################################################################
|
||||
|
||||
Known bugs:
|
||||
|
||||
* The overflow/underflow exceptions may be badly handled in some functions;
|
||||
specially when the intermediary internal results have exponent which
|
||||
exceeds the hardware limit (2^30 for a 32 bits CPU, and 2^62 for a 64 bits
|
||||
CPU) or the exact result is close to an overflow/underflow threshold.
|
||||
|
||||
* Under Linux/x86 with the traditional FPU, some functions do not work
|
||||
if the FPU rounding precision has been changed to single (this is a
|
||||
bad practice and should be useless, but one never knows what other
|
||||
software will do).
|
||||
|
||||
* Some functions do not use MPFR_SAVE_EXPO_* macros, thus do not behave
|
||||
correctly in a reduced exponent range.
|
||||
|
||||
* Function hypot gives incorrect result when on the one hand the difference
|
||||
between parameters' exponents is near 2*MPFR_EMAX_MAX and on the other hand
|
||||
the output precision or the precision of the parameter with greatest
|
||||
absolute value is greater than 2*MPFR_EMAX_MAX-4.
|
||||
|
||||
Potential bugs:
|
||||
|
||||
* Possible incorrect results due to internal underflow, which can lead to
|
||||
a huge loss of accuracy while the error analysis doesn't take that into
|
||||
account. If the underflow occurs at the last function call (just before
|
||||
the MPFR_CAN_ROUND), the result should be correct (or MPFR gets into an
|
||||
infinite loop). TODO: check the code and the error analysis.
|
||||
|
||||
* Possible bugs with huge precisions (> 2^30) and a 32-bit ABI, in particular
|
||||
undetected integer overflows. TODO: use the MPFR_ADD_PREC macro.
|
||||
|
||||
* Possible bugs if the chosen exponent range does not allow to represent
|
||||
the range [1/16, 16].
|
||||
|
||||
* Possible infinite loop in some functions for particular cases: when
|
||||
the exact result is an exactly representable number or the middle of
|
||||
consecutive two such numbers. However for non-algebraic functions, it is
|
||||
believed that no such case exists, except the well-known cases like cos(0)=1,
|
||||
exp(0)=1, and so on, and the x^y function when y is an integer or y=1/2^k.
|
||||
|
||||
* The mpfr_set_ld function may be quite slow if the long double type has an
|
||||
exponent of more than 15 bits.
|
||||
|
||||
* mpfr_set_d may give wrong results on some non-IEEE architectures.
|
||||
|
||||
* Error analysis for some functions may be incorrect (out-of-date due
|
||||
to modifications in the code?).
|
||||
|
||||
* Possible use of non-portable feature (pre-C99) of the integer division
|
||||
with negative result.
|
674
Git/mingw64/share/doc/mpfr/COPYING
Normal file
674
Git/mingw64/share/doc/mpfr/COPYING
Normal file
@ -0,0 +1,674 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
Version 3, 29 June 2007
|
||||
|
||||
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The GNU General Public License is a free, copyleft license for
|
||||
software and other kinds of works.
|
||||
|
||||
The licenses for most software and other practical works are designed
|
||||
to take away your freedom to share and change the works. By contrast,
|
||||
the GNU General Public License is intended to guarantee your freedom to
|
||||
share and change all versions of a program--to make sure it remains free
|
||||
software for all its users. We, the Free Software Foundation, use the
|
||||
GNU General Public License for most of our software; it applies also to
|
||||
any other work released this way by its authors. You can apply it to
|
||||
your programs, too.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not
|
||||
price. Our General Public Licenses are designed to make sure that you
|
||||
have the freedom to distribute copies of free software (and charge for
|
||||
them if you wish), that you receive source code or can get it if you
|
||||
want it, that you can change the software or use pieces of it in new
|
||||
free programs, and that you know you can do these things.
|
||||
|
||||
To protect your rights, we need to prevent others from denying you
|
||||
these rights or asking you to surrender the rights. Therefore, you have
|
||||
certain responsibilities if you distribute copies of the software, or if
|
||||
you modify it: responsibilities to respect the freedom of others.
|
||||
|
||||
For example, if you distribute copies of such a program, whether
|
||||
gratis or for a fee, you must pass on to the recipients the same
|
||||
freedoms that you received. You must make sure that they, too, receive
|
||||
or can get the source code. And you must show them these terms so they
|
||||
know their rights.
|
||||
|
||||
Developers that use the GNU GPL protect your rights with two steps:
|
||||
(1) assert copyright on the software, and (2) offer you this License
|
||||
giving you legal permission to copy, distribute and/or modify it.
|
||||
|
||||
For the developers' and authors' protection, the GPL clearly explains
|
||||
that there is no warranty for this free software. For both users' and
|
||||
authors' sake, the GPL requires that modified versions be marked as
|
||||
changed, so that their problems will not be attributed erroneously to
|
||||
authors of previous versions.
|
||||
|
||||
Some devices are designed to deny users access to install or run
|
||||
modified versions of the software inside them, although the manufacturer
|
||||
can do so. This is fundamentally incompatible with the aim of
|
||||
protecting users' freedom to change the software. The systematic
|
||||
pattern of such abuse occurs in the area of products for individuals to
|
||||
use, which is precisely where it is most unacceptable. Therefore, we
|
||||
have designed this version of the GPL to prohibit the practice for those
|
||||
products. If such problems arise substantially in other domains, we
|
||||
stand ready to extend this provision to those domains in future versions
|
||||
of the GPL, as needed to protect the freedom of users.
|
||||
|
||||
Finally, every program is threatened constantly by software patents.
|
||||
States should not allow patents to restrict development and use of
|
||||
software on general-purpose computers, but in those that do, we wish to
|
||||
avoid the special danger that patents applied to a free program could
|
||||
make it effectively proprietary. To prevent this, the GPL assures that
|
||||
patents cannot be used to render the program non-free.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow.
|
||||
|
||||
TERMS AND CONDITIONS
|
||||
|
||||
0. Definitions.
|
||||
|
||||
"This License" refers to version 3 of the GNU General Public License.
|
||||
|
||||
"Copyright" also means copyright-like laws that apply to other kinds of
|
||||
works, such as semiconductor masks.
|
||||
|
||||
"The Program" refers to any copyrightable work licensed under this
|
||||
License. Each licensee is addressed as "you". "Licensees" and
|
||||
"recipients" may be individuals or organizations.
|
||||
|
||||
To "modify" a work means to copy from or adapt all or part of the work
|
||||
in a fashion requiring copyright permission, other than the making of an
|
||||
exact copy. The resulting work is called a "modified version" of the
|
||||
earlier work or a work "based on" the earlier work.
|
||||
|
||||
A "covered work" means either the unmodified Program or a work based
|
||||
on the Program.
|
||||
|
||||
To "propagate" a work means to do anything with it that, without
|
||||
permission, would make you directly or secondarily liable for
|
||||
infringement under applicable copyright law, except executing it on a
|
||||
computer or modifying a private copy. Propagation includes copying,
|
||||
distribution (with or without modification), making available to the
|
||||
public, and in some countries other activities as well.
|
||||
|
||||
To "convey" a work means any kind of propagation that enables other
|
||||
parties to make or receive copies. Mere interaction with a user through
|
||||
a computer network, with no transfer of a copy, is not conveying.
|
||||
|
||||
An interactive user interface displays "Appropriate Legal Notices"
|
||||
to the extent that it includes a convenient and prominently visible
|
||||
feature that (1) displays an appropriate copyright notice, and (2)
|
||||
tells the user that there is no warranty for the work (except to the
|
||||
extent that warranties are provided), that licensees may convey the
|
||||
work under this License, and how to view a copy of this License. If
|
||||
the interface presents a list of user commands or options, such as a
|
||||
menu, a prominent item in the list meets this criterion.
|
||||
|
||||
1. Source Code.
|
||||
|
||||
The "source code" for a work means the preferred form of the work
|
||||
for making modifications to it. "Object code" means any non-source
|
||||
form of a work.
|
||||
|
||||
A "Standard Interface" means an interface that either is an official
|
||||
standard defined by a recognized standards body, or, in the case of
|
||||
interfaces specified for a particular programming language, one that
|
||||
is widely used among developers working in that language.
|
||||
|
||||
The "System Libraries" of an executable work include anything, other
|
||||
than the work as a whole, that (a) is included in the normal form of
|
||||
packaging a Major Component, but which is not part of that Major
|
||||
Component, and (b) serves only to enable use of the work with that
|
||||
Major Component, or to implement a Standard Interface for which an
|
||||
implementation is available to the public in source code form. A
|
||||
"Major Component", in this context, means a major essential component
|
||||
(kernel, window system, and so on) of the specific operating system
|
||||
(if any) on which the executable work runs, or a compiler used to
|
||||
produce the work, or an object code interpreter used to run it.
|
||||
|
||||
The "Corresponding Source" for a work in object code form means all
|
||||
the source code needed to generate, install, and (for an executable
|
||||
work) run the object code and to modify the work, including scripts to
|
||||
control those activities. However, it does not include the work's
|
||||
System Libraries, or general-purpose tools or generally available free
|
||||
programs which are used unmodified in performing those activities but
|
||||
which are not part of the work. For example, Corresponding Source
|
||||
includes interface definition files associated with source files for
|
||||
the work, and the source code for shared libraries and dynamically
|
||||
linked subprograms that the work is specifically designed to require,
|
||||
such as by intimate data communication or control flow between those
|
||||
subprograms and other parts of the work.
|
||||
|
||||
The Corresponding Source need not include anything that users
|
||||
can regenerate automatically from other parts of the Corresponding
|
||||
Source.
|
||||
|
||||
The Corresponding Source for a work in source code form is that
|
||||
same work.
|
||||
|
||||
2. Basic Permissions.
|
||||
|
||||
All rights granted under this License are granted for the term of
|
||||
copyright on the Program, and are irrevocable provided the stated
|
||||
conditions are met. This License explicitly affirms your unlimited
|
||||
permission to run the unmodified Program. The output from running a
|
||||
covered work is covered by this License only if the output, given its
|
||||
content, constitutes a covered work. This License acknowledges your
|
||||
rights of fair use or other equivalent, as provided by copyright law.
|
||||
|
||||
You may make, run and propagate covered works that you do not
|
||||
convey, without conditions so long as your license otherwise remains
|
||||
in force. You may convey covered works to others for the sole purpose
|
||||
of having them make modifications exclusively for you, or provide you
|
||||
with facilities for running those works, provided that you comply with
|
||||
the terms of this License in conveying all material for which you do
|
||||
not control copyright. Those thus making or running the covered works
|
||||
for you must do so exclusively on your behalf, under your direction
|
||||
and control, on terms that prohibit them from making any copies of
|
||||
your copyrighted material outside their relationship with you.
|
||||
|
||||
Conveying under any other circumstances is permitted solely under
|
||||
the conditions stated below. Sublicensing is not allowed; section 10
|
||||
makes it unnecessary.
|
||||
|
||||
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
||||
|
||||
No covered work shall be deemed part of an effective technological
|
||||
measure under any applicable law fulfilling obligations under article
|
||||
11 of the WIPO copyright treaty adopted on 20 December 1996, or
|
||||
similar laws prohibiting or restricting circumvention of such
|
||||
measures.
|
||||
|
||||
When you convey a covered work, you waive any legal power to forbid
|
||||
circumvention of technological measures to the extent such circumvention
|
||||
is effected by exercising rights under this License with respect to
|
||||
the covered work, and you disclaim any intention to limit operation or
|
||||
modification of the work as a means of enforcing, against the work's
|
||||
users, your or third parties' legal rights to forbid circumvention of
|
||||
technological measures.
|
||||
|
||||
4. Conveying Verbatim Copies.
|
||||
|
||||
You may convey verbatim copies of the Program's source code as you
|
||||
receive it, in any medium, provided that you conspicuously and
|
||||
appropriately publish on each copy an appropriate copyright notice;
|
||||
keep intact all notices stating that this License and any
|
||||
non-permissive terms added in accord with section 7 apply to the code;
|
||||
keep intact all notices of the absence of any warranty; and give all
|
||||
recipients a copy of this License along with the Program.
|
||||
|
||||
You may charge any price or no price for each copy that you convey,
|
||||
and you may offer support or warranty protection for a fee.
|
||||
|
||||
5. Conveying Modified Source Versions.
|
||||
|
||||
You may convey a work based on the Program, or the modifications to
|
||||
produce it from the Program, in the form of source code under the
|
||||
terms of section 4, provided that you also meet all of these conditions:
|
||||
|
||||
a) The work must carry prominent notices stating that you modified
|
||||
it, and giving a relevant date.
|
||||
|
||||
b) The work must carry prominent notices stating that it is
|
||||
released under this License and any conditions added under section
|
||||
7. This requirement modifies the requirement in section 4 to
|
||||
"keep intact all notices".
|
||||
|
||||
c) You must license the entire work, as a whole, under this
|
||||
License to anyone who comes into possession of a copy. This
|
||||
License will therefore apply, along with any applicable section 7
|
||||
additional terms, to the whole of the work, and all its parts,
|
||||
regardless of how they are packaged. This License gives no
|
||||
permission to license the work in any other way, but it does not
|
||||
invalidate such permission if you have separately received it.
|
||||
|
||||
d) If the work has interactive user interfaces, each must display
|
||||
Appropriate Legal Notices; however, if the Program has interactive
|
||||
interfaces that do not display Appropriate Legal Notices, your
|
||||
work need not make them do so.
|
||||
|
||||
A compilation of a covered work with other separate and independent
|
||||
works, which are not by their nature extensions of the covered work,
|
||||
and which are not combined with it such as to form a larger program,
|
||||
in or on a volume of a storage or distribution medium, is called an
|
||||
"aggregate" if the compilation and its resulting copyright are not
|
||||
used to limit the access or legal rights of the compilation's users
|
||||
beyond what the individual works permit. Inclusion of a covered work
|
||||
in an aggregate does not cause this License to apply to the other
|
||||
parts of the aggregate.
|
||||
|
||||
6. Conveying Non-Source Forms.
|
||||
|
||||
You may convey a covered work in object code form under the terms
|
||||
of sections 4 and 5, provided that you also convey the
|
||||
machine-readable Corresponding Source under the terms of this License,
|
||||
in one of these ways:
|
||||
|
||||
a) Convey the object code in, or embodied in, a physical product
|
||||
(including a physical distribution medium), accompanied by the
|
||||
Corresponding Source fixed on a durable physical medium
|
||||
customarily used for software interchange.
|
||||
|
||||
b) Convey the object code in, or embodied in, a physical product
|
||||
(including a physical distribution medium), accompanied by a
|
||||
written offer, valid for at least three years and valid for as
|
||||
long as you offer spare parts or customer support for that product
|
||||
model, to give anyone who possesses the object code either (1) a
|
||||
copy of the Corresponding Source for all the software in the
|
||||
product that is covered by this License, on a durable physical
|
||||
medium customarily used for software interchange, for a price no
|
||||
more than your reasonable cost of physically performing this
|
||||
conveying of source, or (2) access to copy the
|
||||
Corresponding Source from a network server at no charge.
|
||||
|
||||
c) Convey individual copies of the object code with a copy of the
|
||||
written offer to provide the Corresponding Source. This
|
||||
alternative is allowed only occasionally and noncommercially, and
|
||||
only if you received the object code with such an offer, in accord
|
||||
with subsection 6b.
|
||||
|
||||
d) Convey the object code by offering access from a designated
|
||||
place (gratis or for a charge), and offer equivalent access to the
|
||||
Corresponding Source in the same way through the same place at no
|
||||
further charge. You need not require recipients to copy the
|
||||
Corresponding Source along with the object code. If the place to
|
||||
copy the object code is a network server, the Corresponding Source
|
||||
may be on a different server (operated by you or a third party)
|
||||
that supports equivalent copying facilities, provided you maintain
|
||||
clear directions next to the object code saying where to find the
|
||||
Corresponding Source. Regardless of what server hosts the
|
||||
Corresponding Source, you remain obligated to ensure that it is
|
||||
available for as long as needed to satisfy these requirements.
|
||||
|
||||
e) Convey the object code using peer-to-peer transmission, provided
|
||||
you inform other peers where the object code and Corresponding
|
||||
Source of the work are being offered to the general public at no
|
||||
charge under subsection 6d.
|
||||
|
||||
A separable portion of the object code, whose source code is excluded
|
||||
from the Corresponding Source as a System Library, need not be
|
||||
included in conveying the object code work.
|
||||
|
||||
A "User Product" is either (1) a "consumer product", which means any
|
||||
tangible personal property which is normally used for personal, family,
|
||||
or household purposes, or (2) anything designed or sold for incorporation
|
||||
into a dwelling. In determining whether a product is a consumer product,
|
||||
doubtful cases shall be resolved in favor of coverage. For a particular
|
||||
product received by a particular user, "normally used" refers to a
|
||||
typical or common use of that class of product, regardless of the status
|
||||
of the particular user or of the way in which the particular user
|
||||
actually uses, or expects or is expected to use, the product. A product
|
||||
is a consumer product regardless of whether the product has substantial
|
||||
commercial, industrial or non-consumer uses, unless such uses represent
|
||||
the only significant mode of use of the product.
|
||||
|
||||
"Installation Information" for a User Product means any methods,
|
||||
procedures, authorization keys, or other information required to install
|
||||
and execute modified versions of a covered work in that User Product from
|
||||
a modified version of its Corresponding Source. The information must
|
||||
suffice to ensure that the continued functioning of the modified object
|
||||
code is in no case prevented or interfered with solely because
|
||||
modification has been made.
|
||||
|
||||
If you convey an object code work under this section in, or with, or
|
||||
specifically for use in, a User Product, and the conveying occurs as
|
||||
part of a transaction in which the right of possession and use of the
|
||||
User Product is transferred to the recipient in perpetuity or for a
|
||||
fixed term (regardless of how the transaction is characterized), the
|
||||
Corresponding Source conveyed under this section must be accompanied
|
||||
by the Installation Information. But this requirement does not apply
|
||||
if neither you nor any third party retains the ability to install
|
||||
modified object code on the User Product (for example, the work has
|
||||
been installed in ROM).
|
||||
|
||||
The requirement to provide Installation Information does not include a
|
||||
requirement to continue to provide support service, warranty, or updates
|
||||
for a work that has been modified or installed by the recipient, or for
|
||||
the User Product in which it has been modified or installed. Access to a
|
||||
network may be denied when the modification itself materially and
|
||||
adversely affects the operation of the network or violates the rules and
|
||||
protocols for communication across the network.
|
||||
|
||||
Corresponding Source conveyed, and Installation Information provided,
|
||||
in accord with this section must be in a format that is publicly
|
||||
documented (and with an implementation available to the public in
|
||||
source code form), and must require no special password or key for
|
||||
unpacking, reading or copying.
|
||||
|
||||
7. Additional Terms.
|
||||
|
||||
"Additional permissions" are terms that supplement the terms of this
|
||||
License by making exceptions from one or more of its conditions.
|
||||
Additional permissions that are applicable to the entire Program shall
|
||||
be treated as though they were included in this License, to the extent
|
||||
that they are valid under applicable law. If additional permissions
|
||||
apply only to part of the Program, that part may be used separately
|
||||
under those permissions, but the entire Program remains governed by
|
||||
this License without regard to the additional permissions.
|
||||
|
||||
When you convey a copy of a covered work, you may at your option
|
||||
remove any additional permissions from that copy, or from any part of
|
||||
it. (Additional permissions may be written to require their own
|
||||
removal in certain cases when you modify the work.) You may place
|
||||
additional permissions on material, added by you to a covered work,
|
||||
for which you have or can give appropriate copyright permission.
|
||||
|
||||
Notwithstanding any other provision of this License, for material you
|
||||
add to a covered work, you may (if authorized by the copyright holders of
|
||||
that material) supplement the terms of this License with terms:
|
||||
|
||||
a) Disclaiming warranty or limiting liability differently from the
|
||||
terms of sections 15 and 16 of this License; or
|
||||
|
||||
b) Requiring preservation of specified reasonable legal notices or
|
||||
author attributions in that material or in the Appropriate Legal
|
||||
Notices displayed by works containing it; or
|
||||
|
||||
c) Prohibiting misrepresentation of the origin of that material, or
|
||||
requiring that modified versions of such material be marked in
|
||||
reasonable ways as different from the original version; or
|
||||
|
||||
d) Limiting the use for publicity purposes of names of licensors or
|
||||
authors of the material; or
|
||||
|
||||
e) Declining to grant rights under trademark law for use of some
|
||||
trade names, trademarks, or service marks; or
|
||||
|
||||
f) Requiring indemnification of licensors and authors of that
|
||||
material by anyone who conveys the material (or modified versions of
|
||||
it) with contractual assumptions of liability to the recipient, for
|
||||
any liability that these contractual assumptions directly impose on
|
||||
those licensors and authors.
|
||||
|
||||
All other non-permissive additional terms are considered "further
|
||||
restrictions" within the meaning of section 10. If the Program as you
|
||||
received it, or any part of it, contains a notice stating that it is
|
||||
governed by this License along with a term that is a further
|
||||
restriction, you may remove that term. If a license document contains
|
||||
a further restriction but permits relicensing or conveying under this
|
||||
License, you may add to a covered work material governed by the terms
|
||||
of that license document, provided that the further restriction does
|
||||
not survive such relicensing or conveying.
|
||||
|
||||
If you add terms to a covered work in accord with this section, you
|
||||
must place, in the relevant source files, a statement of the
|
||||
additional terms that apply to those files, or a notice indicating
|
||||
where to find the applicable terms.
|
||||
|
||||
Additional terms, permissive or non-permissive, may be stated in the
|
||||
form of a separately written license, or stated as exceptions;
|
||||
the above requirements apply either way.
|
||||
|
||||
8. Termination.
|
||||
|
||||
You may not propagate or modify a covered work except as expressly
|
||||
provided under this License. Any attempt otherwise to propagate or
|
||||
modify it is void, and will automatically terminate your rights under
|
||||
this License (including any patent licenses granted under the third
|
||||
paragraph of section 11).
|
||||
|
||||
However, if you cease all violation of this License, then your
|
||||
license from a particular copyright holder is reinstated (a)
|
||||
provisionally, unless and until the copyright holder explicitly and
|
||||
finally terminates your license, and (b) permanently, if the copyright
|
||||
holder fails to notify you of the violation by some reasonable means
|
||||
prior to 60 days after the cessation.
|
||||
|
||||
Moreover, your license from a particular copyright holder is
|
||||
reinstated permanently if the copyright holder notifies you of the
|
||||
violation by some reasonable means, this is the first time you have
|
||||
received notice of violation of this License (for any work) from that
|
||||
copyright holder, and you cure the violation prior to 30 days after
|
||||
your receipt of the notice.
|
||||
|
||||
Termination of your rights under this section does not terminate the
|
||||
licenses of parties who have received copies or rights from you under
|
||||
this License. If your rights have been terminated and not permanently
|
||||
reinstated, you do not qualify to receive new licenses for the same
|
||||
material under section 10.
|
||||
|
||||
9. Acceptance Not Required for Having Copies.
|
||||
|
||||
You are not required to accept this License in order to receive or
|
||||
run a copy of the Program. Ancillary propagation of a covered work
|
||||
occurring solely as a consequence of using peer-to-peer transmission
|
||||
to receive a copy likewise does not require acceptance. However,
|
||||
nothing other than this License grants you permission to propagate or
|
||||
modify any covered work. These actions infringe copyright if you do
|
||||
not accept this License. Therefore, by modifying or propagating a
|
||||
covered work, you indicate your acceptance of this License to do so.
|
||||
|
||||
10. Automatic Licensing of Downstream Recipients.
|
||||
|
||||
Each time you convey a covered work, the recipient automatically
|
||||
receives a license from the original licensors, to run, modify and
|
||||
propagate that work, subject to this License. You are not responsible
|
||||
for enforcing compliance by third parties with this License.
|
||||
|
||||
An "entity transaction" is a transaction transferring control of an
|
||||
organization, or substantially all assets of one, or subdividing an
|
||||
organization, or merging organizations. If propagation of a covered
|
||||
work results from an entity transaction, each party to that
|
||||
transaction who receives a copy of the work also receives whatever
|
||||
licenses to the work the party's predecessor in interest had or could
|
||||
give under the previous paragraph, plus a right to possession of the
|
||||
Corresponding Source of the work from the predecessor in interest, if
|
||||
the predecessor has it or can get it with reasonable efforts.
|
||||
|
||||
You may not impose any further restrictions on the exercise of the
|
||||
rights granted or affirmed under this License. For example, you may
|
||||
not impose a license fee, royalty, or other charge for exercise of
|
||||
rights granted under this License, and you may not initiate litigation
|
||||
(including a cross-claim or counterclaim in a lawsuit) alleging that
|
||||
any patent claim is infringed by making, using, selling, offering for
|
||||
sale, or importing the Program or any portion of it.
|
||||
|
||||
11. Patents.
|
||||
|
||||
A "contributor" is a copyright holder who authorizes use under this
|
||||
License of the Program or a work on which the Program is based. The
|
||||
work thus licensed is called the contributor's "contributor version".
|
||||
|
||||
A contributor's "essential patent claims" are all patent claims
|
||||
owned or controlled by the contributor, whether already acquired or
|
||||
hereafter acquired, that would be infringed by some manner, permitted
|
||||
by this License, of making, using, or selling its contributor version,
|
||||
but do not include claims that would be infringed only as a
|
||||
consequence of further modification of the contributor version. For
|
||||
purposes of this definition, "control" includes the right to grant
|
||||
patent sublicenses in a manner consistent with the requirements of
|
||||
this License.
|
||||
|
||||
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
||||
patent license under the contributor's essential patent claims, to
|
||||
make, use, sell, offer for sale, import and otherwise run, modify and
|
||||
propagate the contents of its contributor version.
|
||||
|
||||
In the following three paragraphs, a "patent license" is any express
|
||||
agreement or commitment, however denominated, not to enforce a patent
|
||||
(such as an express permission to practice a patent or covenant not to
|
||||
sue for patent infringement). To "grant" such a patent license to a
|
||||
party means to make such an agreement or commitment not to enforce a
|
||||
patent against the party.
|
||||
|
||||
If you convey a covered work, knowingly relying on a patent license,
|
||||
and the Corresponding Source of the work is not available for anyone
|
||||
to copy, free of charge and under the terms of this License, through a
|
||||
publicly available network server or other readily accessible means,
|
||||
then you must either (1) cause the Corresponding Source to be so
|
||||
available, or (2) arrange to deprive yourself of the benefit of the
|
||||
patent license for this particular work, or (3) arrange, in a manner
|
||||
consistent with the requirements of this License, to extend the patent
|
||||
license to downstream recipients. "Knowingly relying" means you have
|
||||
actual knowledge that, but for the patent license, your conveying the
|
||||
covered work in a country, or your recipient's use of the covered work
|
||||
in a country, would infringe one or more identifiable patents in that
|
||||
country that you have reason to believe are valid.
|
||||
|
||||
If, pursuant to or in connection with a single transaction or
|
||||
arrangement, you convey, or propagate by procuring conveyance of, a
|
||||
covered work, and grant a patent license to some of the parties
|
||||
receiving the covered work authorizing them to use, propagate, modify
|
||||
or convey a specific copy of the covered work, then the patent license
|
||||
you grant is automatically extended to all recipients of the covered
|
||||
work and works based on it.
|
||||
|
||||
A patent license is "discriminatory" if it does not include within
|
||||
the scope of its coverage, prohibits the exercise of, or is
|
||||
conditioned on the non-exercise of one or more of the rights that are
|
||||
specifically granted under this License. You may not convey a covered
|
||||
work if you are a party to an arrangement with a third party that is
|
||||
in the business of distributing software, under which you make payment
|
||||
to the third party based on the extent of your activity of conveying
|
||||
the work, and under which the third party grants, to any of the
|
||||
parties who would receive the covered work from you, a discriminatory
|
||||
patent license (a) in connection with copies of the covered work
|
||||
conveyed by you (or copies made from those copies), or (b) primarily
|
||||
for and in connection with specific products or compilations that
|
||||
contain the covered work, unless you entered into that arrangement,
|
||||
or that patent license was granted, prior to 28 March 2007.
|
||||
|
||||
Nothing in this License shall be construed as excluding or limiting
|
||||
any implied license or other defenses to infringement that may
|
||||
otherwise be available to you under applicable patent law.
|
||||
|
||||
12. No Surrender of Others' Freedom.
|
||||
|
||||
If conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot convey a
|
||||
covered work so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you may
|
||||
not convey it at all. For example, if you agree to terms that obligate you
|
||||
to collect a royalty for further conveying from those to whom you convey
|
||||
the Program, the only way you could satisfy both those terms and this
|
||||
License would be to refrain entirely from conveying the Program.
|
||||
|
||||
13. Use with the GNU Affero General Public License.
|
||||
|
||||
Notwithstanding any other provision of this License, you have
|
||||
permission to link or combine any covered work with a work licensed
|
||||
under version 3 of the GNU Affero General Public License into a single
|
||||
combined work, and to convey the resulting work. The terms of this
|
||||
License will continue to apply to the part which is the covered work,
|
||||
but the special requirements of the GNU Affero General Public License,
|
||||
section 13, concerning interaction through a network will apply to the
|
||||
combination as such.
|
||||
|
||||
14. Revised Versions of this License.
|
||||
|
||||
The Free Software Foundation may publish revised and/or new versions of
|
||||
the GNU General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to
|
||||
address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the
|
||||
Program specifies that a certain numbered version of the GNU General
|
||||
Public License "or any later version" applies to it, you have the
|
||||
option of following the terms and conditions either of that numbered
|
||||
version or of any later version published by the Free Software
|
||||
Foundation. If the Program does not specify a version number of the
|
||||
GNU General Public License, you may choose any version ever published
|
||||
by the Free Software Foundation.
|
||||
|
||||
If the Program specifies that a proxy can decide which future
|
||||
versions of the GNU General Public License can be used, that proxy's
|
||||
public statement of acceptance of a version permanently authorizes you
|
||||
to choose that version for the Program.
|
||||
|
||||
Later license versions may give you additional or different
|
||||
permissions. However, no additional obligations are imposed on any
|
||||
author or copyright holder as a result of your choosing to follow a
|
||||
later version.
|
||||
|
||||
15. Disclaimer of Warranty.
|
||||
|
||||
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
|
||||
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
|
||||
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
|
||||
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
|
||||
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
|
||||
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
|
||||
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
||||
|
||||
16. Limitation of Liability.
|
||||
|
||||
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
|
||||
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
|
||||
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
|
||||
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
|
||||
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
|
||||
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
|
||||
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
|
||||
SUCH DAMAGES.
|
||||
|
||||
17. Interpretation of Sections 15 and 16.
|
||||
|
||||
If the disclaimer of warranty and limitation of liability provided
|
||||
above cannot be given local legal effect according to their terms,
|
||||
reviewing courts shall apply local law that most closely approximates
|
||||
an absolute waiver of all civil liability in connection with the
|
||||
Program, unless a warranty or assumption of liability accompanies a
|
||||
copy of the Program in return for a fee.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
How to Apply These Terms to Your New Programs
|
||||
|
||||
If you develop a new program, and you want it to be of the greatest
|
||||
possible use to the public, the best way to achieve this is to make it
|
||||
free software which everyone can redistribute and change under these terms.
|
||||
|
||||
To do so, attach the following notices to the program. It is safest
|
||||
to attach them to the start of each source file to most effectively
|
||||
state the exclusion of warranty; and each file should have at least
|
||||
the "copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
Copyright (C) <year> <name of author>
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program 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 General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If the program does terminal interaction, make it output a short
|
||||
notice like this when it starts in an interactive mode:
|
||||
|
||||
<program> Copyright (C) <year> <name of author>
|
||||
This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||
This is free software, and you are welcome to redistribute it
|
||||
under certain conditions; type `show c' for details.
|
||||
|
||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||
parts of the General Public License. Of course, your program's commands
|
||||
might be different; for a GUI interface, you would use an "about box".
|
||||
|
||||
You should also get your employer (if you work as a programmer) or school,
|
||||
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
||||
For more information on this, and how to apply and follow the GNU GPL, see
|
||||
<https://www.gnu.org/licenses/>.
|
||||
|
||||
The GNU General Public License does not permit incorporating your program
|
||||
into proprietary programs. If your program is a subroutine library, you
|
||||
may consider it more useful to permit linking proprietary applications with
|
||||
the library. If this is what you want to do, use the GNU Lesser General
|
||||
Public License instead of this License. But first, please read
|
||||
<https://www.gnu.org/licenses/why-not-lgpl.html>.
|
165
Git/mingw64/share/doc/mpfr/COPYING.LESSER
Normal file
165
Git/mingw64/share/doc/mpfr/COPYING.LESSER
Normal file
@ -0,0 +1,165 @@
|
||||
GNU LESSER GENERAL PUBLIC LICENSE
|
||||
Version 3, 29 June 2007
|
||||
|
||||
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
|
||||
This version of the GNU Lesser General Public License incorporates
|
||||
the terms and conditions of version 3 of the GNU General Public
|
||||
License, supplemented by the additional permissions listed below.
|
||||
|
||||
0. Additional Definitions.
|
||||
|
||||
As used herein, "this License" refers to version 3 of the GNU Lesser
|
||||
General Public License, and the "GNU GPL" refers to version 3 of the GNU
|
||||
General Public License.
|
||||
|
||||
"The Library" refers to a covered work governed by this License,
|
||||
other than an Application or a Combined Work as defined below.
|
||||
|
||||
An "Application" is any work that makes use of an interface provided
|
||||
by the Library, but which is not otherwise based on the Library.
|
||||
Defining a subclass of a class defined by the Library is deemed a mode
|
||||
of using an interface provided by the Library.
|
||||
|
||||
A "Combined Work" is a work produced by combining or linking an
|
||||
Application with the Library. The particular version of the Library
|
||||
with which the Combined Work was made is also called the "Linked
|
||||
Version".
|
||||
|
||||
The "Minimal Corresponding Source" for a Combined Work means the
|
||||
Corresponding Source for the Combined Work, excluding any source code
|
||||
for portions of the Combined Work that, considered in isolation, are
|
||||
based on the Application, and not on the Linked Version.
|
||||
|
||||
The "Corresponding Application Code" for a Combined Work means the
|
||||
object code and/or source code for the Application, including any data
|
||||
and utility programs needed for reproducing the Combined Work from the
|
||||
Application, but excluding the System Libraries of the Combined Work.
|
||||
|
||||
1. Exception to Section 3 of the GNU GPL.
|
||||
|
||||
You may convey a covered work under sections 3 and 4 of this License
|
||||
without being bound by section 3 of the GNU GPL.
|
||||
|
||||
2. Conveying Modified Versions.
|
||||
|
||||
If you modify a copy of the Library, and, in your modifications, a
|
||||
facility refers to a function or data to be supplied by an Application
|
||||
that uses the facility (other than as an argument passed when the
|
||||
facility is invoked), then you may convey a copy of the modified
|
||||
version:
|
||||
|
||||
a) under this License, provided that you make a good faith effort to
|
||||
ensure that, in the event an Application does not supply the
|
||||
function or data, the facility still operates, and performs
|
||||
whatever part of its purpose remains meaningful, or
|
||||
|
||||
b) under the GNU GPL, with none of the additional permissions of
|
||||
this License applicable to that copy.
|
||||
|
||||
3. Object Code Incorporating Material from Library Header Files.
|
||||
|
||||
The object code form of an Application may incorporate material from
|
||||
a header file that is part of the Library. You may convey such object
|
||||
code under terms of your choice, provided that, if the incorporated
|
||||
material is not limited to numerical parameters, data structure
|
||||
layouts and accessors, or small macros, inline functions and templates
|
||||
(ten or fewer lines in length), you do both of the following:
|
||||
|
||||
a) Give prominent notice with each copy of the object code that the
|
||||
Library is used in it and that the Library and its use are
|
||||
covered by this License.
|
||||
|
||||
b) Accompany the object code with a copy of the GNU GPL and this license
|
||||
document.
|
||||
|
||||
4. Combined Works.
|
||||
|
||||
You may convey a Combined Work under terms of your choice that,
|
||||
taken together, effectively do not restrict modification of the
|
||||
portions of the Library contained in the Combined Work and reverse
|
||||
engineering for debugging such modifications, if you also do each of
|
||||
the following:
|
||||
|
||||
a) Give prominent notice with each copy of the Combined Work that
|
||||
the Library is used in it and that the Library and its use are
|
||||
covered by this License.
|
||||
|
||||
b) Accompany the Combined Work with a copy of the GNU GPL and this license
|
||||
document.
|
||||
|
||||
c) For a Combined Work that displays copyright notices during
|
||||
execution, include the copyright notice for the Library among
|
||||
these notices, as well as a reference directing the user to the
|
||||
copies of the GNU GPL and this license document.
|
||||
|
||||
d) Do one of the following:
|
||||
|
||||
0) Convey the Minimal Corresponding Source under the terms of this
|
||||
License, and the Corresponding Application Code in a form
|
||||
suitable for, and under terms that permit, the user to
|
||||
recombine or relink the Application with a modified version of
|
||||
the Linked Version to produce a modified Combined Work, in the
|
||||
manner specified by section 6 of the GNU GPL for conveying
|
||||
Corresponding Source.
|
||||
|
||||
1) Use a suitable shared library mechanism for linking with the
|
||||
Library. A suitable mechanism is one that (a) uses at run time
|
||||
a copy of the Library already present on the user's computer
|
||||
system, and (b) will operate properly with a modified version
|
||||
of the Library that is interface-compatible with the Linked
|
||||
Version.
|
||||
|
||||
e) Provide Installation Information, but only if you would otherwise
|
||||
be required to provide such information under section 6 of the
|
||||
GNU GPL, and only to the extent that such information is
|
||||
necessary to install and execute a modified version of the
|
||||
Combined Work produced by recombining or relinking the
|
||||
Application with a modified version of the Linked Version. (If
|
||||
you use option 4d0, the Installation Information must accompany
|
||||
the Minimal Corresponding Source and Corresponding Application
|
||||
Code. If you use option 4d1, you must provide the Installation
|
||||
Information in the manner specified by section 6 of the GNU GPL
|
||||
for conveying Corresponding Source.)
|
||||
|
||||
5. Combined Libraries.
|
||||
|
||||
You may place library facilities that are a work based on the
|
||||
Library side by side in a single library together with other library
|
||||
facilities that are not Applications and are not covered by this
|
||||
License, and convey such a combined library under terms of your
|
||||
choice, if you do both of the following:
|
||||
|
||||
a) Accompany the combined library with a copy of the same work based
|
||||
on the Library, uncombined with any other library facilities,
|
||||
conveyed under the terms of this License.
|
||||
|
||||
b) Give prominent notice with the combined library that part of it
|
||||
is a work based on the Library, and explaining where to find the
|
||||
accompanying uncombined form of the same work.
|
||||
|
||||
6. Revised Versions of the GNU Lesser General Public License.
|
||||
|
||||
The Free Software Foundation may publish revised and/or new versions
|
||||
of the GNU Lesser General Public License from time to time. Such new
|
||||
versions will be similar in spirit to the present version, but may
|
||||
differ in detail to address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the
|
||||
Library as you received it specifies that a certain numbered version
|
||||
of the GNU Lesser General Public License "or any later version"
|
||||
applies to it, you have the option of following the terms and
|
||||
conditions either of that published version or of any later version
|
||||
published by the Free Software Foundation. If the Library as you
|
||||
received it does not specify a version number of the GNU Lesser
|
||||
General Public License, you may choose any version of the GNU Lesser
|
||||
General Public License ever published by the Free Software Foundation.
|
||||
|
||||
If the Library as you received it specifies that a proxy can decide
|
||||
whether future versions of the GNU Lesser General Public License shall
|
||||
apply, that proxy's public statement of acceptance of any version is
|
||||
permanent authorization for you to choose that version for the
|
||||
Library.
|
391
Git/mingw64/share/doc/mpfr/FAQ.html
Normal file
391
Git/mingw64/share/doc/mpfr/FAQ.html
Normal file
@ -0,0 +1,391 @@
|
||||
<?xml version="1.0" encoding="iso-8859-1"?>
|
||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
|
||||
|
||||
<!--
|
||||
Copyright 2000-2019 Free Software Foundation, Inc.
|
||||
Contributed by the AriC and Caramba projects, INRIA.
|
||||
|
||||
This file is part of the GNU MPFR Library.
|
||||
|
||||
The GNU MPFR 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 GNU MPFR 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 GNU MPFR Library; see the file COPYING.LESSER. If not, see
|
||||
https://www.gnu.org/licenses/ or write to the Free Software Foundation, Inc.,
|
||||
51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
-->
|
||||
|
||||
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
|
||||
|
||||
<head><meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
||||
<title>Frequently Asked Questions about GNU MPFR</title>
|
||||
<style type="text/css">/*<![CDATA[*/
|
||||
/* Global stylesheet for visual media */
|
||||
|
||||
html, body
|
||||
{
|
||||
background: white;
|
||||
color: black;
|
||||
}
|
||||
|
||||
div.logo { float: right }
|
||||
div.logo img { border: 0 }
|
||||
|
||||
div.footer img { border: 0 }
|
||||
|
||||
dt
|
||||
{
|
||||
margin-top: 2ex;
|
||||
margin-bottom: 1ex;
|
||||
font-weight: bolder;
|
||||
}
|
||||
|
||||
/* For testing: dd { background: #ddddff } */
|
||||
|
||||
table { margin: 0.5ex auto }
|
||||
|
||||
li { margin-top: 0.5ex; margin-bottom: 0.5ex }
|
||||
|
||||
dd + dd
|
||||
{
|
||||
margin-top: 0;
|
||||
margin-bottom: 0;
|
||||
padding-top: 0.5ex;
|
||||
padding-bottom: 0;
|
||||
}
|
||||
|
||||
li > p, dd > p
|
||||
{
|
||||
margin-top: 0;
|
||||
margin-bottom: 0;
|
||||
padding-top: 0.5ex;
|
||||
padding-bottom: 0.5ex;
|
||||
}
|
||||
|
||||
.block-code code, code.block-code,
|
||||
.block-code samp, samp.block-code
|
||||
{
|
||||
display: block;
|
||||
padding: 0.5ex 0;
|
||||
margin-left: 2em;
|
||||
}
|
||||
|
||||
.highlight { background: #dddddd }
|
||||
|
||||
.nowrap { white-space: nowrap }
|
||||
|
||||
/*
|
||||
dl.faq { counter-reset: faq }
|
||||
|
||||
dl.faq dt:before
|
||||
{
|
||||
counter-increment: faq;
|
||||
content: counter(faq) ". ";
|
||||
}
|
||||
*/
|
||||
|
||||
dl.faq dt { background: #dddddd }
|
||||
|
||||
dl.faq dd
|
||||
{
|
||||
border-left: 4px solid;
|
||||
border-color: transparent;
|
||||
margin-left: 0em;
|
||||
padding-left: 1.5em;
|
||||
}
|
||||
|
||||
dl.faq dt:target + dd
|
||||
{
|
||||
border-left-color: #aaaaaa;
|
||||
}
|
||||
|
||||
var.env { font-style: normal }
|
||||
/*]]>*/</style>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<h1>Frequently Asked Questions about <cite><acronym>GNU</acronym> <acronym>MPFR</acronym></cite></h1>
|
||||
|
||||
<p><strong>Important notice: Problems with a particular version of
|
||||
<cite><acronym>MPFR</acronym></cite> are discussed in the corresponding
|
||||
bugs page.</strong></p>
|
||||
|
||||
<p>The latest version of this <acronym>FAQ</acronym> is available at
|
||||
<a href="https://www.mpfr.org/faq.html">https://www.mpfr.org/faq.html</a>.
|
||||
Please look at this version if possible.</p>
|
||||
|
||||
<ol>
|
||||
<li><a href="#mpfr_vs_mpf">What are the differences between
|
||||
<cite><acronym>MPF</acronym></cite> from <cite><acronym>GMP</acronym></cite>
|
||||
and <cite><acronym>MPFR</acronym></cite>?</a></li>
|
||||
<li><a href="#mpf2mpfr">How to convert my program written using
|
||||
<cite><acronym>MPF</acronym></cite> to
|
||||
<cite><acronym>MPFR</acronym></cite>?</a></li>
|
||||
<li><a href="#no_libgmp">At configure time, I get the error: <q>libgmp not found or uses a different ABI.</q></a></li>
|
||||
<li><a href="#undef_ref1">I get undefined reference to <code>__gmp_get_memory_functions</code>.</a></li>
|
||||
<li><a href="#undef_ref2">When I link my program with
|
||||
<cite><acronym>MPFR</acronym></cite>, I get undefined reference
|
||||
to <code>__gmpXXXX</code>.</a></li>
|
||||
<li><a href="#crash_high_prec">My program crashes with high precisions.</a></li>
|
||||
<li><a href="#accuracy">Though I have increased the precision, the results
|
||||
are not more accurate.</a></li>
|
||||
<li><a href="#detect_mpfr">How can I detect <cite><acronym>MPFR</acronym></cite>
|
||||
installation using <cite>autoconf</cite> or <cite>pkg-config</cite>?</a></li>
|
||||
<li><a href="#cite">How to cite <cite><acronym>MPFR</acronym></cite> in a
|
||||
scientific publication?</a></li>
|
||||
<li><a href="#fpic">When I build <cite><acronym>MPFR</acronym></cite>, I get
|
||||
an error asking me to recompile with <samp>-fPIC</samp>.</a></li>
|
||||
</ol>
|
||||
|
||||
<dl class="faq">
|
||||
|
||||
<dt id="mpfr_vs_mpf">1. What are the differences between
|
||||
<cite><acronym>MPF</acronym></cite> from <cite><acronym>GMP</acronym></cite>
|
||||
and <cite><acronym>MPFR</acronym></cite>?</dt>
|
||||
|
||||
<dd><p>The main differences are:</p>
|
||||
<ul>
|
||||
<li><p>The precision of a <cite><acronym>MPFR</acronym></cite> variable
|
||||
is the <em>exact</em> number of bits used for its mantissa, whereas in
|
||||
<cite><acronym>MPF</acronym></cite>, the precision requested by the user
|
||||
is a minimum value (<cite><acronym>MPF</acronym></cite> generally uses a
|
||||
higher precision). With the additional difference below, this implies that
|
||||
the <cite><acronym>MPFR</acronym></cite> results do not depend on the
|
||||
number of bits (16, 32, 64 or more) of the underlying architecture.</p></li>
|
||||
<li><p>As a consequence, <cite><acronym>MPFR</acronym></cite> uses a
|
||||
base-2 exponent, whereas in <cite><acronym>MPF</acronym></cite>, this
|
||||
is a base-2<sup>32</sup> or base-2<sup>64</sup> exponent, depending on
|
||||
the limb size. For this reason (and other internal ones), the maximum
|
||||
exponent range in <cite><acronym>MPFR</acronym></cite> is different
|
||||
(and smaller, if the exponent is represented by the same type as in
|
||||
<cite><acronym>MPF</acronym></cite>).</p></li>
|
||||
<li><p><cite><acronym>MPFR</acronym></cite> provides an additional rounding
|
||||
mode argument to its functions; furthermore, it is guaranteed that the
|
||||
result of any operation is the nearest possible floating-point value from
|
||||
the exact result (considering the input variables as exact values), taking
|
||||
into account the precision of the destination variable and the rounding
|
||||
mode. <cite><acronym>MPFR</acronym></cite> also says whether the rounded
|
||||
result is above or below the exact result.</p></li>
|
||||
<li><p><cite><acronym>MPFR</acronym></cite> supports much more functions
|
||||
(in particular transcendental functions such as exponentials, logarithms,
|
||||
trigonometric functions and so on) and special values: signed zeros,
|
||||
infinities, not-a-number (NaN).</p></li>
|
||||
</ul></dd>
|
||||
|
||||
<dt id="mpf2mpfr">2. How to convert my program written using
|
||||
<cite><acronym>MPF</acronym></cite> to
|
||||
<cite><acronym>MPFR</acronym></cite>?</dt>
|
||||
|
||||
<dd><p>You need to add <q><code>r</code></q> to the function names, and to
|
||||
specify the rounding mode (<code>MPFR_RNDN</code> for rounding to nearest,
|
||||
<code>MPFR_RNDZ</code> for rounding toward zero, <code>MPFR_RNDU</code>
|
||||
for rounding toward plus infinity, <code>MPFR_RNDD</code> for rounding
|
||||
toward minus infinity). You can also define macros as follows:
|
||||
<code class="block-code">#define mpf_add(a, b, c) mpfr_add(a, b, c, MPFR_RNDN)</code></p>
|
||||
<p>The header file <samp>mpf2mpfr.h</samp> from the
|
||||
<cite><acronym>MPFR</acronym></cite> distribution automatically
|
||||
redefines all <cite><acronym>MPF</acronym></cite> functions in this
|
||||
way, using the default <cite><acronym>MPFR</acronym></cite> rounding
|
||||
mode. Thus you simply need to add the following line in all your files
|
||||
using <cite><acronym>MPF</acronym></cite> functions:
|
||||
<code class="block-code">#include <mpf2mpfr.h></code>
|
||||
just after the <samp>gmp.h</samp> and <samp>mpfr.h</samp>
|
||||
header files. If the program uses <cite><acronym>MPF</acronym></cite>
|
||||
internals (such as direct access to <code>__mpf_struct</code> members),
|
||||
additional changes will be needed.</p></dd>
|
||||
|
||||
<dt id="no_libgmp">3. At configure time, I get the error: <q>libgmp not found or uses a different ABI.</q></dt>
|
||||
|
||||
<dd><p>This test (<samp>checking for __gmpz_init in -lgmp</samp>) comes
|
||||
after the <samp>gmp.h</samp> detection. The failure occurs either because
|
||||
the <cite><acronym>GMP</acronym></cite> library could not be found
|
||||
(as it is not in the provided library search paths) or because the
|
||||
<cite><acronym>GMP</acronym></cite> library that was found does not have
|
||||
the expected <acronym title="Application Binary Interface">ABI</acronym>
|
||||
(<abbr>e.g.</abbr> 32-bit <abbr>vs</abbr> 64-bit). The former problem can be
|
||||
due to the fact that a static build of <cite><acronym>MPFR</acronym></cite>
|
||||
was requested while only a shared <cite><acronym>GMP</acronym></cite> library
|
||||
is installed (or the opposite, but another error can also show up in this
|
||||
case, see the <a href="#fpic">question about <samp>-fPIC</samp></a>). The
|
||||
latter problem can have several causes:</p>
|
||||
<ul>
|
||||
<li>A wrong libgmp library has been picked up. This can occur if you have
|
||||
several <cite><acronym>GMP</acronym></cite> versions installed on the
|
||||
machine and something is wrong with the provided library search paths.</li>
|
||||
<li>Wrong compiler options (<samp>CFLAGS</samp>) were given. In general, the
|
||||
presence or absence of the <samp>-m64</samp> compiler option must match the
|
||||
library <acronym title="Application Binary Interface">ABI</acronym>.</li>
|
||||
<li>A wrong <samp>gmp.h</samp> file has been picked up (if you have several
|
||||
<cite><acronym>GMP</acronym></cite> versions installed). Indeed, by default,
|
||||
<cite><acronym>MPFR</acronym></cite> gets the compiler options from the
|
||||
<samp>gmp.h</samp> file (with <cite><acronym>GMP</acronym></cite> 4.2.3
|
||||
or later); this is needed because <cite><acronym>GMP</acronym></cite> does
|
||||
not necessarily use the default <acronym>ABI</acronym>. The consequence is
|
||||
that if the <samp>gmp.h</samp> file is associated with a library using a
|
||||
different <acronym>ABI</acronym>, the <acronym>ABI</acronym>-related options
|
||||
will be incorrect. Hence the failure.</li>
|
||||
</ul>
|
||||
<p>Note: The <samp>config.log</samp> output gives more information
|
||||
than the error message. In particular, see the output of the test:
|
||||
<samp>checking for CC and CFLAGS in gmp.h</samp>; it should give you
|
||||
the default compiler options (from <samp>gmp.h</samp>).</p>
|
||||
|
||||
<p>See also the answer to the <a href="#undef_ref1">next question</a>.</p></dd>
|
||||
|
||||
<dt id="undef_ref1">4. I get undefined reference to <code>__gmp_get_memory_functions</code>.</dt>
|
||||
|
||||
<dd><p>Note: this was mainly a problem when upgrading from
|
||||
<cite><acronym>GMP</acronym></cite> 4.1.4 to a later version,
|
||||
but information given below may still be useful in other cases,
|
||||
when several <cite><acronym>GMP</acronym></cite> libraries are
|
||||
installed on the same machine.</p>
|
||||
|
||||
<p>If you get such an error, in particular when running
|
||||
<samp>make check</samp>, then this probably means that you are using
|
||||
the header file from <cite><acronym>GMP</acronym></cite> 4.2.x but the
|
||||
<cite><acronym>GMP</acronym></cite> 4.1.4 library. This can happen if
|
||||
several <cite><acronym>GMP</acronym></cite> versions are installed on
|
||||
your machine (<abbr>e.g.</abbr>, one provided by the system in
|
||||
<samp>/usr/{include,lib}</samp> and a new one installed by the owner or
|
||||
administrator of the machine in <samp>/usr/local/{include,lib}</samp>)
|
||||
and your include and library search paths are inconsistent. On various
|
||||
<acronym>GNU</acronym>/Linux machines, this is unfortunately the case
|
||||
by default (<samp>/usr/local/include</samp> is in the default include
|
||||
search path, but <samp>/usr/local/lib</samp> is <em>not</em> in the
|
||||
default library search path). Typical errors are:
|
||||
<samp class="block-code">undefined reference to `__gmp_get_memory_functions'</samp>
|
||||
in <samp>make check</samp>. The best solution is to add
|
||||
<samp>/usr/local/include</samp> to your <var class="env">C_INCLUDE_PATH</var>
|
||||
environment variable and to add <samp>/usr/local/lib</samp> to your
|
||||
<var class="env">LIBRARY_PATH</var> and <var class="env">LD_LIBRARY_PATH</var>
|
||||
environment variables (and/or <var class="env">LD_RUN_PATH</var>).
|
||||
Alternatively, you can use <samp>--with-gmp*</samp> configure options,
|
||||
<abbr>e.g.</abbr> <samp>--with-gmp=/usr/local</samp>, but <strong>this is
|
||||
not guaranteed to work</strong> (in particular with <samp>gcc</samp> and
|
||||
system directories such as <samp>/usr</samp> or <samp>/usr/local</samp>),
|
||||
and other software that uses <cite><acronym>GMP</acronym></cite> and/or
|
||||
<cite><acronym>MPFR</acronym></cite> will need correct paths too;
|
||||
environment variables allow you to set them in a global way.</p>
|
||||
<p>Other information can be given in the <samp>INSTALL</samp> file and
|
||||
<samp>ld</samp> manual. Please look at them for more details. See also
|
||||
the <a href="#undef_ref2">next question</a>.</p></dd>
|
||||
|
||||
<dt id="undef_ref2">5. When I link my program with
|
||||
<cite><acronym>MPFR</acronym></cite>, I get undefined reference
|
||||
to <code>__gmpXXXX</code>.</dt>
|
||||
|
||||
<dd><p>Link your program with <cite><acronym>GMP</acronym></cite>. Assuming
|
||||
that your program is <samp>foo.c</samp>, you should link it using:
|
||||
<samp class="block-code">cc link.c -lmpfr -lgmp</samp>
|
||||
<cite><acronym>MPFR</acronym></cite> library reference (<samp>-lmpfr</samp>)
|
||||
should be before <cite><acronym>GMP</acronym></cite>'s one
|
||||
(<samp>-lgmp</samp>). Another solution is, with <acronym>GNU</acronym>
|
||||
<samp>ld</samp>, to give all the libraries inside a group:
|
||||
<samp class="block-code">gcc link.c -Wl,--start-group libgmp.a libmpfr.a -Wl,--end-group</samp>
|
||||
See <samp>INSTALL</samp> file and <samp>ld</samp> manual for more
|
||||
details.</p>
|
||||
<p>If you used correct link options, but still get an error, this may mean
|
||||
that your include and library search paths are inconsistent. Please see the
|
||||
<a href="#undef_ref1">previous question</a>.</p></dd>
|
||||
|
||||
<dt id="crash_high_prec">6. My program crashes with high precisions.</dt>
|
||||
|
||||
<dd><p>Your stack size limit may be too small; indeed, by default,
|
||||
<cite><acronym>GMP</acronym></cite> 4.1.4 and below allocates all
|
||||
temporary results on the stack, and in very high precisions, this
|
||||
limit may be reached. You can solve this problem in different ways:</p>
|
||||
<ul>
|
||||
<li><p>You can upgrade to <cite><acronym>GMP</acronym></cite> 4.2 (or above),
|
||||
which now makes temporary allocations on the stack only when they are
|
||||
small.</p></li>
|
||||
<li><p>You can increase the stack size limit with the <samp>limit</samp>,
|
||||
<samp>unlimit</samp> or <samp>ulimit</samp> command, depending on your
|
||||
shell. This may fail on some systems, where the maximum stack size cannot
|
||||
be increased above some value.</p></li>
|
||||
<li><p>You can rebuild both <cite><acronym>GMP</acronym></cite> and
|
||||
<cite><acronym>MPFR</acronym></cite> to use another allocation method.</p></li>
|
||||
</ul></dd>
|
||||
|
||||
<dt id="accuracy">7. Though I have increased the precision, the results
|
||||
are not more accurate.</dt>
|
||||
|
||||
<dd><p>The reason may be the use of C floating-point numbers. If you want
|
||||
to store a floating-point constant to a <code>mpfr_t</code>, you should use
|
||||
<code>mpfr_set_str</code> (or one of the <cite><acronym>MPFR</acronym></cite>
|
||||
constant functions, such as <code>mpfr_const_pi</code> for π) instead
|
||||
of <code>mpfr_set_d</code> or <code>mpfr_set_ld</code>. Otherwise the
|
||||
floating-point constant will be first converted into a reduced-precision
|
||||
(<abbr>e.g.</abbr>, 53-bit) binary number before
|
||||
<cite><acronym>MPFR</acronym></cite> can work with it. This is the case
|
||||
in particular for most exact decimal numbers, such as 0.17, which are
|
||||
not exactly representable in binary.</p>
|
||||
<p>Also remember that <cite><acronym>MPFR</acronym></cite> does not track
|
||||
the accuracy of the results: copying a value <var>x</var> to <var>y</var>
|
||||
with <code>mpfr_set (y, x, MPFR_RNDN)</code> where the variable <var>y</var>
|
||||
is more precise than the variable <var>x</var> will not make it more
|
||||
accurate; the (binary) value will remain unchanged.</p></dd>
|
||||
|
||||
<dt id="detect_mpfr">8. How can I detect <cite><acronym>MPFR</acronym></cite>
|
||||
installation using <cite>autoconf</cite> or <cite>pkg-config</cite>?</dt>
|
||||
|
||||
<dd><p>The <cite><acronym>MPFR</acronym></cite> team does not currently
|
||||
recommend any <cite>autoconf</cite> code, but a section will later
|
||||
be added to the <cite><acronym>MPFR</acronym></cite> manual.
|
||||
Limited <cite>pkg-config</cite> support has been added for
|
||||
<cite><acronym>MPFR</acronym></cite><EFBFBD>4.0.0; example:</p>
|
||||
<pre style="margin-left: 2em">cc myprogram.c $(pkg-config --cflags --libs mpfr)</pre></dd>
|
||||
|
||||
<dt id="cite">9. How to cite <cite><acronym>MPFR</acronym></cite> in a
|
||||
scientific publication?</dt>
|
||||
|
||||
<dd><p>To properly cite <cite><acronym>MPFR</acronym></cite> in a scientific
|
||||
publication, please cite the
|
||||
<a href="https://doi.org/10.1145/1236463.1236468"><acronym title="Association for Computing Machinery">ACM</acronym>
|
||||
<acronym title="Transactions on Mathematical Software">TOMS</acronym>
|
||||
paper</a>
|
||||
and/or the library web page
|
||||
<a href="https://www.mpfr.org/">https://www.mpfr.org</a>. If your publication
|
||||
is related to a particular release of <cite><acronym>MPFR</acronym></cite>,
|
||||
for example if you report timings, please also indicate the release number
|
||||
for future reference.</p></dd>
|
||||
|
||||
<dt id="fpic">10. When I build <cite><acronym>MPFR</acronym></cite>, I get
|
||||
an error asking me to recompile with <samp>-fPIC</samp>.</dt>
|
||||
|
||||
<dd><p>A typical error looks like:</p>
|
||||
<p><tt>/usr/bin/ld: <em>/path/to/</em>libgmp.a(realloc.o): relocation
|
||||
R_X86_64_32 against `.rodata.str1.1' can not be used when making a
|
||||
shared object; recompile with -fPIC<br />
|
||||
<em>/path/to/</em>libgmp.a: could not read symbols: Bad value<br />
|
||||
collect2: ld returned 1 exit status</tt></p>
|
||||
<p>The probable reason is that you tried to build
|
||||
<cite><acronym>MPFR</acronym></cite> with the shared library enabled (this
|
||||
is the default), while only a static <cite><acronym>GMP</acronym></cite>
|
||||
library could be found. To solve this problem, either rebuild and reinstall
|
||||
<cite><acronym>GMP</acronym></cite> without the <samp>--disable-shared</samp>
|
||||
configure option, or configure <cite><acronym>MPFR</acronym></cite> with
|
||||
<samp>--disable-shared</samp>. If you did this and still get the above
|
||||
error, the cause may be conflicting <cite><acronym>GMP</acronym></cite>
|
||||
versions installed on your system; please check that your search path
|
||||
settings are correct.</p>
|
||||
<p>Additional note about the last sentence: Under <acronym>GNU</acronym>/Linux
|
||||
(for instance), the linker takes the first library found in the library search
|
||||
path, whether it is dynamic or static. The default behavior under darwin is
|
||||
different, but <cite><acronym>MPFR</acronym></cite> will change it.</p></dd>
|
||||
<!-- Reference concerning darwin: see MPFR_LD_SEARCH_PATHS_FIRST
|
||||
in MPFR's configure.{ac,in} and acinclude.m4 -->
|
||||
|
||||
</dl>
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
431
Git/mingw64/share/doc/mpfr/NEWS
Normal file
431
Git/mingw64/share/doc/mpfr/NEWS
Normal file
@ -0,0 +1,431 @@
|
||||
Copyright 2000-2019 Free Software Foundation, Inc.
|
||||
Contributed by the AriC and Caramba projects, INRIA.
|
||||
|
||||
This file is part of the GNU MPFR Library.
|
||||
|
||||
The GNU MPFR 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 GNU MPFR 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 GNU MPFR Library; see the file COPYING.LESSER. If not, see
|
||||
https://www.gnu.org/licenses/ or write to the Free Software Foundation, Inc.,
|
||||
51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
|
||||
##############################################################################
|
||||
|
||||
Changes from version 4.0.1 to version 4.0.2:
|
||||
- Corrected minimal GMP version in the INSTALL file and the MPFR manual.
|
||||
- Option -pedantic is now always removed from __GMP_CFLAGS (see INSTALL).
|
||||
- Shared caches: cleanup; really detect lock failures (abort in this case).
|
||||
- Improved MPFR manual. In particular, corrected/completed the
|
||||
mpfr_get_str description in order to follow the historical behavior
|
||||
and GMP's mpf_get_str function.
|
||||
- Bug fixes (see ChangeLog file).
|
||||
|
||||
Changes from version 4.0.0 to version 4.0.1:
|
||||
- Improved MPFR manual.
|
||||
- Improved __GMP_CC and __GMP_CFLAGS retrieval (in particular for MS Windows).
|
||||
- Fixed a build failure on some platforms when --with-gmp-build is used.
|
||||
- Bug fixes (see ChangeLog file), in particular in mpfr_div_ui, which
|
||||
could yield an incorrectly rounded result to nearest when using
|
||||
different precisions; this bug had been present since the introduction
|
||||
of mpfr_div_ui, and in MPFR 4.0.0, it was affecting mpfr_div too.
|
||||
- New: optional "make check-exported-symbols", mainly for the MPFR developers
|
||||
and binary distributions, to check that MPFR does not define symbols with a
|
||||
GMP reserved prefix (experimental).
|
||||
|
||||
Changes from versions 3.1.* to version 4.0.0:
|
||||
- The "dinde aux marrons" release.
|
||||
- MPFR now depends on GMP 5.0+ instead of 4.1+.
|
||||
- API change:
|
||||
Applications that call GMP's mp_set_memory_functions function to change
|
||||
the allocators must first call the new function mpfr_mp_memory_cleanup
|
||||
in all threads where MPFR is potentially used; this new function is
|
||||
currently equivalent to mpfr_free_cache.
|
||||
The reason is that the way memory allocation is done by MPFR has changed
|
||||
(again), so that the current GMP allocators are used (since for some
|
||||
applications, the old allocators may become invalid).
|
||||
Note: Freeing the caches like this might have a performance impact on some
|
||||
particular applications; if this is an issue, this could be handled for a
|
||||
future MPFR version.
|
||||
- Mini-gmp support via the --enable-mini-gmp configure option (experimental).
|
||||
- The minimum precision MPFR_PREC_MIN is now 1, with rounding defined as
|
||||
in the errata of IEEE 754-2008 and in the following IEEE 754 revision
|
||||
(ties rounded away from zero).
|
||||
- Shared caches for multithreaded applications.
|
||||
New function mpfr_free_cache2.
|
||||
- Partial support of MPFR_RNDF (faithful rounding).
|
||||
- New functions: mpfr_fpif_export and mpfr_fpif_import to export and import
|
||||
numbers in a floating-point interchange format, independent both on the
|
||||
number of bits per word and on the endianness.
|
||||
- New function mpfr_fmodquo to return the low bits of the quotient
|
||||
corresponding to mpfr_fmod.
|
||||
- New functions mpfr_flags_clear, mpfr_flags_set, mpfr_flags_test,
|
||||
mpfr_flags_save and mpfr_flags_restore to operate on groups of flags.
|
||||
- New functions mpfr_set_float128 and mpfr_get_float128 to convert from/to
|
||||
the __float128 type (requires --enable-float128 and compiler support).
|
||||
- New functions mpfr_buildopt_float128_p and mpfr_buildopt_sharedcache_p.
|
||||
- New functions mpfr_rint_roundeven and mpfr_roundeven, completing the
|
||||
other similar round-to-integer functions for rounding to nearest with
|
||||
the even-rounding rule.
|
||||
- New macro mpfr_round_nearest_away to add partial emulation of the
|
||||
rounding to nearest-away (as defined in IEEE 754-2008).
|
||||
- New functions mpfr_nrandom and mpfr_erandom to generate random numbers
|
||||
following normal and exponential distributions respectively.
|
||||
- New functions mpfr_fmma and mpfr_fmms to compute a*b+c*d and a*b-c*d.
|
||||
- New function mpfr_rootn_ui, similar to mpfr_root, but agreeing with the
|
||||
rootn function of the IEEE 754-2008 standard.
|
||||
- New functions mpfr_log_ui to compute the logarithm of an integer,
|
||||
mpfr_gamma_inc for the incomplete Gamma function.
|
||||
- New function mpfr_beta for the Beta function (incomplete, experimental).
|
||||
- New function mpfr_get_q to convert a floating-point number into rational.
|
||||
- The mpfr_dump function is now described in the manual; its output format
|
||||
has slightly changed.
|
||||
- The mpfr_eint function now returns the value of the E1/eint1 function
|
||||
for negative argument.
|
||||
- The behavior of the mpfr_set_exp function changed, as it could easily
|
||||
yield undefined behavior in some cases (this modifies both the API and
|
||||
the ABI).
|
||||
- In function mpfr_urandom, the next random state no longer depends on the
|
||||
current exponent range and the rounding mode. The exceptions due to the
|
||||
rounding of the random number are now correctly generated, following the
|
||||
uniform distribution.
|
||||
- Functions mpfr_grandom and mpfr_root are deprecated and will be removed
|
||||
in a future release.
|
||||
- Complete rewrite of function mpfr_sum, which now works in all cases (the
|
||||
old one could take all the memory and/or crash with inputs of different
|
||||
magnitudes in case of huge cancellation or table maker's dilemma). The
|
||||
sign of an exact zero result is now specified, and the return value is
|
||||
now the usual ternary value. Note that the position of "const" in the
|
||||
mpfr_sum prototype has been fixed (the manual was correct); user code
|
||||
should not be affected.
|
||||
- Old, deprecated macros mpfr_add_one_ulp and mpfr_sub_one_ulp removed.
|
||||
The mpfr_next* functions should be used instead.
|
||||
- Internally, improved caching: a minimum of 10% increase of the precision
|
||||
is guaranteed to avoid too many recomputations.
|
||||
- Added internal small-precision mpz_t pool, which aims to avoid the
|
||||
overhead of memory allocation, in particular.
|
||||
New function mpfr_free_pool.
|
||||
- Added configure option --enable-assert=none to avoid checking any assertion.
|
||||
- The --enable-decimal-float configure option no longer requires
|
||||
--with-gmp-build, and support for decimal floats is now automatically
|
||||
detected by default (similarly for support for __float128).
|
||||
- Updated tuning parameters.
|
||||
- Better support for Automake 1.13+ (now used to generate the tarball).
|
||||
- Dropped K&R C compatibility.
|
||||
- Improved MPFR manual.
|
||||
- New MPFRbench program (see the tools/bench directory).
|
||||
- Major speedup in mpfr_add, mpfr_sub, mpfr_mul, mpfr_div and mpfr_sqrt when
|
||||
all operands have the same precision and this precision is less than twice
|
||||
the number of bits per word, e.g., less than 128 on a 64-bit computer.
|
||||
- Speedup by a factor of almost 2 in the double <--> mpfr conversions
|
||||
(mpfr_set_d and mpfr_get_d).
|
||||
- Speedup in mpfr_log1p and mpfr_atanh for small arguments.
|
||||
- Speedup in the mpfr_const_euler function (contributed by Fredrik Johansson),
|
||||
in the computation of Bernoulli numbers (used in mpfr_gamma, mpfr_li2,
|
||||
mpfr_digamma, mpfr_lngamma and mpfr_lgamma), in mpfr_div, in mpfr_fma
|
||||
and mpfr_fms.
|
||||
- Test coverage: 96.3% lines of code.
|
||||
- Bug fixes. In particular: a speed improvement when the --enable-assert
|
||||
or --enable-assert=full configure option is used with GCC; mpfr_get_str
|
||||
now sets the NaN flag on NaN input and the inexact flag when the conversion
|
||||
is inexact. For a full list, see http://www.mpfr.org/mpfr-3.1.6/#fixed
|
||||
and the same section for any previous 3.1.x version (follow the links
|
||||
in the "Changes..." sections).
|
||||
- Microsoft Windows: Added support for thread-safe DLL (shared library).
|
||||
Tested with MinGW, ICC and MSVC.
|
||||
- Limited pkg-config support.
|
||||
- Autotools: Under Linux, make sure that the old dtags (when supported)
|
||||
are used if LD_LIBRARY_PATH is defined; otherwise "make check" would
|
||||
check an installed, compatible MPFR library found in LD_LIBRARY_PATH
|
||||
instead of the one that has been built with "make".
|
||||
- New: optional "make check-gmp-symbols", mainly for binary distributions,
|
||||
to check that MPFR does not use GMP internal symbols (experimental).
|
||||
|
||||
Changes from versions 3.0.* to version 3.1.0:
|
||||
- The "canard à l'orange" release.
|
||||
- The MPFR source has been reorganized.
|
||||
- Dropped ansi2knr support.
|
||||
- TLS support is now detected automatically. If TLS is supported, MPFR is
|
||||
built as thread safe by default. To disable TLS explicitly, configure
|
||||
MPFR with --disable-thread-safe.
|
||||
- New --enable-gmp-internals configure option to use GMP's undocumented
|
||||
functions (not from the public API). Note that library versioning is
|
||||
not guaranteed to work if this option is used.
|
||||
- The mpfr_urandom and mpfr_urandomb functions now return identical values
|
||||
on processors with different word size (assuming the same random seed, and
|
||||
since the GMP random generator does not depend itself on the word size,
|
||||
cf https://gmplib.org/list-archives/gmp-devel/2010-September/001642.html).
|
||||
- The mpfr_add_one_ulp and mpfr_sub_one_ulp macros (which are obsolete and
|
||||
no more documented) will be removed in a future release.
|
||||
- Speed improvement for the mpfr_sqr and mpfr_div functions using Mulders'
|
||||
algorithm. As a consequence, other functions using those routines are
|
||||
also faster.
|
||||
- Much faster formatted output (mpfr_printf, etc.) with %Rg and similar.
|
||||
- The --with-gmp-build configure option can now be used when the GMP
|
||||
source directory and the GMP build directory are different (without
|
||||
having to copy header files manually as before).
|
||||
- New functions mpfr_buildopt_gmpinternals_p, mpfr_buildopt_tune_case,
|
||||
mpfr_frexp, mpfr_grandom and mpfr_z_sub.
|
||||
- New divide-by-zero exception (flag) and associated functions.
|
||||
- The mpfr.h header can be included several times, while still supporting
|
||||
optional functions (see Section "Headers and Libraries" in the manual).
|
||||
- Updated tuning parameters.
|
||||
- Improved MPFR manual.
|
||||
- MPFR tests: libtool no longer generates wrapper scripts with "make check"
|
||||
(so that running the tests under valgrind or gdb is easier).
|
||||
- Internal change: the logging mechanism has been improved.
|
||||
- Test coverage: 95.2% lines of code.
|
||||
- Bug fixes, in particular a huge inefficiency in mpfr_exp (when the
|
||||
target precision is less than MPFR_EXP_THRESHOLD) on hard-to-round
|
||||
cases, which can take several minutes.
|
||||
Note: The mpfr_subnormalize implementation up to MPFR 3.0.0 did not change
|
||||
the flags. In particular, it did not follow the generic rule concerning
|
||||
the inexact flag (and no special behavior was specified). The case of the
|
||||
underflow flag was more a lack of specification.
|
||||
|
||||
Changes from versions 2.4.* to version 3.0.0:
|
||||
- The "boudin aux pommes" release.
|
||||
- MPFR 3.0.0 is binary incompatible with previous versions but (almost)
|
||||
API compatible. More precisely the obsolete functions mpfr_random
|
||||
and mpfr_random2 have been removed, the meaning of the return type
|
||||
of the function mpfr_get_f has changed, and the return type of the
|
||||
function mpfr_get_z is now int instead of void. In practice, this
|
||||
should not break any existing code.
|
||||
- MPFR is now distributed under the GNU Lesser General Public License
|
||||
version 3 or later (LGPL v3+).
|
||||
- Rounding modes GMP_RNDx are now MPFR_RNDx (GMP_RNDx kept for
|
||||
compatibility).
|
||||
- A new rounding mode (MPFR_RNDA) is available to round away from zero.
|
||||
- The rounding mode type is now mpfr_rnd_t (as in previous versions,
|
||||
both mpfr_rnd_t and mp_rnd_t are accepted, but mp_rnd_t may be
|
||||
removed in the future).
|
||||
- The precision type is now mpfr_prec_t (as in previous versions, both
|
||||
mpfr_prec_t and mp_prec_t are accepted, but mp_prec_t may be removed
|
||||
in the future) and it is now signed (it was unsigned in MPFR 2.*, but
|
||||
this was not documented). In practice, this change should not affect
|
||||
existing code that assumed nothing on the precision type.
|
||||
- MPFR now has its own exponent type mpfr_exp_t, which is currently
|
||||
the same as GMP's mp_exp_t.
|
||||
- Functions mpfr_random and mpfr_random2 have been removed.
|
||||
- mpfr_get_f and mpfr_get_z now return a ternary value.
|
||||
- mpfr_strtofr now accepts bases from 37 to 62.
|
||||
- mpfr_custom_get_mantissa was renamed to mpfr_custom_get_significand
|
||||
(mpfr_custom_get_mantissa is still available via a #define).
|
||||
- Functions mpfr_get_si, mpfr_get_ui, mpfr_get_sj, mpfr_get_uj,
|
||||
mpfr_get_z and mpfr_get_z_2exp no longer have cases with undefined
|
||||
behavior; in these cases, the behavior is now specified, and in
|
||||
particular, the erange flag is set.
|
||||
- New functions mpfr_buildopt_tls_p and mpfr_buildopt_decimal_p giving
|
||||
information about options used at MPFR build time.
|
||||
- New function mpfr_regular_p.
|
||||
- New function mpfr_set_zero.
|
||||
- New function mpfr_digamma.
|
||||
- New function mpfr_ai (incomplete, experimental).
|
||||
- New functions mpfr_set_flt and mpfr_get_flt to convert from/to the
|
||||
float type.
|
||||
- New function mpfr_urandom.
|
||||
- New function mpfr_set_z_2exp (companion to mpfr_get_z_2exp, which
|
||||
was renamed from mpfr_get_z_exp in previous versions).
|
||||
- New function mpfr_min_prec.
|
||||
- Speed improvement for large precisions in the trigonometric functions
|
||||
(mpfr_sin, mpfr_cos, mpfr_tan, mpfr_sin_cos): speedup of about 2.5
|
||||
for 10^5 digits, of about 5 for 10^6 digits.
|
||||
- Speed improvement for large precisions of the inverse trigonometric
|
||||
functions (arcsin, arccos, arctan): about 2 for 10^3 digits, up to
|
||||
2.7 for 10^6 digits.
|
||||
- Some documentation files are installed in $docdir.
|
||||
- The detection of a GMP build directory (more precisely, the internal
|
||||
header files of GMP) was previously done separately from the use of
|
||||
the --with-gmp-build configure option. This was not consistent with
|
||||
the documentation and with other parts of the configure script. So,
|
||||
as of MPFR 3.0.0, the internal header files of GMP are now used if
|
||||
and only if the --with-gmp-build configure option is given.
|
||||
- The configure script recognizes some extra "long double" formats
|
||||
(double big endian, double little endian, double-double big endian).
|
||||
- MPFR manual: added "API Compatibility" section.
|
||||
- Test coverage: 97.1% lines of code.
|
||||
- Bug fixes.
|
||||
|
||||
Changes from versions 2.3.* to version 2.4.0:
|
||||
- The "andouillette sauce moutarde" release.
|
||||
- MPFR is now a GNU package.
|
||||
- Changes in the behavior of mpfr_strtofr and in its documentation
|
||||
concerning particular cases where the code and the documentation
|
||||
did not match; this change is also present in MPFR 2.3.1.
|
||||
- Behavior of mpfr_check_range changed: if the value is an inexact
|
||||
infinity, the overflow flag is set (in case it was lost); this
|
||||
change is also present in MPFR 2.3.2.
|
||||
- Function mpfr_init_gmp_rand (only defined when building MPFR without
|
||||
the --with-gmp-build configure option) is no longer defined at all.
|
||||
This function was private and not documented, and was used only in
|
||||
the MPFR test suite. User code that calls it is regarded as broken
|
||||
and may fail as a consequence. Running the old test suite against
|
||||
MPFR 2.4.0 may also fail.
|
||||
- New functions:
|
||||
* between a MPFR number and a double: mpfr_add_d, mpfr_sub_d,
|
||||
mpfr_d_sub, mpfr_mul_d, mpfr_div_d, mpfr_d_div,
|
||||
* formatted input/output:
|
||||
mpfr_printf, mpfr_fprintf, mpfr_vprintf, mpfr_vfprintf,
|
||||
mpfr_sprintf, mpfr_snprintf, mpfr_vsprintf, mpfr_vsnprintf,
|
||||
mpfr_asprintf, mpfr_vasprintf.
|
||||
* mpfr_sinh_cosh, mpfr_li2, mpfr_modf, mpfr_fmod, mpfr_rec_sqrt.
|
||||
- Configure test for TLS support.
|
||||
- Get default $CC and $CFLAGS from gmp.h (__GMP_CC / __GMP_CFLAGS,
|
||||
which are available as of GMP 4.2.3).
|
||||
- Documented the fact that mpfr_random and mpfr_random2 will be
|
||||
suppressed in the next release, and that the specification of
|
||||
mpfr_eq may change in the next release (for compatibility with
|
||||
the mpf layer of GMP).
|
||||
- Test coverage: 96.7% lines of code.
|
||||
- Bug fixes.
|
||||
|
||||
Changes from versions 2.2.* to version 2.3.0:
|
||||
- The mpfr.info file is now installed in the share subdirectory
|
||||
(as required by the Filesystem Hierarchy Standard); see output
|
||||
of "./configure --help".
|
||||
- The shared library is now enabled by default. If the MPFR build
|
||||
fails on your platform, try the --disable-shared configure option
|
||||
to disable the shared library.
|
||||
- Thread-safe support with Microsoft Visual compiler.
|
||||
- New functions mpfr_j0, mpfr_j1, mpfr_jn, mpfr_y0, mpfr_y1, mpfr_yn,
|
||||
mpfr_lgamma, mpfr_remainder, mpfr_remquo, mpfr_fms, mpfr_signbit,
|
||||
mpfr_setsign, mpfr_copysign, mpfr_get_patches.
|
||||
- Functions mpfr_sin, mpfr_cos and mpfr_sin_cos improved (argument
|
||||
reduction).
|
||||
- More detailed MPFR manual.
|
||||
- Improved tests (make check).
|
||||
- Bug fixes.
|
||||
|
||||
Changes from versions 2.1.* to version 2.2.0:
|
||||
- Bug fixes.
|
||||
- new functions mpfr_set_overflow, mpfr_set_underflow, mpfr_set_inexflag,
|
||||
mpfr_set_erangeflag, mpfr_set_nanflag, mpfr_erfc, mpfr_atan2, mpfr_pow_z,
|
||||
mpfr_subnormalize, mpfr_const_catalan, mpfr_sec, mpfr_csc, mpfr_cot,
|
||||
mpfr_root, mpfr_eint, mpfr_get_f, mpfr_sech, mpfr_csch, mpfr_coth,
|
||||
mpfr_lngamma.
|
||||
- new macro: MPFR_VERSION_STRING
|
||||
- Remove the exported MPFR variables from mpfr.h to mpfr-impl.h.
|
||||
(They were undocumented, so programs which respect the API still work).
|
||||
- Grep CC and CFLAGS from GMP Makefile if possible.
|
||||
- Math functions are faster (both average and worst cases).
|
||||
- Better support for long double.
|
||||
- Shared library of MPFR.
|
||||
- Binary compatible with previous versions if you do not use undocumented
|
||||
features.
|
||||
- Thread safe (if built with --enable-thread-safe).
|
||||
- Logging facility.
|
||||
- Change in the semantics of mpfr_out_str/mpfr_get_str when n_digits=0.
|
||||
- Better locale support.
|
||||
|
||||
Changes from version 2.1.0 to version 2.1.1:
|
||||
- Better way to detect the GMP library.
|
||||
- Bug fixes.
|
||||
|
||||
Changes from version 2.0.3 to version 2.1.0:
|
||||
- Bug fixes.
|
||||
- new functions mpfr_strtofr, mpfr_set_uj, mpfr_set_sj, mpfr_set_ui_2exp,
|
||||
mpfr_set_si_2exp, mpfr_set_sj_2exp, mpfr_set_uj_2exp, mpfr_get_uj,
|
||||
mpfr_get_sj, mpfr_get_z, mpfr_free_str, mpfr_si_sub, mpfr_sub_si,
|
||||
mpfr_mul_si, mpfr_si_div, mpfr_div_si, mpfr_sqr, mpfr_cmp_z, mpfr_cmp_q,
|
||||
mpfr_zero_p, mpfr_free_cache, mpfr_sum, mpfr_get_version,
|
||||
mpfr_get_default_rounding_mode, mpfr_get_emin_min, mpfr_get_emin_max,
|
||||
mpfr_get_emax_min, mpfr_get_emax_max, mpfr_inits, mpfr_inits2, mpfr_clears,
|
||||
mpfr_fits_intmax_p, mpfr_fits_uintmax_p, mpfr_clear_erangeflag,
|
||||
mpfr_erangeflag_p, mpfr_rint_round, mpfr_rint_trunc, mpfr_rint_ceil,
|
||||
mpfr_rint_floor.
|
||||
- new macros MPFR_DECL_INIT, MPFR_VERSION, MPFR_VERSION_NUM,
|
||||
MPFR_VERSION_MAJOR, MPFR_VERSION_MINOR, MPFR_VERSION_PATCHLEVEL.
|
||||
- improved documentation.
|
||||
- improved configure.
|
||||
- improved portability (library and test suite).
|
||||
- It handles correctly non IEEE-754 double.
|
||||
- GMP internal files are not needed to install MPFR.
|
||||
- It is faster with low-precision floating point.
|
||||
- New global flag: ERANGE_FLAG.
|
||||
- Binary incompatible with previous versions, but API compatible.
|
||||
- mpfr_set_str doesn't allow anymore "@NAN@garbagechar" and "@INF@garbagechar",
|
||||
allows base 0 (detection of the base), prefix (0x, 0b), leading whitespace.
|
||||
|
||||
Changes from version 2.0.2 to version 2.0.3:
|
||||
- Bug fixes.
|
||||
- Support GMP as a shared library (not fully tested).
|
||||
|
||||
Changes from version 2.0.1 to version 2.0.2:
|
||||
- many bug fixes and other improvements.
|
||||
- new functions mpfr_prec_round (replaces mpfr_round_prec), mpfr_get_exp,
|
||||
mpfr_set_exp, mpfr_get_ld, mpfr_set_ld, mpfr_get_d_2exp, mpfr_get_si,
|
||||
mpfr_get_ui, mpfr_nextabove, mpfr_nextbelow, mpfr_nexttoward, mpfr_frac,
|
||||
mpfr_fits_*, mpfr_cmp_d, mpfr_cmpabs, mpfr_erf, mpfr_gamma, mpfr_zeta,
|
||||
mpfr_greater_p, mpfr_greaterequal_p, mpfr_less_p, mpfr_lessequal_p,
|
||||
mpfr_lessgreater_p, mpfr_equal_p, mpfr_unordered_p.
|
||||
- removed functions: mpfr_print_binary, mpfr_round_prec (replaced by
|
||||
mpfr_prec_round), mpfr_set_str_raw, mpfr_set_machine_rnd_mode.
|
||||
- function mpfr_isinteger renamed mpfr_integer_p.
|
||||
- return type of some functions changed from void to int, for consistency.
|
||||
- return type of mpfr_set_prec changed from int to void.
|
||||
- new values for exponent range.
|
||||
- rename internal variables.
|
||||
|
||||
Changes from version 2001 to version 2.0.1:
|
||||
- new mathematical functions: acos, acosh, asin, asinh, atan, atanh, cosh,
|
||||
base-2 exponential and logarithm, base-10 logarithm, expm1, factorial,
|
||||
pow, pow_si, pow_ui, sinh, tan, tanh, ui_pow, ui_pow_ui
|
||||
- other new functions: mpfr_const_euler, mpfr_dim, mpfr_fma, mpfr_hypot,
|
||||
mpfr_min, mpfr_max, mpfr_rint, mpfr_set_inf, mpfr_set_nan
|
||||
- new operations with MPZ or MPQ: mpfr_{add,sub,mul,div}_[zq]
|
||||
- new predicates: mpfr_inf_p, mpfr_nan_p, mpfr_number_p, mpfr_isinteger,
|
||||
- add mechanism to set/check exponent range (overflow, underflow), partially
|
||||
implemented in the mpfr functions.
|
||||
- efficiency: mpfr_div is now faster when the divisor has a few limbs
|
||||
- rounding: now mpfr_pow implements exact rounding, and most functions return a
|
||||
ternary value indicating the position of the returned value wrt the exact one
|
||||
(thus the return value is now 'int' instead of 'void')
|
||||
- complete rewrite of the configuration files
|
||||
- mpfr_get_d, mpfr_{add,sub}_one_ulp now get a rounding mode as 2nd argument
|
||||
- some function names did change: mpz_set_fr is now mpfr_get_z_exp,
|
||||
mpfr_print_raw is now mpfr_print_binary.
|
||||
|
||||
Changes from version 1.0 to version 2001:
|
||||
- the default installation does not provide any more access to machine
|
||||
rounding mode, and as a consequence does not compare MPFR results with
|
||||
precision=53 to machine results. Add option -DTEST if you want to have
|
||||
access to machine rounding mode, and to check MPFR results against.
|
||||
- the MPFR files do not need <math.h> any more
|
||||
- the header file <mpfr.h> was split into <mpfr.h> for exported functions
|
||||
and <mpfr-impl.h> for internal functions. The user should not use functions
|
||||
or macros from <mpfr-impl.h>, since those may change in further releases.
|
||||
- <mpfr.h> was modified in order to make easy a C++ interface
|
||||
- MPFR now deals with infinities (+infinity and -infinity) and NaN
|
||||
- the missing function mpfr_swap is now available
|
||||
- mpfr_zeta was removed (was incomplete)
|
||||
- mpfr_init and mpfr_init2 now initialize the corresponding variable to 0
|
||||
(like in other initialization functions from GNU MP)
|
||||
- in case memory allocation fails, an error message is output
|
||||
- several bugs of version 1.0 were fixed
|
||||
|
||||
Changes from version 0.4 to version 1.0:
|
||||
|
||||
- Version 1.0 now uses a standard configure/make installation.
|
||||
- Version 1.0 implements all functions that are available in the MPF class
|
||||
from GMP 3.1 (except mpf_swap) and a header file mpf2mpfr.h is included in
|
||||
the distribution for easy change from MPF to MPFR.
|
||||
- Version 1.0 implements new elementary functions: mpfr_sincos
|
||||
- Some functions and macros have been renamed: mpfr_log2 is now
|
||||
mpfr_const_log2, mpfr_pi is now mpfr_const_pi, SIGN is now MPFR_SIGN.
|
||||
- Version 1.0 uses faster algorithms for mpfr_exp, mpfr_const_pi,
|
||||
mpfr_const_log2. Compare the timings from version 1.0 and version 0.4.
|
||||
- Version 1.0 corrects some bugs of version 0.4.
|
||||
- The precision of MPFR variables is now named mpfr_prec, which makes it
|
||||
easier to change it, to say unsigned long long. Same for the rounding mode
|
||||
which is called mp_rnd_t.
|
||||
|
||||
You'll find other news concerning the GNU MPFR library on the web
|
||||
page <http://www.mpfr.org/>.
|
692
Git/mingw64/share/doc/mpfr/TODO
Normal file
692
Git/mingw64/share/doc/mpfr/TODO
Normal file
@ -0,0 +1,692 @@
|
||||
Copyright 1999-2019 Free Software Foundation, Inc.
|
||||
Contributed by the AriC and Caramba projects, INRIA.
|
||||
|
||||
This file is part of the GNU MPFR Library.
|
||||
|
||||
The GNU MPFR 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 GNU MPFR 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 GNU MPFR Library; see the file COPYING.LESSER. If not, see
|
||||
https://www.gnu.org/licenses/ or write to the Free Software Foundation, Inc.,
|
||||
51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
|
||||
Table of contents:
|
||||
1. Documentation
|
||||
2. Compiler/library detection
|
||||
3. Changes in existing functions
|
||||
4. New functions to implement
|
||||
5. Efficiency
|
||||
6. Miscellaneous
|
||||
7. Portability
|
||||
|
||||
##############################################################################
|
||||
1. Documentation
|
||||
##############################################################################
|
||||
|
||||
- add a description of the algorithms used and a proof of correctness
|
||||
|
||||
##############################################################################
|
||||
2. Compiler/library detection
|
||||
##############################################################################
|
||||
|
||||
- if we want to distinguish GMP and MPIR, we can check at configure time
|
||||
the following symbols which are only defined in MPIR:
|
||||
|
||||
#define __MPIR_VERSION 0
|
||||
#define __MPIR_VERSION_MINOR 9
|
||||
#define __MPIR_VERSION_PATCHLEVEL 0
|
||||
|
||||
There is also a library symbol mpir_version, which should match VERSION, set
|
||||
by configure, for example 0.9.0.
|
||||
|
||||
- update ICC detection.
|
||||
* Use only __INTEL_COMPILER instead of the obsolete macro __ICC?
|
||||
* Possibly enable some features with ICC. For instance, removing
|
||||
"&& !defined(__ICC)" from src/mpfr.h works with ICC 15.0.0 20140723.
|
||||
|
||||
##############################################################################
|
||||
3. Changes in existing functions
|
||||
##############################################################################
|
||||
|
||||
- export mpfr_overflow and mpfr_underflow as public functions
|
||||
|
||||
- many functions currently taking into account the precision of the *input*
|
||||
variable to set the initial working precision (acosh, asinh, cosh, ...).
|
||||
This is nonsense since the "average" working precision should only depend
|
||||
on the precision of the *output* variable (and maybe on the *value* of
|
||||
the input in case of cancellation).
|
||||
-> remove those dependencies from the input precision.
|
||||
|
||||
- mpfr_can_round:
|
||||
change the meaning of the 2nd argument (err). Currently the error is
|
||||
at most 2^(MPFR_EXP(b)-err), i.e. err is the relative shift wrt the
|
||||
most significant bit of the approximation. I propose that the error
|
||||
is now at most 2^err ulps of the approximation, i.e.
|
||||
2^(MPFR_EXP(b)-MPFR_PREC(b)+err).
|
||||
|
||||
- mpfr_set_q first tries to convert the numerator and the denominator
|
||||
to mpfr_t. But this conversion may fail even if the correctly rounded
|
||||
result is representable. New way to implement:
|
||||
Function q = a/b. nq = PREC(q) na = PREC(a) nb = PREC(b)
|
||||
If na < nb
|
||||
a <- a*2^(nb-na)
|
||||
n <- na-nb+ (HIGH(a,nb) >= b)
|
||||
if (n >= nq)
|
||||
bb <- b*2^(n-nq)
|
||||
a = q*bb+r --> q has exactly n bits.
|
||||
else
|
||||
aa <- a*2^(nq-n)
|
||||
aa = q*b+r --> q has exactly n bits.
|
||||
If RNDN, takes nq+1 bits. (See also the new division function).
|
||||
|
||||
- revisit the conversion functions between a MPFR number and a native
|
||||
floating-point value.
|
||||
* Consequences if some exception is trapped?
|
||||
* Specify under which conditions (current rounding direction and
|
||||
precision of the FPU, whether a format has been recognized...),
|
||||
correct rounding is guaranteed. Fix the code if need be. Do not
|
||||
forget subnormals.
|
||||
* Provide mpfr_buildopt_* functions to tell whether the format of a
|
||||
native type (float / double / long double) has been recognized and
|
||||
which format it is?
|
||||
* For functions that return a native floating-point value (mpfr_get_flt,
|
||||
mpfr_get_d, mpfr_get_ld, mpfr_get_decimal64), in case of underflow or
|
||||
overflow, follow the convention used for the functions in <math.h>?
|
||||
See §7.12.1 "Treatment of error conditions" of ISO C11, which provides
|
||||
two ways of handling error conditions, depending on math_errhandling:
|
||||
errno (to be set to ERANGE here) and floating-point exceptions.
|
||||
If floating-point exceptions need to be generated, do not use
|
||||
feraiseexcept(), as this function may require the math library (-lm);
|
||||
use a floating-point expression instead, such as DBL_MIN * DBL_MIN
|
||||
(underflow) or DBL_MAX * DBL_MAX (overflow), which are probably safe
|
||||
as used in the GNU libc implementation.
|
||||
* For testing the lack of subnormal support:
|
||||
see the -mfpu GCC option for ARM and
|
||||
https://en.wikipedia.org/wiki/Denormal_number#Disabling_denormal_floats_at_the_code_level
|
||||
|
||||
|
||||
##############################################################################
|
||||
4. New functions to implement
|
||||
##############################################################################
|
||||
|
||||
- implement new functions from the C++17 standard:
|
||||
http://en.cppreference.com/w/cpp/numeric/special_math
|
||||
assoc_laguerre, assoc_legendre, comp_ellint_1, comp_ellint_2, comp_ellint_3,
|
||||
cyl_bessel_i, cyl_bessel_j, cyl_bessel_k, cyl_neumann, ellint_1, ellint_2,
|
||||
ellint_3, hermite, legendre, laguerre, sph_bessel, sph_legendre,
|
||||
sph_neumann.
|
||||
Already in mpfr4: beta and riemann_zeta.
|
||||
See also https://isocpp.org/files/papers/P0226R1.pdf and §29.9.5 in the
|
||||
C++17 draft:
|
||||
https://github.com/cplusplus/draft/blob/master/source/numerics.tex
|
||||
- implement mpfr_get_decimal128 and mpfr_set_decimal128
|
||||
- implement mpfr_log_ui to compute log(n) for an unsigned long n.
|
||||
We can write for argument reduction n = 2^k * n/2^k, where
|
||||
2/3 <= n/2^k < 4/3, i.e., k = floor(log2(3n))-1, thus
|
||||
log(n) = k*log(2) + log(n/2^k), and we can use binary splitting on the
|
||||
Taylor expansion of log(1+x) to compute log(n/2^k), where at most
|
||||
p*log(2)/log(3) terms are needed for precision p.
|
||||
Other idea (from Fredrik Johansson): compute log(m) + log(n/m) where
|
||||
m=2^a*3^b*5^c*7^d and m is close to n.
|
||||
- implement mpfr_q_sub, mpfr_z_div, mpfr_q_div?
|
||||
- implement mpfr_pow_q and variants with two integers (native or mpz)
|
||||
instead of a rational? See IEEE P1788.
|
||||
- implement functions for random distributions, see for example
|
||||
https://sympa.inria.fr/sympa/arc/mpfr/2010-01/msg00034.html
|
||||
(suggested by Charles Karney <ckarney@Sarnoff.com>, 18 Jan 2010):
|
||||
* a Bernoulli distribution with prob p/q (exact)
|
||||
* a general discrete distribution (i with prob w[i]/sum(w[i]) (Walker
|
||||
algorithm, but make it exact)
|
||||
* a uniform distribution in (a,b)
|
||||
* exponential distribution (mean lambda) (von Neumann's method?)
|
||||
* normal distribution (mean m, s.d. sigma) (ratio method?)
|
||||
- wanted for Magma [John Cannon <john@maths.usyd.edu.au>, Tue, 19 Apr 2005]:
|
||||
HypergeometricU(a,b,s) = 1/gamma(a)*int(exp(-su)*u^(a-1)*(1+u)^(b-a-1),
|
||||
u=0..infinity)
|
||||
JacobiThetaNullK
|
||||
PolylogP, PolylogD, PolylogDold: see http://arxiv.org/abs/math.CA/0702243
|
||||
and the references herein.
|
||||
JBessel(n, x) = BesselJ(n+1/2, x)
|
||||
KBessel, KBessel2 [2nd kind]
|
||||
JacobiTheta
|
||||
(see http://www.ams.org/journals/mcom/0000-000-00/S0025-5718-2017-03245-2/home.html)
|
||||
LogIntegral
|
||||
ExponentialIntegralEn (formula 5.1.4 of Abramowitz and Stegun)
|
||||
DawsonIntegral
|
||||
GammaD(x) = Gamma(x+1/2)
|
||||
- new functions of IEEE 754-2008, and more generally functions of the
|
||||
C binding draft TS 18661-4:
|
||||
http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1946.pdf
|
||||
Some propositions about rootn: mpfr_rootn_si, mpfr_rootn_sj, mpfr_rootn_z,
|
||||
and versions with an unsigned integer: mpfr_rootn_ui (now implemented, as
|
||||
similar to mpfr_root) and mpfr_rootn_uj.
|
||||
- functions defined in the LIA-2 standard
|
||||
+ minimum and maximum (5.2.2): max, min, max_seq, min_seq, mmax_seq
|
||||
and mmin_seq (mpfr_min and mpfr_max correspond to mmin and mmax);
|
||||
+ rounding_rest, floor_rest, ceiling_rest (5.2.4);
|
||||
+ remr (5.2.5): x - round(x/y) y;
|
||||
+ error functions from 5.2.7 (if useful in MPFR);
|
||||
+ power1pm1 (5.3.6.7): (1 + x)^y - 1;
|
||||
+ logbase (5.3.6.12): \log_x(y);
|
||||
+ logbase1p1p (5.3.6.13): \log_{1+x}(1+y);
|
||||
+ rad (5.3.9.1): x - round(x / (2 pi)) 2 pi = remr(x, 2 pi);
|
||||
+ axis_rad (5.3.9.1) if useful in MPFR;
|
||||
+ cycle (5.3.10.1): rad(2 pi x / u) u / (2 pi) = remr(x, u);
|
||||
+ axis_cycle (5.3.10.1) if useful in MPFR;
|
||||
+ sinu, cosu, tanu, cotu, secu, cscu, cossinu, arcsinu, arccosu,
|
||||
arctanu, arccotu, arcsecu, arccscu (5.3.10.{2..14}):
|
||||
sin(x 2 pi / u), etc.;
|
||||
[from which sinpi(x) = sin(Pi*x), ... are trivial to implement, with u=2.]
|
||||
+ arcu (5.3.10.15): arctan2(y,x) u / (2 pi);
|
||||
+ rad_to_cycle, cycle_to_rad, cycle_to_cycle (5.3.11.{1..3}).
|
||||
- From GSL, missing special functions (if useful in MPFR):
|
||||
(cf https://www.gnu.org/software/gsl/manual/gsl-ref.html#Special-Functions)
|
||||
+ The Airy functions Ai(x) and Bi(x) defined by the integral representations:
|
||||
* Ai(x) = (1/\pi) \int_0^\infty \cos((1/3) t^3 + xt) dt
|
||||
* Bi(x) = (1/\pi) \int_0^\infty (e^(-(1/3) t^3) + \sin((1/3) t^3 + xt)) dt
|
||||
* Derivatives of Airy Functions
|
||||
+ The Bessel functions for n integer and n fractional:
|
||||
* Regular Modified Cylindrical Bessel Functions I_n
|
||||
* Irregular Modified Cylindrical Bessel Functions K_n
|
||||
* Regular Spherical Bessel Functions j_n: j_0(x) = \sin(x)/x,
|
||||
j_1(x)= (\sin(x)/x-\cos(x))/x & j_2(x)= ((3/x^2-1)\sin(x)-3\cos(x)/x)/x
|
||||
Note: the "spherical" Bessel functions are solutions of
|
||||
x^2 y'' + 2 x y' + [x^2 - n (n+1)] y = 0 and satisfy
|
||||
j_n(x) = sqrt(Pi/(2x)) J_{n+1/2}(x). They should not be mixed with the
|
||||
classical Bessel Functions, also noted j0, j1, jn, y0, y1, yn in C99
|
||||
and mpfr.
|
||||
Cf https://en.wikipedia.org/wiki/Bessel_function#Spherical_Bessel_functions
|
||||
*Irregular Spherical Bessel Functions y_n: y_0(x) = -\cos(x)/x,
|
||||
y_1(x)= -(\cos(x)/x+\sin(x))/x &
|
||||
y_2(x)= (-3/x^3+1/x)\cos(x)-(3/x^2)\sin(x)
|
||||
* Regular Modified Spherical Bessel Functions i_n:
|
||||
i_l(x) = \sqrt{\pi/(2x)} I_{l+1/2}(x)
|
||||
* Irregular Modified Spherical Bessel Functions:
|
||||
k_l(x) = \sqrt{\pi/(2x)} K_{l+1/2}(x).
|
||||
+ Clausen Function:
|
||||
Cl_2(x) = - \int_0^x dt \log(2 \sin(t/2))
|
||||
Cl_2(\theta) = \Im Li_2(\exp(i \theta)) (dilogarithm).
|
||||
+ Dawson Function: \exp(-x^2) \int_0^x dt \exp(t^2).
|
||||
+ Debye Functions: D_n(x) = n/x^n \int_0^x dt (t^n/(e^t - 1))
|
||||
+ Elliptic Integrals:
|
||||
* Definition of Legendre Forms:
|
||||
F(\phi,k) = \int_0^\phi dt 1/\sqrt((1 - k^2 \sin^2(t)))
|
||||
E(\phi,k) = \int_0^\phi dt \sqrt((1 - k^2 \sin^2(t)))
|
||||
P(\phi,k,n) = \int_0^\phi dt 1/((1 + n \sin^2(t))\sqrt(1 - k^2 \sin^2(t)))
|
||||
* Complete Legendre forms are denoted by
|
||||
K(k) = F(\pi/2, k)
|
||||
E(k) = E(\pi/2, k)
|
||||
* Definition of Carlson Forms
|
||||
RC(x,y) = 1/2 \int_0^\infty dt (t+x)^(-1/2) (t+y)^(-1)
|
||||
RD(x,y,z) = 3/2 \int_0^\infty dt (t+x)^(-1/2) (t+y)^(-1/2) (t+z)^(-3/2)
|
||||
RF(x,y,z) = 1/2 \int_0^\infty dt (t+x)^(-1/2) (t+y)^(-1/2) (t+z)^(-1/2)
|
||||
RJ(x,y,z,p) = 3/2 \int_0^\infty dt
|
||||
(t+x)^(-1/2) (t+y)^(-1/2) (t+z)^(-1/2) (t+p)^(-1)
|
||||
+ Elliptic Functions (Jacobi)
|
||||
+ N-relative exponential:
|
||||
exprel_N(x) = N!/x^N (\exp(x) - \sum_{k=0}^{N-1} x^k/k!)
|
||||
+ exponential integral:
|
||||
E_2(x) := \Re \int_1^\infty dt \exp(-xt)/t^2.
|
||||
Ei_3(x) = \int_0^x dt \exp(-t^3) for x >= 0.
|
||||
Ei(x) := - PV(\int_{-x}^\infty dt \exp(-t)/t)
|
||||
+ Hyperbolic/Trigonometric Integrals
|
||||
Shi(x) = \int_0^x dt \sinh(t)/t
|
||||
Chi(x) := Re[ \gamma_E + \log(x) + \int_0^x dt (\cosh[t]-1)/t]
|
||||
Si(x) = \int_0^x dt \sin(t)/t
|
||||
Ci(x) = -\int_x^\infty dt \cos(t)/t for x > 0
|
||||
AtanInt(x) = \int_0^x dt \arctan(t)/t
|
||||
[ \gamma_E is the Euler constant ]
|
||||
+ Fermi-Dirac Function:
|
||||
F_j(x) := (1/r\Gamma(j+1)) \int_0^\infty dt (t^j / (\exp(t-x) + 1))
|
||||
+ Pochhammer symbol (a)_x := \Gamma(a + x)/\Gamma(a) : see [Smith01] in
|
||||
algorithms.bib
|
||||
logarithm of the Pochhammer symbol
|
||||
+ Gegenbauer Functions
|
||||
+ Laguerre Functions
|
||||
+ Eta Function: \eta(s) = (1-2^{1-s}) \zeta(s)
|
||||
Hurwitz zeta function: \zeta(s,q) = \sum_0^\infty (k+q)^{-s}.
|
||||
+ Lambert W Functions, W(x) are defined to be solutions of the equation:
|
||||
W(x) \exp(W(x)) = x.
|
||||
This function has multiple branches for x < 0 (2 funcs W0(x) and Wm1(x))
|
||||
From Fredrik Johansson:
|
||||
See https://cs.uwaterloo.ca/research/tr/1993/03/W.pdf, in particular
|
||||
formulas 5.2 and 5.3 for the error bound: one first computes an
|
||||
approximation w, and then evaluates the residual w e^w - x. There is an
|
||||
expression for the error in terms of the residual and the derivative W'(t),
|
||||
where the derivative can be bounded by piecewise simple functions,
|
||||
something like min(1, 1/t) when t >= 0.
|
||||
See https://arxiv.org/abs/1705.03266 for rigorous error bounds.
|
||||
+ Trigamma Function psi'(x).
|
||||
and Polygamma Function: psi^{(m)}(x) for m >= 0, x > 0.
|
||||
- functions from ISO/IEC 24747:2009 (Extensions to the C Library,
|
||||
to Support Mathematical Special Functions).
|
||||
Standard: http://www.iso.org/iso/catalogue_detail.htm?csnumber=38857
|
||||
Draft: http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1292.pdf
|
||||
Rationale: http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1244.pdf
|
||||
See also: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2010/n3060.pdf
|
||||
(similar, for C++).
|
||||
Also check whether the functions that are already implemented in MPFR
|
||||
match this standard.
|
||||
|
||||
- from gnumeric (www.gnome.org/projects/gnumeric/doc/function-reference.html):
|
||||
- incomplete beta function, see message from Martin Maechler
|
||||
<maechler@stat.math.ethz.ch> on 18 Jan 2016, and Section 6.6 in
|
||||
Abramowitz & Stegun
|
||||
- betaln
|
||||
- degrees
|
||||
- radians
|
||||
- sqrtpi
|
||||
|
||||
- mpfr_inp_raw, mpfr_out_raw (cf mail "Serialization of mpfr_t" from Alexey
|
||||
and answer from Granlund on mpfr list, May 2007)
|
||||
- [maybe useful for SAGE] implement companion frac_* functions to the rint_*
|
||||
functions. For example mpfr_frac_floor(x) = x - floor(x). (The current
|
||||
mpfr_frac function corresponds to mpfr_rint_trunc.)
|
||||
- scaled erfc (https://sympa.inria.fr/sympa/arc/mpfr/2009-05/msg00054.html)
|
||||
- asec, acsc, acot, asech, acsch and acoth (mail from Björn Terelius on mpfr
|
||||
list, 18 June 2009)
|
||||
|
||||
##############################################################################
|
||||
5. Efficiency
|
||||
##############################################################################
|
||||
|
||||
- Fredrik Johansson reports that mpfr_ai is slow for large arguments: an
|
||||
asymptotic expansion should be used (once done, remove REDUCE_EMAX from
|
||||
tests/tai.c and update the description in mpfr.texi).
|
||||
- for exp(x), Fredrik Johansson reports a 20% speed improvement starting from
|
||||
4000 bits, and up to a 75% memory improvement in his Arb implementation, by
|
||||
using recursive instead of iterative binary splitting:
|
||||
https://github.com/fredrik-johansson/arb/blob/master/elefun/exp_sum_bs_powtab.c
|
||||
- improve mpfr_grandom using the algorithm in http://arxiv.org/abs/1303.6257
|
||||
- use the src/x86_64/corei5/mparam.h file once GMP recognizes correctly the
|
||||
Core i5 processors (note that gcc -mtune=native gives __tune_corei7__
|
||||
and not __tune_corei5__ on those processors)
|
||||
- implement a mpfr_sqrthigh algorithm based on Mulders' algorithm, with a
|
||||
basecase variant
|
||||
- use mpn_div_q to speed up mpfr_div. However mpn_div_q, which is new in
|
||||
GMP 5, is not documented in the GMP manual, thus we are not sure it
|
||||
guarantees to return the same quotient as mpn_tdiv_qr.
|
||||
Also mpfr_div uses the remainder computed by mpn_divrem. A workaround would
|
||||
be to first try with mpn_div_q, and if we cannot (easily) compute the
|
||||
rounding, then use the current code with mpn_divrem.
|
||||
- improve atanh(x) for small x by using atanh(x) = log1p(2x/(1-x)),
|
||||
and log1p should also be improved for small arguments.
|
||||
- compute exp by using the series for cosh or sinh, which has half the terms
|
||||
(see Exercise 4.11 from Modern Computer Arithmetic, version 0.3)
|
||||
The same method can be used for log, using the series for atanh, i.e.,
|
||||
atanh(x) = 1/2*log((1+x)/(1-x)).
|
||||
- improve mpfr_gamma (see https://code.google.com/p/fastfunlib/). A possible
|
||||
idea is to implement a fast algorithm for the argument reconstruction
|
||||
gamma(x+k): instead of performing k products by x+i, we could precompute
|
||||
x^2, ..., x^m for m ~ sqrt(k), and perform only sqrt(k) products.
|
||||
One could also use the series for 1/gamma(x), see for example
|
||||
http://dlmf.nist.gov/5/7/ or formula (36) from
|
||||
http://mathworld.wolfram.com/GammaFunction.html
|
||||
- improve the computation of Bernoulli numbers: instead of computing just one
|
||||
B[2n] at a time in mpfr_bernoulli_internal, we could compute several at a
|
||||
time, sharing the expensive computation of the 1/p^(2n) series.
|
||||
- fix regression with mpfr_mpz_root (from Keith Briggs, 5 July 2006), for
|
||||
example on 3Ghz P4 with gmp-4.2, x=12.345:
|
||||
prec=50000 k=2 k=3 k=10 k=100
|
||||
mpz_root 0.036 0.072 0.476 7.628
|
||||
mpfr_mpz_root 0.004 0.004 0.036 12.20
|
||||
See also mail from Carl Witty on mpfr list, 09 Oct 2007.
|
||||
- for sparse input (say x=1 with 2 bits), mpfr_exp is not faster than for
|
||||
full precision when precision <= MPFR_EXP_THRESHOLD. The reason is
|
||||
that argument reduction kills sparsity. Maybe avoid argument reduction
|
||||
for sparse input?
|
||||
- speed up mpfr_atan for large arguments (to speed up mpc_log) see FR #6198
|
||||
- improve mpfr_sin on values like ~pi (do not compute sin from cos, because
|
||||
of the cancellation). For instance, reduce the input modulo pi/2 in
|
||||
[-pi/4,pi/4], and define auxiliary functions for which the argument is
|
||||
assumed to be already reduced (so that the sin function can avoid
|
||||
unnecessary computations by calling the auxiliary cos function instead of
|
||||
the full cos function). This will require a native code for sin, for
|
||||
example using the reduction sin(3x)=3sin(x)-4sin(x)^3.
|
||||
See https://sympa.inria.fr/sympa/arc/mpfr/2007-08/msg00001.html and
|
||||
the following messages.
|
||||
- improve generic.c to work for number of terms <> 2^k
|
||||
- rewrite mpfr_greater_p... as native code.
|
||||
|
||||
- mpf_t uses a scheme where the number of limbs actually present can
|
||||
be less than the selected precision, thereby allowing low precision
|
||||
values (for instance small integers) to be stored and manipulated in
|
||||
an mpf_t efficiently.
|
||||
|
||||
Perhaps mpfr should get something similar, especially if looking to
|
||||
replace mpf with mpfr, though it'd be a major change. Alternately
|
||||
perhaps those mpfr routines like mpfr_mul where optimizations are
|
||||
possible through stripping low zero bits or limbs could check for
|
||||
that (this would be less efficient but easier).
|
||||
|
||||
- try the idea of the paper "Reduced Cancellation in the Evaluation of Entire
|
||||
Functions and Applications to the Error Function" by W. Gawronski, J. Mueller
|
||||
and M. Reinhard, to be published in SIAM Journal on Numerical Analysis: to
|
||||
avoid cancellation in say erfc(x) for x large, they compute the Taylor
|
||||
expansion of erfc(x)*exp(x^2/2) instead (which has less cancellation),
|
||||
and then divide by exp(x^2/2) (which is simpler to compute).
|
||||
|
||||
- replace the *_THRESHOLD macros by global (TLS) variables that can be
|
||||
changed at run time (via a function, like other variables)? One benefit
|
||||
is that users could use a single MPFR binary on several machines (e.g.,
|
||||
a library provided by binary packages or shared via NFS) with different
|
||||
thresholds. On the default values, this would be a bit less efficient
|
||||
than the current code, but this isn't probably noticeable (this should
|
||||
be tested). Something like:
|
||||
long *mpfr_tune_get(void) to get the current values (the first value
|
||||
is the size of the array).
|
||||
int mpfr_tune_set(long *array) to set the tune values.
|
||||
int mpfr_tune_run(long level) to find the best values (the support
|
||||
for this feature is optional, this can also be done with an
|
||||
external function).
|
||||
|
||||
- better distinguish different processors (for example Opteron and Core 2)
|
||||
and use corresponding default tuning parameters (as in GMP). This could be
|
||||
done in configure.ac to avoid hacking config.guess, for example define
|
||||
MPFR_HAVE_CORE2.
|
||||
Note (VL): the effect on cross-compilation (that can be a processor
|
||||
with the same architecture, e.g. compilation on a Core 2 for an
|
||||
Opteron) is not clear. The choice should be consistent with the
|
||||
build target (e.g. -march or -mtune value with gcc).
|
||||
Also choose better default values. For instance, the default value of
|
||||
MPFR_MUL_THRESHOLD is 40, while the best values that have been found
|
||||
are between 11 and 19 for 32 bits and between 4 and 10 for 64 bits!
|
||||
|
||||
- during the Many Digits competition, we noticed that (our implantation of)
|
||||
Mulders short product was slower than a full product for large sizes.
|
||||
This should be precisely analyzed and fixed if needed.
|
||||
|
||||
- for various functions, check the timings as a function of the magnitude
|
||||
of the input (and the input and/or output precisions?), and use better
|
||||
thresholds for asymptotic expansions.
|
||||
|
||||
- improve the special case of mpfr_{add,sub} (x, x, y, ...) when |x| > |y|
|
||||
to do the addition in-place and have a complexity of O(prec(y)) in most
|
||||
cases. The mpfr_{add,sub}_{d,ui} functions should automatically benefit
|
||||
from this change.
|
||||
|
||||
- in gmp_op.c, for functions with mpz_srcptr, check whether mpz_fits_slong_p
|
||||
is really useful in all cases (see TODO in this file).
|
||||
|
||||
- optimize code that uses a test based on the fact that x >> s is
|
||||
undefined in C for s == width of x but the result is expected to
|
||||
be 0. ARM and PowerPC could benefit from such an optimization,
|
||||
but not x86. This needs support from the compiler.
|
||||
For PowerPC: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=79233
|
||||
|
||||
- deal with MPFR_RNDF in mpfr_round_near_x (replaced by MPFR_RNDZ).
|
||||
|
||||
- instead of a fixed mparam.h, optionally use function multiversioning
|
||||
(FMV), currently only available with the GNU C++ front end:
|
||||
https://gcc.gnu.org/wiki/FunctionMultiVersioning
|
||||
According to https://lwn.net/Articles/691932/ the dispatch resolution
|
||||
is now done by the dynamic loader, so that this should be fast enough
|
||||
(the cost would be the reading of a static variable, initialized at
|
||||
load time, instead of a constant).
|
||||
In particular, binary package distributions would benefit from FMV as
|
||||
only one binary is generated for different processor families.
|
||||
|
||||
|
||||
##############################################################################
|
||||
6. Miscellaneous
|
||||
##############################################################################
|
||||
|
||||
- [suggested by Tobias Burnus <burnus(at)net-b.de> and
|
||||
Asher Langton <langton(at)gcc.gnu.org>, Wed, 01 Aug 2007]
|
||||
support quiet and signaling NaNs in mpfr:
|
||||
* functions to set/test a quiet/signaling NaN: mpfr_set_snan, mpfr_snan_p,
|
||||
mpfr_set_qnan, mpfr_qnan_p
|
||||
* correctly convert to/from double (if encoding of s/qNaN is fixed in 754R)
|
||||
Note: Signaling NaNs are not specified by the ISO C standard and may
|
||||
not be supported by the implementation. GCC needs the -fsignaling-nans
|
||||
option (but this does not affect the C library, which may or may not
|
||||
accept signaling NaNs).
|
||||
|
||||
- check again coverage: on 2007-07-27, Patrick Pelissier reports that the
|
||||
following files are not tested at 100%: add1.c, atan.c, atan2.c,
|
||||
cache.c, cmp2.c, const_catalan.c, const_euler.c, const_log2.c, cos.c,
|
||||
gen_inverse.h, div_ui.c, eint.c, exp3.c, exp_2.c, expm1.c, fma.c, fms.c,
|
||||
lngamma.c, gamma.c, get_d.c, get_f.c, get_ld.c, get_str.c, get_z.c,
|
||||
inp_str.c, jn.c, jyn_asympt.c, lngamma.c, mpfr-gmp.c, mul.c, mul_ui.c,
|
||||
mulders.c, out_str.c, pow.c, print_raw.c, rint.c, root.c, round_near_x.c,
|
||||
round_raw_generic.c, set_d.c, set_ld.c, set_q.c, set_uj.c, set_z.c, sin.c,
|
||||
sin_cos.c, sinh.c, sqr.c, stack_interface.c, sub1.c, sub1sp.c, subnormal.c,
|
||||
uceil_exp2.c, uceil_log2.c, ui_pow_ui.c, urandomb.c, yn.c, zeta.c, zeta_ui.c.
|
||||
|
||||
- check the constants mpfr_set_emin (-16382-63) and mpfr_set_emax (16383) in
|
||||
get_ld.c and the other constants, and provide a testcase for large and
|
||||
small numbers.
|
||||
|
||||
- from Kevin Ryde <user42@zip.com.au>:
|
||||
Also for pi.c, a pre-calculated compiled-in pi to a few thousand
|
||||
digits would be good value I think. After all, say 10000 bits using
|
||||
1250 bytes would still be small compared to the code size!
|
||||
Store pi in round to zero mode (to recover other modes).
|
||||
|
||||
- add other prototypes for round to nearest-away (mpfr_round_nearest_away
|
||||
only deals with the prototypes of say mpfr_sin) or implement it as a native
|
||||
rounding mode
|
||||
- add a new roundind mode: round to odd. If the result is not exactly
|
||||
representable, then round to the odd mantissa. This rounding
|
||||
has the nice property that for k > 1, if:
|
||||
y = round(x, p+k, TO_ODD)
|
||||
z = round(y, p, TO_NEAREST_EVEN), then
|
||||
z = round(x, p, TO_NEAREST_EVEN)
|
||||
so it avoids the double-rounding problem.
|
||||
VL: I prefer the (original?) term "sticky rounding", as used in
|
||||
J Strother Moore, Tom Lynch, Matt Kaufmann. A Mechanically Checked
|
||||
Proof of the Correctness of the Kernel of the AMD5K86 Floating-Point
|
||||
Division Algorithm. IEEE Transactions on Computers, 1996.
|
||||
and
|
||||
http://www.russinoff.com/libman/text/node26.html
|
||||
|
||||
- new rounding mode MPFR_RNDE when the result is known to be exact?
|
||||
* In normal mode, this would allow MPFR to optimize using
|
||||
this information.
|
||||
* In debug mode, MPFR would check that the result is exact
|
||||
(i.e. that the ternary value is 0).
|
||||
|
||||
- new "rounding mode" MPFR_RNDF (faithful rounding)?
|
||||
This is not really a rounding mode since it is non-deterministic. The
|
||||
goal is to avoid the Table Maker's Dilemma in internal computations.
|
||||
The definition of faithful rounding of a real number x is: return either
|
||||
RNDD(x) or RNDU(x). This means that if x is exactly representable, one
|
||||
returns x exactly. In MPFR, the ternary value should be unspecified for
|
||||
efficiency reasons.
|
||||
Note: One typically implements faithful rounding by computing an
|
||||
approximation to the result with some adequately chosen error bound,
|
||||
then by rounding this approximation to nearest.
|
||||
Concerning the choice of the error bound, if the result x is equal to
|
||||
1 + t, where t is a very small positive number, then the error bound
|
||||
needs to be at most ulp(x)/4 + t. Since t can be arbitrarily small,
|
||||
the error bound needs to be at most ulp(x)/4. And this error bound
|
||||
is sufficient in all cases. Note that with the even rounding rule or
|
||||
rounding away from zero, it is not needed to relax the condition when
|
||||
x is exactly representable.
|
||||
|
||||
- add tests of the ternary value for constants
|
||||
|
||||
- When doing Extensive Check (--enable-assert=full), since all the
|
||||
functions use a similar use of MACROS (ZivLoop, ROUND_P), it should
|
||||
be possible to do such a scheme:
|
||||
For the first call to ROUND_P when we can round.
|
||||
Mark it as such and save the approximated rounding value in
|
||||
a temporary variable.
|
||||
Then after, if the mark is set, check if:
|
||||
- we still can round.
|
||||
- The rounded value is the same.
|
||||
It should be a complement to tgeneric tests.
|
||||
|
||||
- in div.c, try to find a case for which cy != 0 after the line
|
||||
cy = mpn_sub_1 (sp + k, sp + k, qsize, cy);
|
||||
(which should be added to the tests), e.g. by having {vp, k} = 0, or
|
||||
prove that this cannot happen.
|
||||
|
||||
- add a configure test for --enable-logging to ignore the option if
|
||||
it cannot be supported. Modify the "configure --help" description
|
||||
to say "on systems that support it".
|
||||
|
||||
- add generic bad cases for functions that don't have an inverse
|
||||
function that is implemented (use a single Newton iteration).
|
||||
|
||||
- add bad cases for the internal error bound (by using a dichotomy
|
||||
between a bad case for the correct rounding and some input value
|
||||
with fewer Ziv iterations?).
|
||||
|
||||
- add an option to use a 32-bit exponent type (int) on LP64 machines,
|
||||
mainly for developers, in order to be able to test the case where the
|
||||
extended exponent range is the same as the default exponent range, on
|
||||
such platforms.
|
||||
Tests can be done with the exp-int branch (added on 2010-12-17, and
|
||||
many tests fail at this time).
|
||||
|
||||
- test underflow/overflow detection of various functions (in particular
|
||||
mpfr_exp) in reduced exponent ranges, including ranges that do not
|
||||
contain 0.
|
||||
|
||||
- add an internal macro that does the equivalent of the following?
|
||||
MPFR_IS_ZERO(x) || MPFR_GET_EXP(x) <= value
|
||||
|
||||
- check whether __gmpfr_emin and __gmpfr_emax could be replaced by
|
||||
a constant (see README.dev). Also check the use of MPFR_EMIN_MIN
|
||||
and MPFR_EMAX_MAX.
|
||||
|
||||
- add a test checking that no mpfr.h macros depend on mpfr-impl.h
|
||||
(the current tests cannot check that since mpfr-impl.h is always
|
||||
included).
|
||||
|
||||
- move some macro definitions from acinclude.m4 to the m4 directory
|
||||
as suggested by the Automake manual? The reason is that the
|
||||
acinclude.m4 file is big and a bit difficult to read.
|
||||
|
||||
- use symbol versioning.
|
||||
|
||||
- check whether mpz_t caching (pool) is necessary. Timings with -static
|
||||
with details about the C / C library implementation should be put
|
||||
somewhere as a comment in the source or in the doc. Using -static
|
||||
is important because otherwise the cache saves the dynamic call to
|
||||
mpz_init and mpz_clear; so, what we're measuring is not clear.
|
||||
See thread:
|
||||
https://gmplib.org/list-archives/gmp-devel/2015-September/004147.html
|
||||
Summary: It will not be integrated in GMP because 1) This yields
|
||||
problems with threading (in MPFR, we have TLS variables, but this is
|
||||
not the case of GMP). 2) The gain (if confirmed with -static) would
|
||||
be due to a poor malloc implementation (timings would depend on the
|
||||
platform). 3) Applications would use more RAM.
|
||||
Additional notes [VL]: the major differences in the timings given
|
||||
by Patrick in 2014-01 under Linux were:
|
||||
Before:
|
||||
arccos(x) took 0.054689 ms (32767 eval in 1792 ms)
|
||||
arctan(x) took 0.042116 ms (32767 eval in 1380 ms)
|
||||
After:
|
||||
arccos(x) took 0.043580 ms (32767 eval in 1428 ms)
|
||||
arctan(x) took 0.035401 ms (32767 eval in 1160 ms)
|
||||
mpfr_acos doesn't use mpz, but calls mpfr_atan, so that the issue comes
|
||||
from mpfr_atan, which uses mpz a lot. The problem mainly comes from the
|
||||
reallocations in GMP because mpz_init is used instead of mpz_init2 with
|
||||
the estimated maximum size. Other places in the code that uses mpz_init
|
||||
may be concerned.
|
||||
Issues with mpz_t caching:
|
||||
* The pool can take much memory, which may no longer be useful.
|
||||
For instance:
|
||||
mpfr_init2 (x, 10000000);
|
||||
mpfr_log_ui (x, 17, MPFR_RNDN);
|
||||
/* ... */
|
||||
mpfr_clear (x);
|
||||
/* followed by code using only small precision */
|
||||
while contrary to real caches, they contain no data. This is not
|
||||
valuable memory: freeing/allocating a large block of memory is
|
||||
much faster than the actual computations, so that mpz_t caching
|
||||
has no impact on the performance in such cases. A pool with large
|
||||
blocks also potentially destroys the data locality.
|
||||
* It assumes that the real GMP functions are __gmpz_init and
|
||||
__gmpz_clear, which are not part of the official GMP API, thus
|
||||
is based on GMP internals, which may change in the future or
|
||||
may be different in forks / compatible libraries / etc. This
|
||||
can be solved if MPFR code calls mpfr_mpz_init / mpfr_mpz_clear
|
||||
directly, avoiding the #define's.
|
||||
Questions that need to be answered:
|
||||
* What about the comparisons with other memory allocators?
|
||||
* Shouldn't the pool be part of the memory allocator?
|
||||
For the default memory allocator (malloc): RFE?
|
||||
If it is decided to keep some form of mpz_t caching, a possible solution
|
||||
for both issues: define mpfr_mpz_init2 and mpfr_mpz_clear2, which both
|
||||
take 2 arguments like mpz_init2, where mpfr_mpz_init2 behaves in a way
|
||||
similar to mpz_init2, and mpfr_mpz_clear2 behaves in a way similar to
|
||||
mpz_clear but where the size argument is a hint for the pool; if it is
|
||||
too large, then the mpz_t should not be pushed back to the pool. The
|
||||
size argument of mpfr_mpz_init2 could also be a hint to decide which
|
||||
element to pull from the pool.
|
||||
|
||||
- in tsum, add testcases for mpfr_sum triggering the bug fixed in r9722,
|
||||
that is, with a large error during the computation of the secondary term
|
||||
(when the TMD occurs).
|
||||
|
||||
- add internal or public variants of some basic functions (+, -, *) with
|
||||
mpz_t as the exponent for correctly rounded polynomials (like fmma),
|
||||
in order to avoid internal overflow and underflow in extreme cases?
|
||||
Alternatively, for fmma, modify add*.c and sub*.c code to define
|
||||
mpfr_add_raw, which takes arrays of limbs and their precision, and the
|
||||
positive exponent delta (as mpfr_uexp_t to be always representable).
|
||||
The exponent delta should be sufficient for now since it can be bounded
|
||||
by MPFR_PREC_MAX+1 if need be.
|
||||
|
||||
- use the keyword "static" in array indices of parameter declarations with
|
||||
C99 compilers (6.7.5.3p7) when the pointer is expected not to be null?
|
||||
For instance, if mpfr.h is changed to have:
|
||||
__MPFR_DECLSPEC void mpfr_dump (const __mpfr_struct [static 1]);
|
||||
and one calls
|
||||
mpfr_dump (NULL);
|
||||
one gets a warning with Clang. This is just an example; this needs to be
|
||||
done in a clean way.
|
||||
See:
|
||||
http://stackoverflow.com/a/3430353/3782797
|
||||
https://hamberg.no/erlend/posts/2013-02-18-static-array-indices.html
|
||||
|
||||
- change most mpfr_urandomb occurrences to mpfr_urandom in the tests?
|
||||
(The one done in r10573 allowed us to find a bug even without
|
||||
assertion checking.)
|
||||
|
||||
- tzeta has been much slower since r9848 (which increases the precision
|
||||
of the input for the low output precisions), at least with the x86
|
||||
32-bit ABI. This seems to come from the fact that the working precision
|
||||
in the mpfr_zeta implementation depends on the precision of the input.
|
||||
Once mpfr_zeta has improved, change the last argument of test_generic
|
||||
in tzeta.c back to 5 (as it was before r10667).
|
||||
|
||||
- check the small-precision tables in the tests?
|
||||
This may require to export some pointer to the tables, but this could
|
||||
be done only if some debug macro is defined.
|
||||
|
||||
- optionally use malloc() for the caches? See mpfr_mp_memory_cleanup.
|
||||
Note: This can be implemented by adding a TLS flag saying whether we
|
||||
are under cache generation or not, and by making the MPFR allocation
|
||||
functions consider this flag. Moreover, this can only work for mpfr_t
|
||||
caching (floating-point constants), not for mpz_t caching (Bernoulli
|
||||
constants) because we do not have the control of memory allocation for
|
||||
mpz_init.
|
||||
|
||||
|
||||
##############################################################################
|
||||
7. Portability
|
||||
##############################################################################
|
||||
|
||||
- add a web page with results of builds on different architectures
|
||||
|
||||
- [Kevin about texp.c long strings]
|
||||
For strings longer than c99 guarantees, it might be cleaner to
|
||||
introduce a "tests_strdupcat" or something to concatenate literal
|
||||
strings into newly allocated memory. I thought I'd done that in a
|
||||
couple of places already. Arrays of chars are not much fun.
|
||||
|
||||
- use https://gcc.gnu.org/viewcvs/gcc/trunk/config/stdint.m4 for mpfr-gmp.h
|
||||
|
||||
- with MinGW, build with -D__USE_MINGW_ANSI_STDIO by default?
|
1
Git/mingw64/share/doc/mpfr/examples/ReadMe
Normal file
1
Git/mingw64/share/doc/mpfr/examples/ReadMe
Normal file
@ -0,0 +1 @@
|
||||
This directory contains simple examples.
|
Reference in New Issue
Block a user