Skip to content

A very accurate and very efficient multiple precision solver written in C++ for quartic equations with real or complex coefficients based on the paper ACM Transactions on Mathematical Software May 2020 Article No. 20, https://doi.org/10.1145/3386241

Notifications You must be signed in to change notification settings

cridemichel/quarticpp

Repository files navigation

quarticpp

[ For a generic polynomial solver which includes also this class please see https://github.com/cridemichel/polypp ]

The C++ class quartic.hpp provides a very accurate and very efficient quartic solver based on the paper ACM Transactions on Mathematical Software May 2020 Article No.: 20 https://doi.org/10.1145/3386241. With this class you can solve both real and complex quartics in double or multiple precision (see below). In addition to headers you will find some .cpp files with examples on how to use this class. Multiprecision is implemented through boost multiprecision libraries (https://www.boost.org/doc/libs/1_73_0/libs/multiprecision/doc/html/index.html) and you need to have both boost and gmp (https://gmplib.org/) installed. Boost and gmp are conveniently provided by boost and gmp homebrew packages (https://brew.sh/). Note that homebrew not only supports Mac OSX but also Linux and Windows (see https://docs.brew.sh/Homebrew-on-Linux). To build the sources you need a c++ compiler which complies with c++17. It is strongly recommended to install g++ from homebrew. The package is called gcc and it will provide the g++ executable.

The class itself can be used without boost and gmp and it does not require gcc from homebrew. This means that the quartic example can be straightforwardly compiled by the command:

make quartic

without installing anything else.

Instead, by issuing the command:

make all

you obtain the following executables:

quartic: example of usage of quartic.hpp class for solving quartic equations

quartic_mp: example of usage of quartic.hpp to solve quartic in multiple precision (using boost)

quartic_cmplx: solution of a complex quartic

statanalysis: it performs the statistical analyses shown in Figs. 2-4 of the ACM paper. The syntax is the following (where '>' is the shell prompt string):

> statanalysis <trials> <output> <sample> <solver>

where:

trials: it is the number of roots (samples A-E) or coefficients (sample F) to generate

output: every trials save the the probability distribution function P(eps_rel) in the file named P_of_eps_rel-XXX.dat and the cumulative distribution function F(eps_rel) in the file named F_of_eps_rel-XXX.dat, where XXX can be dbl (for double precision) or mp (for multiprecision)

sample: it is an integer between 0 and 5 which specifies the sample to generate according to Table 4 with 0={sample A}, 1={sample B}, 2={sample C}, 3={sample D}, 4={sample E} and 5={sample F}

solver: it is 0 or 1 which specifies the precision to use
for the analysis, where 0=dbl (double) and 1=mp (multiprecision), (-1 perform both tests)

accuracytest: It performs the accuracy tests shown in Table 1 of the ACM paper. The syntax is (where '>' is the shell prompt string):

> accuracytest <case>

where case is an integer between 1 and 24, which corresponds to the 24 cases shown in Table 1 of the ACM paper.

Citing

If you use quarticpp in your research, please consider giving proper attribution by citing the following publication:

  • A.G. Orellana and C. De Michele, Algorithm 1010: Boosting Efficiency in Solving Quartic Equations with No Compromise in Accuracy, ACM Trans. Math. Softw. 46, 20:1-20:28 (2020) https://doi.org/10.1145/3386241

About

A very accurate and very efficient multiple precision solver written in C++ for quartic equations with real or complex coefficients based on the paper ACM Transactions on Mathematical Software May 2020 Article No. 20, https://doi.org/10.1145/3386241

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published