This website contains software written by David H. Bailey, either solely (items 1, 2, 3, 4 and 5) or in collaboration with other authors (items 6 and 7). Please send any comments or questions for this site to:
Here are the software packages that are available:
This package permits one to perform floating-point computations (real and complex) to arbitrarily high numeric precision, by making only relatively minor changes to existing Fortran-90 programs (mostly changes to type statements). All basic arithmetic operations and transcendental functions are supported, together with an extensive set of special functions and polynomial evaluation routines.
The package comes in two versions: one completely self-contained, all-Fortran version that is simple to install; and one version based on the MPFR package that is more complicated to install but runs somewhat faster on most applications. Both versions are completely thread-safe. Both versions also detect, and provide means to overcome, accuracy problems rooted in the usage of inexact double-precision constants and expressions. A high-level Fortran-90 interface, supporting both multiprecision real and complex datatypes, is provided for each, so that most users need only to make minor changes to existing double-precision code. The two versions are "plug-compatible" in the sense that applications written for one also run with the other (provided a simple guideline is followed).
A technical paper describing the package and providing details for usage is available here: MPFUN2020 technical paper (updated 7 Apr 2024).
*** IMPORTANT NOTE: Please read this license document carefully before using the MPFUN package: DHB-License.docx. By downloading or using this software you are agreeing to the modified BSD license that is in this file. If you wish to use this software for any commercial purpose, please contact the author.
The two versions of the software are available here:
MPFUN20-Fort: This is an all-Fortran version based on 8-byte integer arithmetic. It includes support for a medium precision datatype, which results in faster execution on very large problems, and features FFT-based multiplication to accelerate very high precision computations. It compiles in just a few seconds on any system with a Fortran-2008 compliant compiler (examples include the GNU gfortran compiler, the Intel ifort compiler and the NAG Fortran compiler).
For installation instructions, see this README file. The README file also includes a brief summary of programming instructions, although the technical paper above has full details.
MPFUN20-MPFR: This is virtually identical to MPFUN20-Fort in its user interface, but it calls the MPFR package for all low-level functions and operations. The MPFUN20-MPFR version is faster than MPFUN20-Fort on most applications, particularly those that involve transcendental functions. However, installation of MPFUN20-MPFR is significantly more complicated (because the GMP and MPFR packages must first be installed, usually requiring administrator privilege).
For installation instructions, see this README file. The README file also includes a brief summary of programming instructions, although the technical paper above has full details.
This package permits one to perform floating-point computations (real and complex) to double-quad precision (approximately 65 digits), by making only relatively minor changes to existing Fortran programs. All basic arithmetic operations and transcendental functions are supported, together with numerous special functions. The package should run correctly on any Unix-based system supporting a Fortran-2008 compiler and IEEE 128-bit floating-point arithmetic (in hardware or software).
Software for Unix-based systems (including Apple OS X systems): dqfun-v03.tar.gz
For installation instructions, see this README file. The README file also includes a brief summary of programming instructions.
*** IMPORTANT NOTE: Please read this license document carefully before using the DQFUN package: DHB-License.docx. By downloading or using this software you are agreeing to the modified BSD license that is in this file. If you wish to use this software for any commercial purpose, please contact the author.
This package enhances an IEEE quad precision floating-point facility (approx. 33 digit accuracy) to include a library of numerous special functions, all by making only very minor changes to existing Fortran programs. The package should run correctly on any Unix-based system supporting a Fortran-2008 compiler and IEEE 128-bit floating-point arithmetic, in hardware or software.
Software for Unix-based systems (including Apple OS X systems): qxfun-v01.tar.gz
For installation instructions, see this README file. The README file also includes a brief summary of programming instructions.
*** IMPORTANT NOTE: Please read this license document carefully before using the DQFUN package: DHB-License.docx. By downloading or using this software you are agreeing to the modified BSD license that is in this file. If you wish to use this software for any commercial purpose, please contact the author.
This package permits one to perform floating-point computations (real and complex) to double-double precision (approximately 30 digits), by making only relatively minor changes to existing Fortran programs. It is intended as a substitute for IEEE 128-bit quad precision on systems where quad precision is not available. All basic arithmetic operations and transcendental functions are supported, together with numerous special functions. The package should run correctly on any Unix-based system supporting a Fortran-2008 compiler and IEEE 64-bit floating-point arithmetic.
Software for Unix-based systems (including Apple OS X systems): ddfun-v03.tar.gz
For installation instructions, see this README file. The README file also includes a brief summary of programming instructions.
*** IMPORTANT NOTE: Please read this license document carefully before using the DQFUN package: DHB-License.docx. By downloading or using this software you are agreeing to the modified BSD license that is in this file. If you wish to use this software for any commercial purpose, please contact the author.
This is an older all-Fortran version of the MPFUN software, based on floating-point arithmetic. It is several times slower than MPFUN2020. This version is still supported, but MPFUN2020 should be used for new development.
A technical paper describing the package and providing details for usage is available here: MPFUN2015 technical paper.
*** IMPORTANT NOTE: Please read this license document carefully before using the MPFUN package: DHB-License.docx. By downloading or using this software you are agreeing to the modified BSD license that is in this file. If you wish to use this software for any commercial purpose, please contact the author.
The software is available here:
For installation instructions, see this README file. The README.txt file also includes a brief summary of programming instructions, although the technical paper above has full details.
This package is an older arbitrary precision package. It is not thread-safe, but, unlike MPFUN2020, is available with both a Fortran-90 and a C++ high-level interface.
ARPREC for Unix-based systems (including Apple OS X systems): arprec-2.2.20.tar.gz
Note: On some systems, notably a Mac with Safari, the browser may automatically unzip the file as it downloads it. In that case, you may need to rename the file, say from "arprec-2.2.20.tar.gz" to "arprec-2.2.20.tar" before proceeding.
*** IMPORTANT NOTE: This software was written by David Bailey, Xiaoye Li and Yozo Hida, each of whom at the time were at the Lawrence Berkeley National Laboratory. It is available on this site as a convenience. Please read this license document carefully before using: LBNL-BSD-License.docx. By downloading or using this software you are agreeing to the modified BSD license that is in this file. If you wish to use this software for any commercial purpose, please contact the Intellectual Property Office at the Lawrence Berkeley National Laboratory, ipo@lbl.gov.
This package is an older package that provides double-double (approximately 31-digit precision) and quad-double (approximately 62-digit precision) functionality. It is not thread-safe, but, unlike MPFUN2020, is available with both a Fortran-90 and a C++ high-level interface.
QD for Unix-based systems (including Apple OS X systems): qd-2.3.24.tar.gz
Note: On some systems, notably a Mac with Safari, the browser may automatically unzip the file as it downloads it. In that case, you may need to rename the file, say from "qd-2.3.24.tar.gz" to "qd-2.3.24.tar" before proceeding.
*** IMPORTANT NOTE: This software was written by David Bailey, Xiaoye Li and Yozo Hida, each of whom at the time were at the Lawrence Berkeley National Laboratory. It is available on this site as a convenience. Please read this license document carefully before using: LBNL-BSD-License.docx. By downloading or using this software you are agreeing to the modified BSD license that is in this file. If you wish to use this software for any commercial purpose, please contact the Intellectual Property Office at the Lawrence Berkeley National Laboratory, ipo@lbl.gov.