Hello community, here is the log from the commit of package mpc for openSUSE:Factory checked in at 2020-11-03 15:15:08 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Comparing /work/SRC/openSUSE:Factory/mpc (Old) and /work/SRC/openSUSE:Factory/.mpc.new.3463 (New) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Package is "mpc" Tue Nov 3 15:15:08 2020 rev:30 rq:844997 version:1.2.1 Changes: -------- --- /work/SRC/openSUSE:Factory/mpc/mpc.changes 2020-08-28 21:18:03.420227970 +0200 +++ /work/SRC/openSUSE:Factory/.mpc.new.3463/mpc.changes 2020-11-03 15:15:09.507958791 +0100 @@ -1,0 +2,17 @@ +Thu Oct 29 18:30:03 UTC 2020 - Andreas Stieger <andreas.stieger@gmx.de> + +- mpc 1.2.1: + * Fix an incompatibility problem with GMP 6.0 and before + * Fix an intermediate overflow in asin + +------------------------------------------------------------------- +Mon Oct 26 08:44:47 UTC 2020 - Andreas Stieger <andreas.stieger@gmx.de> + +- express build dependencies explicitly to match the versions + required by configue, so that the OBS scheduler is aware of them +- move texinfo requirements to -devel package where they are + are actually used +- package license in every subpackage and mark as license +- run spec-cleaner + +------------------------------------------------------------------- Old: ---- mpc-1.2.0.tar.gz mpc-1.2.0.tar.gz.sig New: ---- mpc-1.2.1.tar.gz mpc-1.2.1.tar.gz.sig ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Other differences: ------------------ ++++++ mpc.spec ++++++ --- /var/tmp/diff_new_pack.MrEb8O/_old 2020-11-03 15:15:10.579959823 +0100 +++ /var/tmp/diff_new_pack.MrEb8O/_new 2020-11-03 15:15:10.579959823 +0100 @@ -17,7 +17,7 @@ Name: mpc -Version: 1.2.0 +Version: 1.2.1 Release: 0 Summary: MPC multiple-precision complex shared library License: LGPL-3.0-or-later @@ -27,11 +27,9 @@ Source1: https://ftp.gnu.org/gnu/mpc/mpc-%{version}.tar.gz.sig Source2: %{name}.keyring Source3: baselibs.conf -BuildRequires: gmp-devel -BuildRequires: mpfr-devel -Requires(post): %{install_info_prereq} -Requires(preun): %{install_info_prereq} -BuildRoot: %{_tmppath}/%{name}-%{version}-build +BuildRequires: pkgconfig +BuildRequires: pkgconfig(gmp) >= 5.0.0 +BuildRequires: pkgconfig(mpfr) >= 4.1.0 %description MPC is a C library for the arithmetic of complex numbers with @@ -51,9 +49,10 @@ Summary: MPC multiple-precision complex library development files Group: Development/Libraries/C and C++ Requires: libmpc3 = %{version} -Requires: mpfr-devel -# FIXME: use proper Requires(pre/post/preun/...) -PreReq: %{install_info_prereq} +Requires: pkgconfig(gmp) >= 5.0.0 +Requires: pkgconfig(mpfr) >= 4.1.0 +Requires(post): %{install_info_prereq} +Requires(preun): %{install_info_prereq} %description devel MPC multiple-precision complex library development files. @@ -64,33 +63,33 @@ %build %global _lto_cflags %{_lto_cflags} -ffat-lto-objects %configure -make %{?_smp_mflags} +%make_build %check -make check %{?_smp_mflags} +%make_build check %install -make DESTDIR=%{buildroot} install %{?_smp_mflags} -rm %{buildroot}%{_libdir}/libmpc.la +%make_install +find %{buildroot} -type f -name "*.la" -delete -print %post -n libmpc3 -p /sbin/ldconfig - %post devel %install_info --info-dir=%{_infodir} %{_infodir}/%{name}.info.gz %postun -n libmpc3 -p /sbin/ldconfig - %preun devel %install_info_delete --info-dir=%{_infodir} %{_infodir}/%{name}.info.gz %files -n libmpc3 %defattr(-,root,root) +%license COPYING.LESSER %{_libdir}/libmpc.so.3* %files devel %defattr(-,root,root) -%doc AUTHORS NEWS COPYING.LESSER -%{_infodir}/mpc.info.gz +%license COPYING.LESSER +%doc AUTHORS NEWS +%{_infodir}/mpc.info%{?ext_info} %{_libdir}/libmpc.a %{_libdir}/libmpc.so %{_includedir}/mpc.h ++++++ mpc-1.2.0.tar.gz -> mpc-1.2.1.tar.gz ++++++ ++++ 1737 lines of diff (skipped) ++++ retrying with extended exclude list diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/Makefile.vc new/mpc-1.2.1/Makefile.vc --- old/mpc-1.2.0/Makefile.vc 2020-08-17 16:55:03.000000000 +0200 +++ new/mpc-1.2.1/Makefile.vc 2020-10-20 18:32:16.000000000 +0200 @@ -50,7 +50,7 @@ CC = cl.exe CDEFAULTFLAGS=/O2 /GR- /MD /nologo /EHs -VERSION=1.2.0 +VERSION=1.2.1 ######################## do not edit below this line ########################## diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/NEWS new/mpc-1.2.1/NEWS --- old/mpc-1.2.0/NEWS 2020-07-23 14:44:44.000000000 +0200 +++ new/mpc-1.2.1/NEWS 2020-09-30 13:02:53.000000000 +0200 @@ -1,11 +1,16 @@ -Changes in version 1.2.0: +Changes in version 1.2.1, released in October 2020: + - Bug fixes: + - Fix an incompatibility problem with GMP 6.0 and before. + - Fix an intermediate overflow in asin. + +Changes in version 1.2.0 ("Hyacinthus orientalis"), released in August 2020: - Minimally required library version: MPFR 4.1.0 - New functions: mpc_sum, mpc_dot - Several functions are more robust with a reduced exponent range (for example corresponding to IEEE 754 binary formats) - New tool mpcheck. -Changes in version 1.1.0: +Changes in version 1.1.0 ("Gladiolus palustris"), released in January 2018: - Minimally required library versions: GMP 5.0.0 and MPFR 3.0.0 - Fixed issues with MPFR 4.0.0 - New functions: mpc_cmp_abs, mpc_rootofunity @@ -19,25 +24,25 @@ - Fixed a bug in mpc_atan(0,y) with |y| near 1, see http://lists.gforge.inria.fr/pipermail/mpc-discuss/2017-March/001404.html -Changes in version 1.0.3: +Changes in version 1.0.3, released in February 2015: - Fixed mpc_pow, see http://lists.gforge.inria.fr/pipermail/mpc-discuss/2014-October/001315.html - #18257: Switched to libtool 2.4.5. -Changes in version 1.0.2: +Changes in version 1.0.2, released in January 2014: - Fixed mpc_atan, mpc_atanh for (+-0, +-1), see http://gcc.gnu.org/bugzilla/show_bug.cgi?id=57994#c7 - Fixed mpc_log10 for purely imaginary argument, see http://lists.gforge.inria.fr/pipermail/mpc-discuss/2012-September/001208.htm... -Changes in version 1.0.1: +Changes in version 1.0.1, released in September 2012: - Switched to automake 1.11.6, see https://lists.gnu.org/archive/html/automake/2012-07/msg00023.html - #14669: Fixed extraction of CC from gmp.h - Fixed case of intermediate zero real or imaginary part in mpc_fma, found by hydra with GMP_CHECK_RANDOMIZE=1346362345 -Changes in version 1.0: +Changes in version 1.0 ("Fagus silvatica"), released in July 2012: - First release as a GNU package - License change: LGPLv3+ for code, GFDLv1.3+ (with no invariant sections) for documentation @@ -59,7 +64,7 @@ infinite part and equals output variable is corrected - mpc_fr_sub: Wrong return value for imaginary part is corrected -Changes in version 0.9: +Changes in version 0.9 ("Epilobium montanum"), released in February 2011: - New functions: - mpc_set_dc, mpc_set_ldc, mpc_get_dc, mpc_get_ldc for converting between mpc type variables and C variables of type double _Complex @@ -81,24 +86,24 @@ #include "mpc-log.h" instead of #include "mpc.h" - Minimally required library versions: gmp 4.3.2, mpfr 2.4.2 -Changes in version 0.8.2: +Changes in version 0.8.2, released in May 2010: - Speed-up of mpc_pow_ui through binary exponentiation -Changes in version 0.8.1: +Changes in version 0.8.1, released in December 2009: - Bug fixes: - mpc_acosh, mpc_asinh, mpc_atanh: swap of precisions between real and imaginary parts - mpc_atan: memory leak - mpc_log: wrong ternary value in data file; masked by bug in mpfr-2.4.1 -Changes in version 0.8 ("Dianthus deltoides"): +Changes in version 0.8 ("Dianthus deltoides"), released in November 2009: - New functions: - mpc_asin, mpc_acos, mpc_atan, mpc_asinh, mpc_acosh, mpc_atanh, mpc_pow_d, mpc_pow_ld, mpc_pow_si, mpc_pow_ui, mpc_pow_z, mpc_pow_fr - Bug fixes: - mpc_ui_div: real divisor -Changes in version 0.7 ("Campanula uniflora"): +Changes in version 0.7 ("Campanula uniflora"), released in September 2009: - New functions: mpc_pow, mpc_set_nan, mpc_swap - Bug fixes: - mpc_log: along branch cut @@ -111,7 +116,7 @@ - Changed MPC_SET_X_Y macro - Functions mpc_random and mpc_random2 removed -Changes in version 0.6 ("Bellis perennis"): +Changes in version 0.6 ("Bellis perennis"), released in April 2009: - New functions: mpc_get_str, mpc_set_str, mpc_strtoc, mpc_set_uj, mpc_set_sj, mpc_set_ld, mpc_set_ld_ld, mpc_set_si_si, mpc_set_uj_uj, mpc_set_sj_sj, mpc_set_f, mpc_set_f_f, mpc_set_q, mpc_set_q_q, mpc_set_z, @@ -130,14 +135,14 @@ - mpc_get_version and MPC_VERSION_STRING agree - Compilation on i686-pc-cygwin and i686-pc-mingw32 fixed -Changes in version 0.5.2: +Changes in version 0.5.2, released in December 2008: - New macros: - version number: MPC_VERSION_NUM, MPC_VERSION - Makefile.vc updated (thanks to Mickael Gastineau) - Compilation on Debian-Gnu-Linux-PowerPC and MacOsX fixed (thanks to Laurent Fousse and Mickael Gastineau) -Changes in version 0.5.1: +Changes in version 0.5.1, released in November 2008: - New functions: - mpc_set_fr_fr - mpc_real, mpc_imag @@ -162,7 +167,7 @@ - fix handling of special values: mpc_exp, mpc_log, mpc_mul, mpc_norm, mpc_sqr, mpc_sqrt -Changes in version 0.5 ("Aconitum neomontanum"): +Changes in version 0.5 ("Aconitum neomontanum"), released in September 2008: - Support for autotools - New functions: - logarithm diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/README new/mpc-1.2.1/README --- old/mpc-1.2.0/README 2020-07-23 14:44:44.000000000 +0200 +++ new/mpc-1.2.1/README 2020-08-21 14:28:40.000000000 +0200 @@ -24,8 +24,8 @@ 1. In the directory of the GNU MPC archive, type - tar xzf mpc-1.2.0.tar.gz - cd mpc-1.2.0 + tar xzf mpc-1.2.1.tar.gz + cd mpc-1.2.1 ./configure make diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/config.h.in new/mpc-1.2.1/config.h.in --- old/mpc-1.2.0/config.h.in 2020-08-17 17:00:14.000000000 +0200 +++ new/mpc-1.2.1/config.h.in 2020-10-20 18:26:31.000000000 +0200 @@ -39,9 +39,6 @@ /* Define to 1 if you have the <memory.h> header file. */ #undef HAVE_MEMORY_H -/* mpfr_fmma is not present */ -#undef HAVE_MPFR_FMMA - /* Define to 1 if you have the `setlocale' function. */ #undef HAVE_SETLOCALE diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/configure.ac new/mpc-1.2.1/configure.ac --- old/mpc-1.2.0/configure.ac 2020-08-17 16:54:28.000000000 +0200 +++ new/mpc-1.2.1/configure.ac 2020-10-20 18:26:01.000000000 +0200 @@ -20,7 +20,7 @@ # Process this file with autoconf to produce a configure script. AC_PREREQ(2.61) -AC_INIT(mpc, 1.2.0, mpc-discuss@lists.gforge.inria.fr) +AC_INIT(mpc, 1.2.1, mpc-discuss@lists.gforge.inria.fr) AC_CONFIG_SRCDIR([src/mpc-impl.h]) AC_CONFIG_AUX_DIR([build-aux]) AC_CONFIG_HEADER([config.h]) @@ -166,22 +166,6 @@ AC_MSG_ERROR([libmpfr not found or uses a different ABI (including static vs shared).]) ]) -AC_MSG_CHECKING(for mpfr_fmma) -LIBS="-lmpfr $LIBS" -AC_LINK_IFELSE( - [AC_LANG_PROGRAM( - [[#include "mpfr.h"]], - [[mpfr_t x; mpfr_fmma (x, x, x, x, x, 0);]] - )], - [ - AC_MSG_RESULT(yes) - AC_DEFINE(HAVE_MPFR_FMMA, 1, [mpfr_fmma is present]) - ], - [ - AC_MSG_RESULT(no) - AC_DEFINE(HAVE_MPFR_FMMA, 0, [mpfr_fmma is not present]) - ]) - # Check for a recent GMP # We only guarantee that with a *functional* and recent enough GMP version, # MPC will compile; we do not guarantee that GMP will compile. diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/doc/mpc.info new/mpc-1.2.1/doc/mpc.info --- old/mpc-1.2.0/doc/mpc.info 2020-08-17 17:00:20.000000000 +0200 +++ new/mpc-1.2.1/doc/mpc.info 2020-10-20 18:28:00.000000000 +0200 @@ -1,7 +1,7 @@ This is mpc.info, produced by makeinfo version 6.7 from mpc.texi. This manual is for GNU MPC, a library for multiple precision complex -arithmetic, version 1.2.0 of August 2020. +arithmetic, version 1.2.1 of October 2020. Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2016, 2018, 2020 INRIA @@ -23,7 +23,7 @@ ******* This manual documents how to install and use the GNU Multiple Precision -Complex Library, version 1.2.0 +Complex Library, version 1.2.1 * Menu: @@ -94,9 +94,9 @@ Here are the steps needed to install the library on Unix systems: - 1. 'tar xzf mpc-1.2.0.tar.gz' + 1. 'tar xzf mpc-1.2.1.tar.gz' - 2. 'cd mpc-1.2.0' + 2. 'cd mpc-1.2.1' 3. './configure' @@ -460,12 +460,12 @@ is done in case the current allocated space for the mantissa of X is sufficient. - -- Function: mpfr_prec_t mpc_get_prec (mpc_t X) + -- Function: mpfr_prec_t mpc_get_prec (const mpc_t X) If the real and imaginary part of X have the same precision, it is returned, otherwise, 0 is returned. -- Function: void mpc_get_prec2 (mpfr_prec_t* PR, mpfr_prec_t* PI, - mpc_t X) + const mpc_t X) Returns the precision of the real part of X via PR and of its imaginary part via PI. @@ -485,7 +485,7 @@ not in the current API, you can define them using the 'MPC_SET_X_Y' macro (*note Advanced Functions::). - -- Function: int mpc_set (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_set (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Set the value of ROP from OP, rounded to the precision of ROP with the given rounding mode RND. @@ -500,10 +500,10 @@ RND) -- Function: int mpc_set_ldc (mpc_t ROP, long double _Complex OP, mpc_rnd_t RND) - -- Function: int mpc_set_z (mpc_t ROP, mpz_t OP mpc_rnd_t RND) - -- Function: int mpc_set_q (mpc_t ROP, mpq_t OP mpc_rnd_t RND) - -- Function: int mpc_set_f (mpc_t ROP, mpf_t OP mpc_rnd_t RND) - -- Function: int mpc_set_fr (mpc_t ROP, mpfr_t OP, mpc_rnd_t RND) + -- Function: int mpc_set_z (mpc_t ROP, const mpz_t OP mpc_rnd_t RND) + -- Function: int mpc_set_q (mpc_t ROP, const mpq_t OP mpc_rnd_t RND) + -- Function: int mpc_set_f (mpc_t ROP, const mpf_t OP mpc_rnd_t RND) + -- Function: int mpc_set_fr (mpc_t ROP, const mpfr_t OP, mpc_rnd_t RND) Set the value of ROP from OP, rounded to the precision of ROP with the given rounding mode RND. The argument OP is interpreted as real, so the imaginary part of ROP is set to zero with a positive @@ -527,14 +527,14 @@ mpc_rnd_t RND) -- Function: int mpc_set_ld_ld (mpc_t ROP, long double OP1, long double OP2, mpc_rnd_t RND) - -- Function: int mpc_set_z_z (mpc_t ROP, mpz_t OP1, mpz_t OP2, - mpc_rnd_t RND) - -- Function: int mpc_set_q_q (mpc_t ROP, mpq_t OP1, mpq_t OP2, - mpc_rnd_t RND) - -- Function: int mpc_set_f_f (mpc_t ROP, mpf_t OP1, mpf_t OP2, - mpc_rnd_t RND) - -- Function: int mpc_set_fr_fr (mpc_t ROP, mpfr_t OP1, mpfr_t OP2, - mpc_rnd_t RND) + -- Function: int mpc_set_z_z (mpc_t ROP, const mpz_t OP1, const mpz_t + OP2, mpc_rnd_t RND) + -- Function: int mpc_set_q_q (mpc_t ROP, const mpq_t OP1, const mpq_t + OP2, mpc_rnd_t RND) + -- Function: int mpc_set_f_f (mpc_t ROP, const mpf_t OP1, const mpf_t + OP2, mpc_rnd_t RND) + -- Function: int mpc_set_fr_fr (mpc_t ROP, const mpfr_t OP1, const + mpfr_t OP2, mpc_rnd_t RND) Set the real part of ROP from OP1, and its imaginary part from OP2, according to the rounding mode RND. @@ -566,7 +566,7 @@ The following functions are available only if '<complex.h>' is included _before_ 'mpc.h'. - -- Function: double _Complex mpc_get_dc (mpc_t OP, mpc_rnd_t RND) + -- Function: double _Complex mpc_get_dc (const mpc_t OP, mpc_rnd_t RND) -- Function: long double _Complex mpc_get_ldc (mpc_t OP, mpc_rnd_t RND) Convert OP to a C complex number, using the rounding mode RND. @@ -621,8 +621,8 @@ number in base BASE; otherwise it returns -1, and ROP is set to NaN+i*NaN. - -- Function: char * mpc_get_str (int B, size_t N, mpc_t OP, mpc_rnd_t - RND) + -- Function: char * mpc_get_str (int B, size_t N, const mpc_t OP, + mpc_rnd_t RND) Convert OP to a string containing its real and imaginary parts, separated by a space and enclosed in a pair of parentheses. The numbers are written in base B (which may vary from 2 to 36) and @@ -683,7 +683,7 @@ problem. -- Function: size_t mpc_out_str (FILE *STREAM, int BASE, size_t - N_DIGITS, mpc_t OP, mpc_rnd_t RND) + N_DIGITS, const mpc_t OP, mpc_rnd_t RND) Output OP on stdio stream STREAM in base BASE, rounded according to RND, in the same format as for 'mpc_strtoc' If STREAM is the null pointer, ROP is written to 'stdout'. @@ -696,9 +696,9 @@ 5.5 Comparison Functions ======================== - -- Function: int mpc_cmp (mpc_t OP1, mpc_t OP2) - -- Function: int mpc_cmp_si_si (mpc_t OP1, long int OP2R, long int - OP2I) + -- Function: int mpc_cmp (const mpc_t OP1, const mpc_t OP2) + -- Function: int mpc_cmp_si_si (const mpc_t OP1, long int OP2R, long + int OP2I) -- Macro: int mpc_cmp_si (mpc_t OP1, long int OP2) Compare OP1 and OP2, where in the case of 'mpc_cmp_si_si', OP2 is @@ -713,7 +713,7 @@ The storage of the return value is such that equality can be simply checked with 'mpc_cmp (op1, op2) == 0'. - -- Function: int mpc_cmp_abs (mpc_t OP1, mpc_t OP2) + -- Function: int mpc_cmp_abs (const mpc_t OP1, const mpc_t OP2) Compare the absolute values of OP1 and OP2. The return value is 0 if both are the same (including infinity), positive if the absolute @@ -728,11 +728,11 @@ 5.6 Projection and Decomposing Functions ======================================== - -- Function: int mpc_real (mpfr_t ROP, mpc_t OP, mpfr_rnd_t RND) + -- Function: int mpc_real (mpfr_t ROP, const mpc_t OP, mpfr_rnd_t RND) Set ROP to the value of the real part of OP rounded in the direction RND. - -- Function: int mpc_imag (mpfr_t ROP, mpc_t OP, mpfr_rnd_t RND) + -- Function: int mpc_imag (mpfr_t ROP, const mpc_t OP, mpfr_rnd_t RND) Set ROP to the value of the imaginary part of OP rounded in the direction RND. @@ -742,11 +742,11 @@ respectively. The 'mpfr' functions can be used on the result of these macros (note that the 'mpfr_t' type is itself a pointer). - -- Function: int mpc_arg (mpfr_t ROP, mpc_t OP, mpfr_rnd_t RND) + -- Function: int mpc_arg (mpfr_t ROP, const mpc_t OP, mpfr_rnd_t RND) Set ROP to the argument of OP, with a branch cut along the negative real axis. - -- Function: int mpc_proj (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_proj (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Compute a projection of OP onto the Riemann sphere. Set ROP to OP rounded in the direction RND, except when at least one part of OP is infinite (even if the other part is a NaN) in which case the @@ -764,105 +764,105 @@ should essentially be the same as with the GNU MPFR library, with only a marginal overhead due to the GNU MPC layer. - -- Function: int mpc_add (mpc_t ROP, mpc_t OP1, mpc_t OP2, mpc_rnd_t - RND) - -- Function: int mpc_add_ui (mpc_t ROP, mpc_t OP1, unsigned long int - OP2, mpc_rnd_t RND) - -- Function: int mpc_add_fr (mpc_t ROP, mpc_t OP1, mpfr_t OP2, + -- Function: int mpc_add (mpc_t ROP, const mpc_t OP1, const mpc_t OP2, mpc_rnd_t RND) + -- Function: int mpc_add_ui (mpc_t ROP, const mpc_t OP1, unsigned long + int OP2, mpc_rnd_t RND) + -- Function: int mpc_add_fr (mpc_t ROP, const mpc_t OP1, const mpfr_t + OP2, mpc_rnd_t RND) Set ROP to OP1 + OP2 rounded according to RND. - -- Function: int mpc_sub (mpc_t ROP, mpc_t OP1, mpc_t OP2, mpc_rnd_t - RND) - -- Function: int mpc_sub_fr (mpc_t ROP, mpc_t OP1, mpfr_t OP2, - mpc_rnd_t RND) - -- Function: int mpc_fr_sub (mpc_t ROP, mpfr_t OP1, mpc_t OP2, + -- Function: int mpc_sub (mpc_t ROP, const mpc_t OP1, const mpc_t OP2, mpc_rnd_t RND) - -- Function: int mpc_sub_ui (mpc_t ROP, mpc_t OP1, unsigned long int + -- Function: int mpc_sub_fr (mpc_t ROP, const mpc_t OP1, const mpfr_t + OP2, mpc_rnd_t RND) + -- Function: int mpc_fr_sub (mpc_t ROP, const mpfr_t OP1, const mpc_t + OP2, mpc_rnd_t RND) + -- Function: int mpc_sub_ui (mpc_t ROP, const mpc_t OP1, unsigned long + int OP2, mpc_rnd_t RND) + -- Macro: int mpc_ui_sub (mpc_t ROP, unsigned long int OP1, const mpc_t OP2, mpc_rnd_t RND) - -- Macro: int mpc_ui_sub (mpc_t ROP, unsigned long int OP1, mpc_t OP2, - mpc_rnd_t RND) -- Function: int mpc_ui_ui_sub (mpc_t ROP, unsigned long int RE1, unsigned long int IM1, mpc_t OP2, mpc_rnd_t RND) Set ROP to OP1 - OP2 rounded according to RND. For 'mpc_ui_ui_sub', OP1 is RE1 + IM1. - -- Function: int mpc_neg (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_neg (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Set ROP to -OP rounded according to RND. Just changes the sign if ROP and OP are the same variable. - -- Function: int mpc_sum (mpc_t ROP, mpc_ptr* OP, unsigned long N, - mpc_rnd_t RND) + -- Function: int mpc_sum (mpc_t ROP, const mpc_ptr* OP, unsigned long + N, mpc_rnd_t RND) Set ROP to the sum of the elements in the array OP of length N, rounded according to RND. - -- Function: int mpc_mul (mpc_t ROP, mpc_t OP1, mpc_t OP2, mpc_rnd_t - RND) - -- Function: int mpc_mul_ui (mpc_t ROP, mpc_t OP1, unsigned long int - OP2, mpc_rnd_t RND) - -- Function: int mpc_mul_si (mpc_t ROP, mpc_t OP1, long int OP2, + -- Function: int mpc_mul (mpc_t ROP, const mpc_t OP1, const mpc_t OP2, mpc_rnd_t RND) - -- Function: int mpc_mul_fr (mpc_t ROP, mpc_t OP1, mpfr_t OP2, + -- Function: int mpc_mul_ui (mpc_t ROP, const mpc_t OP1, unsigned long + int OP2, mpc_rnd_t RND) + -- Function: int mpc_mul_si (mpc_t ROP, const mpc_t OP1, long int OP2, mpc_rnd_t RND) + -- Function: int mpc_mul_fr (mpc_t ROP, const mpc_t OP1, const mpfr_t + OP2, mpc_rnd_t RND) Set ROP to OP1 times OP2 rounded according to RND. Note: for 'mpc_mul', in case OP1 and OP2 have the same value, use 'mpc_sqr' for better efficiency. - -- Function: int mpc_mul_i (mpc_t ROP, mpc_t OP, int SGN, mpc_rnd_t - RND) + -- Function: int mpc_mul_i (mpc_t ROP, const mpc_t OP, int SGN, + mpc_rnd_t RND) Set ROP to OP times the imaginary unit i if SGN is non-negative, set ROP to OP times -i otherwise, in both cases rounded according to RND. - -- Function: int mpc_sqr (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_sqr (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Set ROP to the square of OP rounded according to RND. - -- Function: int mpc_fma (mpc_t ROP, mpc_t OP1, mpc_t OP2, mpc_t OP3, - mpc_rnd_t RND) + -- Function: int mpc_fma (mpc_t ROP, const mpc_t OP1, const mpc_t OP2, + const mpc_t OP3, mpc_rnd_t RND) Set ROP to OP1*OP2+OP3, rounded according to RND, with only one final rounding. - -- Function: int mpc_dot (mpc_t ROP, mpc_ptr* OP1, mpc_ptr* OP2, + -- Function: int mpc_dot (mpc_t ROP, const mpc_ptr* OP1, mpc_ptr* OP2, unsigned long N, mpc_rnd_t RND) Set ROP to the dot product of the elements in the arrays OP1 and OP2, both of length N, rounded according to RND. - -- Function: int mpc_div (mpc_t ROP, mpc_t OP1, mpc_t OP2, mpc_rnd_t - RND) - -- Function: int mpc_div_ui (mpc_t ROP, mpc_t OP1, unsigned long int - OP2, mpc_rnd_t RND) - -- Function: int mpc_div_fr (mpc_t ROP, mpc_t OP1, mpfr_t OP2, + -- Function: int mpc_div (mpc_t ROP, const mpc_t OP1, const mpc_t OP2, mpc_rnd_t RND) - -- Function: int mpc_ui_div (mpc_t ROP, unsigned long int OP1, mpc_t + -- Function: int mpc_div_ui (mpc_t ROP, const mpc_t OP1, unsigned long + int OP2, mpc_rnd_t RND) + -- Function: int mpc_div_fr (mpc_t ROP, const mpc_t OP1, const mpfr_t + OP2, mpc_rnd_t RND) + -- Function: int mpc_ui_div (mpc_t ROP, unsigned long int OP1, const + mpc_t OP2, mpc_rnd_t RND) + -- Function: int mpc_fr_div (mpc_t ROP, const mpfr_t OP1, const mpc_t OP2, mpc_rnd_t RND) - -- Function: int mpc_fr_div (mpc_t ROP, mpfr_t OP1, mpc_t OP2, - mpc_rnd_t RND) Set ROP to OP1/OP2 rounded according to RND. - -- Function: int mpc_conj (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_conj (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Set ROP to the conjugate of OP rounded according to RND. Just changes the sign of the imaginary part if ROP and OP are the same variable. - -- Function: int mpc_abs (mpfr_t ROP, mpc_t OP, mpfr_rnd_t RND) + -- Function: int mpc_abs (mpfr_t ROP, const mpc_t OP, mpfr_rnd_t RND) Set the floating-point number ROP to the absolute value of OP, rounded in the direction RND. - -- Function: int mpc_norm (mpfr_t ROP, mpc_t OP, mpfr_rnd_t RND) + -- Function: int mpc_norm (mpfr_t ROP, const mpc_t OP, mpfr_rnd_t RND) Set the floating-point number ROP to the norm of OP (i.e., the square of its absolute value), rounded in the direction RND. - -- Function: int mpc_mul_2ui (mpc_t ROP, mpc_t OP1, unsigned long int - OP2, mpc_rnd_t RND) - -- Function: int mpc_mul_2si (mpc_t ROP, mpc_t OP1, long int OP2, + -- Function: int mpc_mul_2ui (mpc_t ROP, const mpc_t OP1, unsigned long + int OP2, mpc_rnd_t RND) + -- Function: int mpc_mul_2si (mpc_t ROP, const mpc_t OP1, long int OP2, mpc_rnd_t RND) Set ROP to OP1 times 2 raised to OP2 rounded according to RND. Just modifies the exponents of the real and imaginary parts by OP2 when ROP and OP1 are identical. - -- Function: int mpc_div_2ui (mpc_t ROP, mpc_t OP1, unsigned long int - OP2, mpc_rnd_t RND) - -- Function: int mpc_div_2si (mpc_t ROP, mpc_t OP1, long int OP2, + -- Function: int mpc_div_2ui (mpc_t ROP, const mpc_t OP1, unsigned long + int OP2, mpc_rnd_t RND) + -- Function: int mpc_div_2si (mpc_t ROP, const mpc_t OP1, long int OP2, mpc_rnd_t RND) Set ROP to OP1 divided by 2 raised to OP2 rounded according to RND. Just modifies the exponents of the real and imaginary parts by OP2 @@ -874,25 +874,25 @@ 5.8 Power Functions and Logarithm ================================= - -- Function: int mpc_sqrt (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_sqrt (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Set ROP to the square root of OP rounded according to RND. The returned value ROP has a non-negative real part, and if its real part is zero, a non-negative imaginary part. - -- Function: int mpc_pow (mpc_t ROP, mpc_t OP1, mpc_t OP2, mpc_rnd_t - RND) - -- Function: int mpc_pow_d (mpc_t ROP, mpc_t OP1, double OP2, mpc_rnd_t - RND) - -- Function: int mpc_pow_ld (mpc_t ROP, mpc_t OP1, long double OP2, + -- Function: int mpc_pow (mpc_t ROP, const mpc_t OP1, const mpc_t OP2, mpc_rnd_t RND) - -- Function: int mpc_pow_si (mpc_t ROP, mpc_t OP1, long OP2, mpc_rnd_t - RND) - -- Function: int mpc_pow_ui (mpc_t ROP, mpc_t OP1, unsigned long OP2, + -- Function: int mpc_pow_d (mpc_t ROP, const mpc_t OP1, double OP2, mpc_rnd_t RND) - -- Function: int mpc_pow_z (mpc_t ROP, mpc_t OP1, mpz_t OP2, mpc_rnd_t - RND) - -- Function: int mpc_pow_fr (mpc_t ROP, mpc_t OP1, mpfr_t OP2, + -- Function: int mpc_pow_ld (mpc_t ROP, const mpc_t OP1, long double + OP2, mpc_rnd_t RND) + -- Function: int mpc_pow_si (mpc_t ROP, const mpc_t OP1, long OP2, mpc_rnd_t RND) + -- Function: int mpc_pow_ui (mpc_t ROP, const mpc_t OP1, unsigned long + OP2, mpc_rnd_t RND) + -- Function: int mpc_pow_z (mpc_t ROP, const mpc_t OP1, const mpz_t + OP2, mpc_rnd_t RND) + -- Function: int mpc_pow_fr (mpc_t ROP, const mpc_t OP1, const mpfr_t + OP2, mpc_rnd_t RND) Set ROP to OP1 raised to the power OP2, rounded according to RND. For 'mpc_pow_d', 'mpc_pow_ld', 'mpc_pow_si', 'mpc_pow_ui', 'mpc_pow_z' and 'mpc_pow_fr', the imaginary part of OP2 is @@ -900,12 +900,12 @@ real part 1, and imaginary part 0, with sign being the opposite of that of OP2. - -- Function: int mpc_exp (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_exp (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Set ROP to the exponential of OP, rounded according to RND with the precision of ROP. - -- Function: int mpc_log (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - -- Function: int mpc_log10 (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_log (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_log10 (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Set ROP to the natural and base-10 logarithm of OP respectively, rounded according to RND with the precision of ROP. The principal branch is chosen, with the branch cut on the negative real axis, so @@ -924,48 +924,36 @@ 5.9 Trigonometric Functions =========================== - -- Function: int mpc_sin (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - Set ROP to the sine of OP, rounded according to RND with the - precision of ROP. + -- Function: int mpc_sin (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_cos (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_tan (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + Set ROP to the sine, cosine, tangent of OP, rounded according to + RND with the precision of ROP. - -- Function: int mpc_cos (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - Set ROP to the cosine of OP, rounded according to RND with the - precision of ROP. - - -- Function: int mpc_sin_cos (mpc_t ROP_SIN, mpc_t ROP_COS, mpc_t OP, - mpc_rnd_t RND_SIN, mpc_rnd_t RND_COS) + -- Function: int mpc_sin_cos (mpc_t ROP_SIN, mpc_t ROP_COS, const mpc_t + OP, mpc_rnd_t RND_SIN, mpc_rnd_t RND_COS) Set ROP_SIN to the sine of OP, rounded according to RND_SIN with the precision of ROP_SIN, and ROP_COS to the cosine of OP, rounded according to RND_COS with the precision of ROP_COS. - -- Function: int mpc_tan (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - Set ROP to the tangent of OP, rounded according to RND with the - precision of ROP. - - -- Function: int mpc_sinh (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - Set ROP to the hyperbolic sine of OP, rounded according to RND with - the precision of ROP. - - -- Function: int mpc_cosh (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - Set ROP to the hyperbolic cosine of OP, rounded according to RND - with the precision of ROP. - - -- Function: int mpc_tanh (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - Set ROP to the hyperbolic tangent of OP, rounded according to RND - with the precision of ROP. - - -- Function: int mpc_asin (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - -- Function: int mpc_acos (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - -- Function: int mpc_atan (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_sinh (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_cosh (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_tanh (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + Set ROP to the hyperbolic sine, hyperbolic cosine, hyperbolic + tangent of OP, rounded according to RND with the precision of ROP. + + -- Function: int mpc_asin (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_acos (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_atan (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Set ROP to the inverse sine, inverse cosine, inverse tangent of OP, rounded according to RND with the precision of ROP. - -- Function: int mpc_asinh (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - -- Function: int mpc_acosh (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) - -- Function: int mpc_atanh (mpc_t ROP, mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_asinh (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_acosh (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) + -- Function: int mpc_atanh (mpc_t ROP, const mpc_t OP, mpc_rnd_t RND) Set ROP to the inverse hyperbolic sine, inverse hyperbolic cosine, inverse hyperbolic tangent of OP, rounded according to RND with the - precision of ROP. The branch cut of MPC_ACOSH is (-Inf, 1) + precision of ROP. The branch cut of 'mpc_acosh' is (-Inf, 1) File: mpc.info, Node: Miscellaneous Complex Functions, Next: Advanced Functions, Prev: Trigonometric Functions, Up: Complex Functions @@ -1030,7 +1018,7 @@ return-value.). For instance, you can define mpc_set_ui_fr as follows: - int mpc_set_ui_fr (mpc_t rop, long int re, double im, mpc_rnd_t rnd) + int mpc_set_ui_fr (mpc_t rop, unsigned long int re, mpfr_t im, mpc_rnd_t rnd) MPC_SET_X_Y (ui, fr, rop, re, im, rnd); @@ -1053,18 +1041,16 @@ References ********** - * Torbjörn Granlund et al. 'gmp' - GNU multiprecision library. - Version 4.2.4, <http://gmplib.org/>. + * Torbjörn Granlund et al. 'GMP' - GNU multiprecision library. + Version 6.2.0, <http://gmplib.org>. * Guillaume Hanrot, Vincent Lefèvre, Patrick Pélissier, Paul - Zimmermann et al. 'mpfr' - A library for multiple-precision - floating-point computations with exact rounding. Version 2.4.1, + Zimmermann et al. 'MPFR' - A library for multiple-precision + floating-point computations with exact rounding. Version 4.1.0, <http://www.mpfr.org>. - * IEEE standard for binary floating-point arithmetic, Technical - Report ANSI-IEEE Standard 754-1985, New York, 1985. Approved March - 21, 1985: IEEE Standards Board; approved July 26, 1985: American - National Standards Institute, 18 pages. + * IEEE Standard for Floating-Point Arithmetic, IEEE Computer Society, + IEEE Std 754-2019, Approved 13 June 2019, 84 pages. * Donald E. Knuth, "The Art of Computer Programming", vol 2, "Seminumerical Algorithms", 2nd edition, Addison-Wesley, 1981. @@ -1124,22 +1110,22 @@ (line 9) * mpc_abs: Basic Arithmetic. (line 91) * mpc_acos: Trigonometric Functions. - (line 37) + (line 25) * mpc_acosh: Trigonometric Functions. - (line 43) + (line 31) * mpc_add: Basic Arithmetic. (line 11) * mpc_add_fr: Basic Arithmetic. (line 15) * mpc_add_ui: Basic Arithmetic. (line 13) * mpc_arg: Projection & Decomposing. (line 20) * mpc_asin: Trigonometric Functions. - (line 36) + (line 24) * mpc_asinh: Trigonometric Functions. - (line 42) + (line 30) * mpc_atan: Trigonometric Functions. - (line 38) + (line 26) * mpc_atanh: Trigonometric Functions. - (line 44) + (line 32) * mpc_clear: Initializing Complex Numbers. (line 21) * mpc_cmp: Complex Comparison. (line 6) @@ -1148,9 +1134,9 @@ * mpc_cmp_si_si: Complex Comparison. (line 7) * mpc_conj: Basic Arithmetic. (line 86) * mpc_cos: Trigonometric Functions. - (line 10) + (line 7) * mpc_cosh: Trigonometric Functions. - (line 28) + (line 19) * mpc_div: Basic Arithmetic. (line 74) * mpc_div_2si: Basic Arithmetic. (line 109) * mpc_div_2ui: Basic Arithmetic. (line 107) @@ -1278,9 +1264,9 @@ * mpc_sin: Trigonometric Functions. (line 6) * mpc_sinh: Trigonometric Functions. - (line 24) + (line 18) * mpc_sin_cos: Trigonometric Functions. - (line 14) + (line 12) * mpc_sqr: Basic Arithmetic. (line 61) * mpc_sqrt: Power Functions and Logarithm. (line 6) @@ -1294,9 +1280,9 @@ (line 82) * mpc_t: GNU MPC Basics. (line 15) * mpc_tan: Trigonometric Functions. - (line 20) + (line 8) * mpc_tanh: Trigonometric Functions. - (line 32) + (line 20) * mpc_ui_div: Basic Arithmetic. (line 80) * mpc_ui_sub: Basic Arithmetic. (line 27) * mpc_ui_ui_sub: Basic Arithmetic. (line 29) @@ -1801,30 +1787,30 @@ Tag Table: -Node: Top758 -Node: Copying1465 -Node: Introduction to GNU MPC2237 -Node: Installing GNU MPC2956 -Node: Reporting Bugs8041 -Node: GNU MPC Basics9385 -Ref: return-value13062 -Node: Complex Functions14513 -Node: Initializing Complex Numbers15673 -Node: Assigning Complex Numbers18060 -Node: Converting Complex Numbers22460 -Node: String and Stream Input and Output23085 -Node: Complex Comparison29641 -Node: Projection & Decomposing31154 -Node: Basic Arithmetic32531 -Node: Power Functions and Logarithm37531 -Node: Trigonometric Functions39880 -Node: Miscellaneous Complex Functions42101 -Node: Advanced Functions44277 -Node: Internals45350 -Node: References45801 -Node: Concept Index46704 -Node: Function Index49018 -Node: GNU Free Documentation License63166 +Node: Top759 +Node: Copying1466 +Node: Introduction to GNU MPC2238 +Node: Installing GNU MPC2957 +Node: Reporting Bugs8042 +Node: GNU MPC Basics9386 +Ref: return-value13063 +Node: Complex Functions14514 +Node: Initializing Complex Numbers15674 +Node: Assigning Complex Numbers18073 +Node: Converting Complex Numbers22551 +Node: String and Stream Input and Output23182 +Node: Complex Comparison29750 +Node: Projection & Decomposing31293 +Node: Basic Arithmetic32694 +Node: Power Functions and Logarithm37946 +Node: Trigonometric Functions40379 +Node: Miscellaneous Complex Functions42344 +Node: Advanced Functions44520 +Node: Internals45602 +Node: References46053 +Node: Concept Index46830 +Node: Function Index49144 +Node: GNU Free Documentation License63292 End Tag Table diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/doc/mpc.texi new/mpc-1.2.1/doc/mpc.texi --- old/mpc-1.2.0/doc/mpc.texi 2020-08-17 17:00:15.000000000 +0200 +++ new/mpc-1.2.1/doc/mpc.texi 2020-10-20 18:27:59.000000000 +0200 @@ -549,12 +549,12 @@ case the current allocated space for the mantissa of @var{x} is sufficient. @end deftypefun -@deftypefun mpfr_prec_t mpc_get_prec (mpc_t @var{x}) +@deftypefun mpfr_prec_t mpc_get_prec (const mpc_t @var{x}) If the real and imaginary part of @var{x} have the same precision, it is returned, otherwise, 0 is returned. @end deftypefun -@deftypefun void mpc_get_prec2 (mpfr_prec_t* @var{pr}, mpfr_prec_t* @var{pi}, mpc_t @var{x}) +@deftypefun void mpc_get_prec2 (mpfr_prec_t* @var{pr}, mpfr_prec_t* @var{pi}, const mpc_t @var{x}) Returns the precision of the real part of @var{x} via @var{pr} and of its imaginary part via @var{pi}. @end deftypefun @@ -576,7 +576,7 @@ If you need assignment functions that are not in the current API, you can define them using the @code{MPC_SET_X_Y} macro (@pxref{Advanced Functions}). -@deftypefun int mpc_set (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_set (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Set the value of @var{rop} from @var{op}, rounded to the precision of @var{rop} with the given rounding mode @var{rnd}. @end deftypefun @@ -589,10 +589,10 @@ @deftypefunx int mpc_set_ld (mpc_t @var{rop}, long double @var{op}, mpc_rnd_t @var{rnd}) @deftypefunx int mpc_set_dc (mpc_t @var{rop}, double _Complex @var{op}, mpc_rnd_t @var{rnd}) @deftypefunx int mpc_set_ldc (mpc_t @var{rop}, long double _Complex @var{op}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_set_z (mpc_t @var{rop}, mpz_t @var{op} mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_set_q (mpc_t @var{rop}, mpq_t @var{op} mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_set_f (mpc_t @var{rop}, mpf_t @var{op} mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_set_fr (mpc_t @var{rop}, mpfr_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_set_z (mpc_t @var{rop}, const mpz_t @var{op} mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_set_q (mpc_t @var{rop}, const mpq_t @var{op} mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_set_f (mpc_t @var{rop}, const mpf_t @var{op} mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_set_fr (mpc_t @var{rop}, const mpfr_t @var{op}, mpc_rnd_t @var{rnd}) Set the value of @var{rop} from @var{op}, rounded to the precision of @var{rop} with the given rounding mode @var{rnd}. The argument @var{op} is interpreted as real, so the imaginary part of @@ -611,10 +611,10 @@ @deftypefunx int mpc_set_sj_sj (mpc_t @var{rop}, intmax_t @var{op1}, intmax_t @var{op2}, mpc_rnd_t @var{rnd}) @deftypefunx int mpc_set_d_d (mpc_t @var{rop}, double @var{op1}, double @var{op2}, mpc_rnd_t @var{rnd}) @deftypefunx int mpc_set_ld_ld (mpc_t @var{rop}, long double @var{op1}, long double @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_set_z_z (mpc_t @var{rop}, mpz_t @var{op1}, mpz_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_set_q_q (mpc_t @var{rop}, mpq_t @var{op1}, mpq_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_set_f_f (mpc_t @var{rop}, mpf_t @var{op1}, mpf_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_set_fr_fr (mpc_t @var{rop}, mpfr_t @var{op1}, mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_set_z_z (mpc_t @var{rop}, const mpz_t @var{op1}, const mpz_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_set_q_q (mpc_t @var{rop}, const mpq_t @var{op1}, const mpq_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_set_f_f (mpc_t @var{rop}, const mpf_t @var{op1}, const mpf_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_set_fr_fr (mpc_t @var{rop}, const mpfr_t @var{op1}, const mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) Set the real part of @var{rop} from @var{op1}, and its imaginary part from @var{op2}, according to the rounding mode @var{rnd}. @@ -647,7 +647,7 @@ The following functions are available only if @code{<complex.h>} is included @emph{before} @file{mpc.h}. -@deftypefun double _Complex mpc_get_dc (mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun double _Complex mpc_get_dc (const mpc_t @var{op}, mpc_rnd_t @var{rnd}) @deftypefunx {long double _Complex} mpc_get_ldc (mpc_t @var{op}, mpc_rnd_t @var{rnd}) Convert @var{op} to a C complex number, using the rounding mode @var{rnd}. @end deftypefun @@ -711,7 +711,7 @@ NaN+i*NaN. @end deftypefun -@deftypefun {char *} mpc_get_str (int @var{b}, size_t @var{n}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun {char *} mpc_get_str (int @var{b}, size_t @var{n}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Convert @var{op} to a string containing its real and imaginary parts, separated by a space and enclosed in a pair of parentheses. The numbers are written in base @var{b} (which may vary from 2 to 36) and @@ -776,7 +776,7 @@ to avoid this problem. @end deftypefun -@deftypefun size_t mpc_out_str (FILE *@var{stream}, int @var{base}, size_t @var{n_digits}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun size_t mpc_out_str (FILE *@var{stream}, int @var{base}, size_t @var{n_digits}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Output @var{op} on stdio stream @var{stream} in base @var{base}, rounded according to @var{rnd}, in the same format as for @code{mpc_strtoc} @@ -791,8 +791,8 @@ @cindex Complex comparisons functions @cindex Comparison functions -@deftypefn Function int mpc_cmp (mpc_t @var{op1}, mpc_t @var{op2}) -@deftypefnx Function int mpc_cmp_si_si (mpc_t @var{op1}, long int @var{op2r}, long int @var{op2i}) +@deftypefn Function int mpc_cmp (const mpc_t @var{op1}, const mpc_t @var{op2}) +@deftypefnx Function int mpc_cmp_si_si (const mpc_t @var{op1}, long int @var{op2r}, long int @var{op2i}) @deftypefnx Macro int mpc_cmp_si (mpc_t @var{op1}, long int @var{op2}) Compare @var{op1} and @var{op2}, where in the case of @code{mpc_cmp_si_si}, @@ -810,7 +810,7 @@ with @code{mpc_cmp (op1, op2) == 0}. @end deftypefn -@deftypefn Function int mpc_cmp_abs (mpc_t @var{op1}, mpc_t @var{op2}) +@deftypefn Function int mpc_cmp_abs (const mpc_t @var{op1}, const mpc_t @var{op2}) Compare the absolute values of @var{op1} and @var{op2}. The return value is 0 if both are the same (including infinity), @@ -826,12 +826,12 @@ @section Projection and Decomposing Functions @cindex Projection and Decomposing Functions -@deftypefn Function int mpc_real (mpfr_t @var{rop}, mpc_t @var{op}, mpfr_rnd_t @var{rnd}) +@deftypefn Function int mpc_real (mpfr_t @var{rop}, const mpc_t @var{op}, mpfr_rnd_t @var{rnd}) Set @var{rop} to the value of the real part of @var{op} rounded in the direction @var{rnd}. @end deftypefn -@deftypefn Function int mpc_imag (mpfr_t @var{rop}, mpc_t @var{op}, mpfr_rnd_t @var{rnd}) +@deftypefn Function int mpc_imag (mpfr_t @var{rop}, const mpc_t @var{op}, mpfr_rnd_t @var{rnd}) Set @var{rop} to the value of the imaginary part of @var{op} rounded in the direction @var{rnd}. @end deftypefn @@ -843,12 +843,12 @@ macros (note that the @code{mpfr_t} type is itself a pointer). @end deftypefn -@deftypefn Function int mpc_arg (mpfr_t @var{rop}, mpc_t @var{op}, mpfr_rnd_t @var{rnd}) +@deftypefn Function int mpc_arg (mpfr_t @var{rop}, const mpc_t @var{op}, mpfr_rnd_t @var{rnd}) Set @var{rop} to the argument of @var{op}, with a branch cut along the negative real axis. @end deftypefn -@deftypefn Function int mpc_proj (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefn Function int mpc_proj (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Compute a projection of @var{op} onto the Riemann sphere. Set @var{rop} to @var{op} rounded in the direction @var{rnd}, except when at least one part of @var{op} is infinite (even if the other part is a NaN) in which case the real @@ -867,96 +867,96 @@ essentially be the same as with the GNU MPFR library, with only a marginal overhead due to the GNU MPC layer. -@deftypefun int mpc_add (mpc_t @var{rop}, mpc_t @var{op1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_add_ui (mpc_t @var{rop}, mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_add_fr (mpc_t @var{rop}, mpc_t @var{op1}, mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_add (mpc_t @var{rop}, const mpc_t @var{op1}, const mpc_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_add_ui (mpc_t @var{rop}, const mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_add_fr (mpc_t @var{rop}, const mpc_t @var{op1}, const mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) Set @var{rop} to @var{op1} @math{+} @var{op2} rounded according to @var{rnd}. @end deftypefun -@deftypefn Function int mpc_sub (mpc_t @var{rop}, mpc_t @var{op1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefnx Function int mpc_sub_fr (mpc_t @var{rop}, mpc_t @var{op1}, mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefnx Function int mpc_fr_sub (mpc_t @var{rop}, mpfr_t @var{op1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefnx Function int mpc_sub_ui (mpc_t @var{rop}, mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefnx Macro int mpc_ui_sub (mpc_t @var{rop}, unsigned long int @var{op1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefn Function int mpc_sub (mpc_t @var{rop}, const mpc_t @var{op1}, const mpc_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefnx Function int mpc_sub_fr (mpc_t @var{rop}, const mpc_t @var{op1}, const mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefnx Function int mpc_fr_sub (mpc_t @var{rop}, const mpfr_t @var{op1}, const mpc_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefnx Function int mpc_sub_ui (mpc_t @var{rop}, const mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefnx Macro int mpc_ui_sub (mpc_t @var{rop}, unsigned long int @var{op1}, const mpc_t @var{op2}, mpc_rnd_t @var{rnd}) @deftypefnx Function int mpc_ui_ui_sub (mpc_t @var{rop}, unsigned long int @var{re1}, unsigned long int @var{im1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) Set @var{rop} to @var{op1} @minus{} @var{op2} rounded according to @var{rnd}. For @code{mpc_ui_ui_sub}, @var{op1} is @var{re1} + @var{im1}. @end deftypefn -@deftypefun int mpc_neg (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_neg (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Set @var{rop} to @minus{}@var{op} rounded according to @var{rnd}. Just changes the sign if @var{rop} and @var{op} are the same variable. @end deftypefun -@deftypefun int mpc_sum (mpc_t @var{rop}, mpc_ptr* @var{op}, unsigned long @var{n}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_sum (mpc_t @var{rop}, const mpc_ptr* @var{op}, unsigned long @var{n}, mpc_rnd_t @var{rnd}) Set @var{rop} to the sum of the elements in the array @var{op} of length @var{n}, rounded according to @var{rnd}. @end deftypefun -@deftypefun int mpc_mul (mpc_t @var{rop}, mpc_t @var{op1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_mul_ui (mpc_t @var{rop}, mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_mul_si (mpc_t @var{rop}, mpc_t @var{op1}, long int @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_mul_fr (mpc_t @var{rop}, mpc_t @var{op1}, mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_mul (mpc_t @var{rop}, const mpc_t @var{op1}, const mpc_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_mul_ui (mpc_t @var{rop}, const mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_mul_si (mpc_t @var{rop}, const mpc_t @var{op1}, long int @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_mul_fr (mpc_t @var{rop}, const mpc_t @var{op1}, const mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) Set @var{rop} to @var{op1} times @var{op2} rounded according to @var{rnd}. Note: for @code{mpc_mul}, in case @var{op1} and @var{op2} have the same value, use @code{mpc_sqr} for better efficiency. @end deftypefun -@deftypefun int mpc_mul_i (mpc_t @var{rop}, mpc_t @var{op}, int @var{sgn}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_mul_i (mpc_t @var{rop}, const mpc_t @var{op}, int @var{sgn}, mpc_rnd_t @var{rnd}) Set @var{rop} to @var{op} times the imaginary unit i if @var{sgn} is non-negative, set @var{rop} to @var{op} times -i otherwise, in both cases rounded according to @var{rnd}. @end deftypefun -@deftypefun int mpc_sqr (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_sqr (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Set @var{rop} to the square of @var{op} rounded according to @var{rnd}. @end deftypefun -@deftypefun int mpc_fma (mpc_t @var{rop}, mpc_t @var{op1}, mpc_t @var{op2}, mpc_t @var{op3}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_fma (mpc_t @var{rop}, const mpc_t @var{op1}, const mpc_t @var{op2}, const mpc_t @var{op3}, mpc_rnd_t @var{rnd}) Set @var{rop} to @var{op1}*@var{op2}+@var{op3}, rounded according to @var{rnd}, with only one final rounding. @end deftypefun -@deftypefun int mpc_dot (mpc_t @var{rop}, mpc_ptr* @var{op1}, mpc_ptr* @var{op2}, unsigned long @var{n}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_dot (mpc_t @var{rop}, const mpc_ptr* @var{op1}, mpc_ptr* @var{op2}, unsigned long @var{n}, mpc_rnd_t @var{rnd}) Set @var{rop} to the dot product of the elements in the arrays @var{op1} and @var{op2}, both of length @var{n}, rounded according to @var{rnd}. @end deftypefun -@deftypefun int mpc_div (mpc_t @var{rop}, mpc_t @var{op1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_div_ui (mpc_t @var{rop}, mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_div_fr (mpc_t @var{rop}, mpc_t @var{op1}, mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_ui_div (mpc_t @var{rop}, unsigned long int @var{op1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_fr_div (mpc_t @var{rop}, mpfr_t @var{op1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_div (mpc_t @var{rop}, const mpc_t @var{op1}, const mpc_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_div_ui (mpc_t @var{rop}, const mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_div_fr (mpc_t @var{rop}, const mpc_t @var{op1}, const mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_ui_div (mpc_t @var{rop}, unsigned long int @var{op1}, const mpc_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_fr_div (mpc_t @var{rop}, const mpfr_t @var{op1}, const mpc_t @var{op2}, mpc_rnd_t @var{rnd}) Set @var{rop} to @var{op1}/@var{op2} rounded according to @var{rnd}. @end deftypefun -@deftypefun int mpc_conj (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_conj (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Set @var{rop} to the conjugate of @var{op} rounded according to @var{rnd}. Just changes the sign of the imaginary part if @var{rop} and @var{op} are the same variable. @end deftypefun -@deftypefun int mpc_abs (mpfr_t @var{rop}, mpc_t @var{op}, mpfr_rnd_t @var{rnd}) +@deftypefun int mpc_abs (mpfr_t @var{rop}, const mpc_t @var{op}, mpfr_rnd_t @var{rnd}) Set the floating-point number @var{rop} to the absolute value of @var{op}, rounded in the direction @var{rnd}. @end deftypefun -@deftypefun int mpc_norm (mpfr_t @var{rop}, mpc_t @var{op}, mpfr_rnd_t @var{rnd}) +@deftypefun int mpc_norm (mpfr_t @var{rop}, const mpc_t @var{op}, mpfr_rnd_t @var{rnd}) Set the floating-point number @var{rop} to the norm of @var{op} (i.e., the square of its absolute value), rounded in the direction @var{rnd}. @end deftypefun -@deftypefun int mpc_mul_2ui (mpc_t @var{rop}, mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_mul_2si (mpc_t @var{rop}, mpc_t @var{op1}, long int @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_mul_2ui (mpc_t @var{rop}, const mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_mul_2si (mpc_t @var{rop}, const mpc_t @var{op1}, long int @var{op2}, mpc_rnd_t @var{rnd}) Set @var{rop} to @var{op1} times 2 raised to @var{op2} rounded according to @var{rnd}. Just modifies the exponents of the real and imaginary parts by @var{op2} when @var{rop} and @var{op1} are identical. @end deftypefun -@deftypefun int mpc_div_2ui (mpc_t @var{rop}, mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_div_2si (mpc_t @var{rop}, mpc_t @var{op1}, long int @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_div_2ui (mpc_t @var{rop}, const mpc_t @var{op1}, unsigned long int @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_div_2si (mpc_t @var{rop}, const mpc_t @var{op1}, long int @var{op2}, mpc_rnd_t @var{rnd}) Set @var{rop} to @var{op1} divided by 2 raised to @var{op2} rounded according to @var{rnd}. Just modifies the exponents of the real and imaginary parts by @var{op2} @@ -969,19 +969,19 @@ @cindex Power functions @cindex Logarithm -@deftypefun int mpc_sqrt (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_sqrt (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Set @var{rop} to the square root of @var{op} rounded according to @var{rnd}. The returned value @var{rop} has a non-negative real part, and if its real part is zero, a non-negative imaginary part. @end deftypefun -@deftypefun int mpc_pow (mpc_t @var{rop}, mpc_t @var{op1}, mpc_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_pow_d (mpc_t @var{rop}, mpc_t @var{op1}, double @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_pow_ld (mpc_t @var{rop}, mpc_t @var{op1}, long double @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_pow_si (mpc_t @var{rop}, mpc_t @var{op1}, long @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_pow_ui (mpc_t @var{rop}, mpc_t @var{op1}, unsigned long @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_pow_z (mpc_t @var{rop}, mpc_t @var{op1}, mpz_t @var{op2}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_pow_fr (mpc_t @var{rop}, mpc_t @var{op1}, mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_pow (mpc_t @var{rop}, const mpc_t @var{op1}, const mpc_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_pow_d (mpc_t @var{rop}, const mpc_t @var{op1}, double @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_pow_ld (mpc_t @var{rop}, const mpc_t @var{op1}, long double @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_pow_si (mpc_t @var{rop}, const mpc_t @var{op1}, long @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_pow_ui (mpc_t @var{rop}, const mpc_t @var{op1}, unsigned long @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_pow_z (mpc_t @var{rop}, const mpc_t @var{op1}, const mpz_t @var{op2}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_pow_fr (mpc_t @var{rop}, const mpc_t @var{op1}, const mpfr_t @var{op2}, mpc_rnd_t @var{rnd}) Set @var{rop} to @var{op1} raised to the power @var{op2}, rounded according to @var{rnd}. For @code{mpc_pow_d}, @code{mpc_pow_ld}, @code{mpc_pow_si}, @code{mpc_pow_ui}, @@ -991,13 +991,13 @@ and imaginary part 0, with sign being the opposite of that of @var{op2}. @end deftypefun -@deftypefun int mpc_exp (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_exp (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Set @var{rop} to the exponential of @var{op}, rounded according to @var{rnd} with the precision of @var{rop}. @end deftypefun -@deftypefun int mpc_log (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_log10 (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_log (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_log10 (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Set @var{rop} to the natural and base-10 logarithm of @var{op} respectively, rounded according to @var{rnd} with the precision of @var{rop}. The principal branch is chosen, with the branch cut on the negative real axis, @@ -1029,57 +1029,41 @@ @section Trigonometric Functions @cindex Trigonometric functions -@deftypefun int mpc_sin (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -Set @var{rop} to the sine of @var{op}, +@deftypefun int mpc_sin (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_cos (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_tan (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +Set @var{rop} to the sine, cosine, tangent of @var{op}, rounded according to @var{rnd} with the precision of @var{rop}. @end deftypefun -@deftypefun int mpc_cos (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -Set @var{rop} to the cosine of @var{op}, -rounded according to @var{rnd} with the precision of @var{rop}. -@end deftypefun - -@deftypefun int mpc_sin_cos (mpc_t @var{rop_sin}, mpc_t @var{rop_cos}, mpc_t @var{op}, mpc_rnd_t @var{rnd_sin}, mpc_rnd_t @var{rnd_cos}) +@deftypefun int mpc_sin_cos (mpc_t @var{rop_sin}, mpc_t @var{rop_cos}, const mpc_t @var{op}, mpc_rnd_t @var{rnd_sin}, mpc_rnd_t @var{rnd_cos}) Set @var{rop_sin} to the sine of @var{op}, rounded according to @var{rnd_sin} with the precision of @var{rop_sin}, and @var{rop_cos} to the cosine of @var{op}, rounded according to @var{rnd_cos} with the precision of @var{rop_cos}. @end deftypefun -@deftypefun int mpc_tan (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -Set @var{rop} to the tangent of @var{op}, -rounded according to @var{rnd} with the precision of @var{rop}. -@end deftypefun - -@deftypefun int mpc_sinh (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -Set @var{rop} to the hyperbolic sine of @var{op}, -rounded according to @var{rnd} with the precision of @var{rop}. -@end deftypefun - -@deftypefun int mpc_cosh (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -Set @var{rop} to the hyperbolic cosine of @var{op}, -rounded according to @var{rnd} with the precision of @var{rop}. -@end deftypefun - -@deftypefun int mpc_tanh (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -Set @var{rop} to the hyperbolic tangent of @var{op}, +@deftypefun int mpc_sinh (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_cosh (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_tanh (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +Set @var{rop} to the hyperbolic sine, hyperbolic cosine, hyperbolic tangent of @var{op}, rounded according to @var{rnd} with the precision of @var{rop}. @end deftypefun -@deftypefun int mpc_asin (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_acos (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_atan (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_asin (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_acos (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_atan (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Set @var{rop} to the inverse sine, inverse cosine, inverse tangent of @var{op}, rounded according to @var{rnd} with the precision of @var{rop}. @end deftypefun -@deftypefun int mpc_asinh (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_acosh (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) -@deftypefunx int mpc_atanh (mpc_t @var{rop}, mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefun int mpc_asinh (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_acosh (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) +@deftypefunx int mpc_atanh (mpc_t @var{rop}, const mpc_t @var{op}, mpc_rnd_t @var{rnd}) Set @var{rop} to the inverse hyperbolic sine, inverse hyperbolic cosine, inverse hyperbolic tangent of @var{op}, rounded according to @var{rnd} with the precision of @var{rop}. -The branch cut of @var{mpc_acosh} is +The branch cut of @code{mpc_acosh} is @iftex @math{(-\infty, 1)}. @end iftex @@ -1157,7 +1141,7 @@ For instance, you can define mpc_set_ui_fr as follows: @example -int mpc_set_ui_fr (mpc_t rop, long int re, double im, mpc_rnd_t rnd) +int mpc_set_ui_fr (mpc_t rop, unsigned long int re, mpfr_t im, mpc_rnd_t rnd) MPC_SET_X_Y (ui, fr, rop, re, im, rnd); @end example @end defmac @@ -1183,19 +1167,18 @@ @item Torbj@"orn Granlund et al. -@code{gmp} -- GNU multiprecision library. -Version 4.2.4, @url{http://gmplib.org/}. +@code{GMP} -- GNU multiprecision library. +Version 6.2.0, @url{http://gmplib.org}. @item Guillaume Hanrot, Vincent Lef@`evre, Patrick P@'elissier, Paul Zimmermann et al. -@code{mpfr} -- A library for multiple-precision floating-point computations with exact rounding. -Version 2.4.1, @url{http://www.mpfr.org}. +@code{MPFR} -- A library for multiple-precision floating-point computations with exact rounding. +Version 4.1.0, @url{http://www.mpfr.org}. @item -IEEE standard for binary floating-point arithmetic, Technical Report -ANSI-IEEE Standard 754-1985, New York, 1985. -Approved March 21, 1985: IEEE Standards Board; approved July 26, - 1985: American National Standards Institute, 18 pages. +IEEE Standard for Floating-Point Arithmetic, +IEEE Computer Society, +IEEE Std 754-2019, Approved 13 June 2019, 84 pages. @item Donald E. Knuth, "The Art of Computer Programming", vol 2, diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/doc/stamp-vti new/mpc-1.2.1/doc/stamp-vti --- old/mpc-1.2.0/doc/stamp-vti 2020-08-17 17:00:20.000000000 +0200 +++ new/mpc-1.2.1/doc/stamp-vti 2020-10-20 18:28:00.000000000 +0200 @@ -1,4 +1,4 @@ -@set UPDATED 17 August 2020 -@set UPDATED-MONTH August 2020 -@set EDITION 1.2.0 -@set VERSION 1.2.0 +@set UPDATED 20 October 2020 +@set UPDATED-MONTH October 2020 +@set EDITION 1.2.1 +@set VERSION 1.2.1 diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/doc/version.texi new/mpc-1.2.1/doc/version.texi --- old/mpc-1.2.0/doc/version.texi 2020-08-17 17:00:20.000000000 +0200 +++ new/mpc-1.2.1/doc/version.texi 2020-10-20 18:26:01.000000000 +0200 @@ -1,4 +1,4 @@ -@set UPDATED 17 August 2020 -@set UPDATED-MONTH August 2020 -@set EDITION 1.2.0 -@set VERSION 1.2.0 +@set UPDATED 20 October 2020 +@set UPDATED-MONTH October 2020 +@set EDITION 1.2.1 +@set VERSION 1.2.1 diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/src/Makefile.am new/mpc-1.2.1/src/Makefile.am --- old/mpc-1.2.0/src/Makefile.am 2020-07-23 14:44:44.000000000 +0200 +++ new/mpc-1.2.1/src/Makefile.am 2020-10-20 18:26:20.000000000 +0200 @@ -18,7 +18,7 @@ ## along with this program. If not, see http://www.gnu.org/licenses/ . lib_LTLIBRARIES = libmpc.la -libmpc_la_LDFLAGS = $(MPC_LDFLAGS) -version-info 5:0:2 +libmpc_la_LDFLAGS = $(MPC_LDFLAGS) -version-info 5:1:2 libmpc_la_SOURCES = mpc-impl.h abs.c acos.c acosh.c add.c add_fr.c \ add_si.c add_ui.c arg.c asin.c asinh.c atan.c atanh.c clear.c \ cmp.c cmp_abs.c cmp_si_si.c conj.c cos.c cosh.c \ diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/src/asin.c new/mpc-1.2.1/src/asin.c --- old/mpc-1.2.0/src/asin.c 2020-07-27 11:34:32.000000000 +0200 +++ new/mpc-1.2.1/src/asin.c 2020-09-30 11:20:38.000000000 +0200 @@ -19,6 +19,7 @@ */ #include <stdio.h> +#include <limits.h> /* for ULONG_MAX */ #include "mpc-impl.h" /* Special case op = 1 + i*y for tiny y (see algorithms.tex). @@ -151,20 +152,22 @@ relative error */ ex = mpfr_get_exp (mpc_realref (s)); /* ulp(Re(s)) = 2^(ex+1-p) */ + err = 0; + /* invariant: the error will be kx*2^err */ if (ex+1 > e) /* divide kx by 2^(ex+1-e) */ while (ex+1 > e) { kx = (kx + 1) / 2; ex --; } - else /* multiply kx by 2^(e-(ex+1)) */ - kx <<= e - (ex+1); - /* now the rounding error is bounded by kx*ulp(Re(s)), add the + else /* multiply the error by 2^(e-(ex+1)), thus add e-(ex+1) to err */ + err += e - (ex+1); + /* now the rounding error is bounded by kx*2^err*ulp(Re(s)), add the mathematical error which is bounded by ulp(Re(s)): the first neglected term is less than 1/2*ulp(Re(s)), and each term decreases by at least a factor 2, since |z^2| <= 1/2. */ kx ++; - for (err = 0; kx > 2; err ++, kx = (kx + 1) / 2); + for (; kx > 2; err ++, kx = (kx + 1) / 2); /* can we round Re(s) with error less than 2^(EXP(Re(s))-err) ? */ if (!mpfr_can_round (mpc_realref (s), p - err, MPFR_RNDN, MPFR_RNDZ, mpfr_get_prec (mpc_realref (rop)) + diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/src/atan.c new/mpc-1.2.1/src/atan.c --- old/mpc-1.2.0/src/atan.c 2020-07-23 12:02:47.000000000 +0200 +++ new/mpc-1.2.1/src/atan.c 2020-10-12 18:07:15.000000000 +0200 @@ -143,7 +143,7 @@ mpfr_rnd_t rnd_im, rnd_away; mpfr_t y, z; mpfr_prec_t p, p_im; - int ok; + int ok = 0; rnd_im = MPC_RND_IM (rnd); mpfr_init (y); diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/src/get_version.c new/mpc-1.2.1/src/get_version.c --- old/mpc-1.2.0/src/get_version.c 2020-08-17 16:54:39.000000000 +0200 +++ new/mpc-1.2.1/src/get_version.c 2020-10-20 18:26:01.000000000 +0200 @@ -23,5 +23,5 @@ const char * mpc_get_version (void) { - return "1.2.0"; + return "1.2.1"; } diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/src/mpc.h new/mpc-1.2.1/src/mpc.h --- old/mpc-1.2.0/src/mpc.h 2020-08-17 16:54:50.000000000 +0200 +++ new/mpc-1.2.1/src/mpc.h 2020-10-20 18:26:01.000000000 +0200 @@ -27,8 +27,8 @@ /* Define MPC version number */ #define MPC_VERSION_MAJOR 1 #define MPC_VERSION_MINOR 2 -#define MPC_VERSION_PATCHLEVEL 0 -#define MPC_VERSION_STRING "1.2.0" +#define MPC_VERSION_PATCHLEVEL 1 +#define MPC_VERSION_STRING "1.2.1" /* Macros dealing with MPC VERSION */ #define MPC_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c)) diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/src/mul.c new/mpc-1.2.1/src/mul.c --- old/mpc-1.2.0/src/mul.c 2018-11-22 14:57:30.000000000 +0100 +++ new/mpc-1.2.1/src/mul.c 2020-08-25 15:24:16.000000000 +0200 @@ -1,6 +1,6 @@ /* mpc_mul -- Multiply two complex numbers -Copyright (C) 2002, 2004, 2005, 2008, 2009, 2010, 2011, 2012, 2016 INRIA +Copyright (C) 2002, 2004, 2005, 2008, 2009, 2010, 2011, 2012, 2016, 2020 INRIA This file is part of GNU MPC. @@ -170,196 +170,6 @@ return MPC_INEX (inex_re, inex_im); } -#define MPFR_MANT(x) ((x)->_mpfr_d) -#define MPFR_PREC(x) ((x)->_mpfr_prec) -#define MPFR_EXP(x) ((x)->_mpfr_exp) -#define MPFR_LIMB_SIZE(x) ((MPFR_PREC (x) - 1) / GMP_NUMB_BITS + 1) - -#if HAVE_MPFR_FMMA == 0 -static int -mpc_fmma (mpfr_ptr z, mpfr_srcptr a, mpfr_srcptr b, mpfr_srcptr c, - mpfr_srcptr d, int sign, mpfr_rnd_t rnd) -{ - /* Computes z = ab+cd if sign >= 0, or z = ab-cd if sign < 0. - Assumes that a, b, c, d are finite and non-zero; so any multiplication - of two of them yielding an infinity is an overflow, and a - multiplication yielding 0 is an underflow. - Assumes further that z is distinct from a, b, c, d. */ - - int inex; - mpfr_t u, v; - mp_size_t an, bn, cn, dn; - - /* u=a*b, v=sign*c*d exactly */ - an = MPFR_LIMB_SIZE(a); - bn = MPFR_LIMB_SIZE(b); - cn = MPFR_LIMB_SIZE(c); - dn = MPFR_LIMB_SIZE(d); - MPFR_MANT(u) = malloc ((an + bn) * sizeof (mp_limb_t)); - MPFR_MANT(v) = malloc ((cn + dn) * sizeof (mp_limb_t)); - if (an >= bn) - mpn_mul (MPFR_MANT(u), MPFR_MANT(a), an, MPFR_MANT(b), bn); - else - mpn_mul (MPFR_MANT(u), MPFR_MANT(b), bn, MPFR_MANT(a), an); - if ((MPFR_MANT(u)[an + bn - 1] >> (GMP_NUMB_BITS - 1)) == 0) - { - mpn_lshift (MPFR_MANT(u), MPFR_MANT(u), an + bn, 1); - MPFR_EXP(u) = MPFR_EXP(a) + MPFR_EXP(b) - 1; - } - else - MPFR_EXP(u) = MPFR_EXP(a) + MPFR_EXP(b); - if (cn >= dn) - mpn_mul (MPFR_MANT(v), MPFR_MANT(c), cn, MPFR_MANT(d), dn); - else - mpn_mul (MPFR_MANT(v), MPFR_MANT(d), dn, MPFR_MANT(c), cn); - if ((MPFR_MANT(v)[cn + dn - 1] >> (GMP_NUMB_BITS - 1)) == 0) - { - mpn_lshift (MPFR_MANT(v), MPFR_MANT(v), cn + dn, 1); - MPFR_EXP(v) = MPFR_EXP(c) + MPFR_EXP(d) - 1; - } - else - MPFR_EXP(v) = MPFR_EXP(c) + MPFR_EXP(d); - MPFR_PREC(u) = (an + bn) * GMP_NUMB_BITS; - MPFR_PREC(v) = (cn + dn) * GMP_NUMB_BITS; - MPFR_SIGN(u) = MPFR_SIGN(a) * MPFR_SIGN(b); - if (sign > 0) - MPFR_SIGN(v) = MPFR_SIGN(c) * MPFR_SIGN(d); - else - MPFR_SIGN(v) = -MPFR_SIGN(c) * MPFR_SIGN(d); - - mpfr_check_range (u, 0, MPFR_RNDN); - mpfr_check_range (v, 0, MPFR_RNDN); - - /* tentatively compute z as u+v; here we need z to be distinct - from a, b, c, d to not lose the latter */ - inex = mpfr_add (z, u, v, rnd); - - if (!mpfr_regular_p(z) || !mpfr_regular_p(u) || !mpfr_regular_p(v)) - { - if (mpfr_inf_p (z)) { - /* replace by "correctly rounded overflow" */ - mpfr_set_si (z, (mpfr_signbit (z) ? -1 : 1), MPFR_RNDN); - inex = mpfr_mul_2ui (z, z, mpfr_get_emax (), rnd); - } - else if (mpfr_zero_p (u) && !mpfr_zero_p (v)) { - /* exactly u underflowed, determine inexact flag */ - inex = (mpfr_signbit (u) ? 1 : -1); - } - else if (mpfr_zero_p (v) && !mpfr_zero_p (u)) { - /* exactly v underflowed, determine inexact flag */ - inex = (mpfr_signbit (v) ? 1 : -1); - } - else if (mpfr_nan_p (z) || (mpfr_zero_p (u) && mpfr_zero_p (v))) { - /* In the first case, u and v are infinities with opposite signs. - In the second case, u and v are zeroes; their sum may be 0 or the - least representable number, with a sign to be determined. - Redo the computations with mpz_t exponents */ - mpfr_exp_t ea, eb, ec, ed; - mpz_t eu, ev; - /* cheat to work around the const qualifiers */ - - /* Normalise the input by shifting and keep track of the shifts in - the exponents of u and v */ - ea = mpfr_get_exp (a); - eb = mpfr_get_exp (b); - ec = mpfr_get_exp (c); - ed = mpfr_get_exp (d); - - mpfr_set_exp ((mpfr_ptr) a, (mpfr_prec_t) 0); - mpfr_set_exp ((mpfr_ptr) b, (mpfr_prec_t) 0); - mpfr_set_exp ((mpfr_ptr) c, (mpfr_prec_t) 0); - mpfr_set_exp ((mpfr_ptr) d, (mpfr_prec_t) 0); - - mpz_init (eu); - mpz_init (ev); - mpz_set_si (eu, (long int) ea); - mpz_add_si (eu, eu, (long int) eb); - mpz_set_si (ev, (long int) ec); - mpz_add_si (ev, ev, (long int) ed); - - /* recompute u and v and move exponents to eu and ev */ - mpfr_mul (u, a, b, MPFR_RNDN); - /* exponent of u is non-positive */ - mpz_sub_ui (eu, eu, (unsigned long int) (-mpfr_get_exp (u))); - mpfr_set_exp (u, (mpfr_prec_t) 0); - mpfr_mul (v, c, d, MPFR_RNDN); - if (sign < 0) - mpfr_neg (v, v, MPFR_RNDN); - mpz_sub_ui (ev, ev, (unsigned long int) (-mpfr_get_exp (v))); - mpfr_set_exp (v, (mpfr_prec_t) 0); - - if (mpfr_nan_p (z)) { - mpfr_exp_t emax = mpfr_get_emax (); - int overflow; - /* We have a = ma * 2^ea with 1/2 <= |ma| < 1 and ea <= emax, and - analogously for b. So eu <= 2*emax, and eu > emax since we have - an overflow. The same holds for ev. Shift u and v by as much as - possible so that one of them has exponent emax and the - remaining exponents in eu and ev are the same. Then carry out - the addition. Shifting u and v prevents an underflow. */ - if (mpz_cmp (eu, ev) >= 0) { - mpfr_set_exp (u, emax); - mpz_sub_ui (eu, eu, (long int) emax); - mpz_sub (ev, ev, eu); - mpfr_set_exp (v, (mpfr_exp_t) mpz_get_ui (ev)); - /* remaining common exponent is now in eu */ - } - else { - mpfr_set_exp (v, emax); - mpz_sub_ui (ev, ev, (long int) emax); - mpz_sub (eu, eu, ev); - mpfr_set_exp (u, (mpfr_exp_t) mpz_get_ui (eu)); - mpz_set (eu, ev); - /* remaining common exponent is now also in eu */ - } - inex = mpfr_add (z, u, v, rnd); - /* Result is finite since u and v have different signs. */ - overflow = mpfr_mul_2ui (z, z, mpz_get_ui (eu), rnd); - if (overflow) - inex = overflow; - } - else { - int underflow; - /* Addition of two zeroes with same sign. We have a = ma * 2^ea - with 1/2 <= |ma| < 1 and ea >= emin and similarly for b. - So 2*emin < 2*emin+1 <= eu < emin < 0, and analogously for v. */ - mpfr_exp_t emin = mpfr_get_emin (); - if (mpz_cmp (eu, ev) <= 0) { - mpfr_set_exp (u, emin); - mpz_add_ui (eu, eu, (unsigned long int) (-emin)); - mpz_sub (ev, ev, eu); - mpfr_set_exp (v, (mpfr_exp_t) mpz_get_si (ev)); - } - else { - mpfr_set_exp (v, emin); - mpz_add_ui (ev, ev, (unsigned long int) (-emin)); - mpz_sub (eu, eu, ev); - mpfr_set_exp (u, (mpfr_exp_t) mpz_get_si (eu)); - mpz_set (eu, ev); - } - inex = mpfr_add (z, u, v, rnd); - mpz_neg (eu, eu); - underflow = mpfr_div_2ui (z, z, mpz_get_ui (eu), rnd); - if (underflow) - inex = underflow; - } - - mpz_clear (eu); - mpz_clear (ev); - - mpfr_set_exp ((mpfr_ptr) a, ea); - mpfr_set_exp ((mpfr_ptr) b, eb); - mpfr_set_exp ((mpfr_ptr) c, ec); - mpfr_set_exp ((mpfr_ptr) d, ed); - /* works also when some of a, b, c, d are not all distinct */ - } - } - - free (MPFR_MANT(u)); - free (MPFR_MANT(v)); - return inex; -} -#endif int mpc_mul_naive (mpc_ptr z, mpc_srcptr x, mpc_srcptr y, mpc_rnd_t rnd) @@ -377,17 +187,10 @@ else rop [0] = z [0]; -#if HAVE_MPFR_FMMA inex_re = mpfr_fmms (mpc_realref (rop), mpc_realref (x), mpc_realref (y), mpc_imagref (x), mpc_imagref (y), MPC_RND_RE (rnd)); inex_im = mpfr_fmma (mpc_imagref (rop), mpc_realref (x), mpc_imagref (y), mpc_imagref (x), mpc_realref (y), MPC_RND_IM (rnd)); -#else - inex_re = mpc_fmma (mpc_realref (rop), mpc_realref (x), mpc_realref (y), - mpc_imagref (x), mpc_imagref (y), -1, MPC_RND_RE (rnd)); - inex_im = mpc_fmma (mpc_imagref (rop), mpc_realref (x), mpc_imagref (y), - mpc_imagref (x), mpc_realref (y), +1, MPC_RND_IM (rnd)); -#endif mpc_set (z, rop, MPC_RNDNN); if (overlap) diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/src/pow.c new/mpc-1.2.1/src/pow.c --- old/mpc-1.2.0/src/pow.c 2020-07-23 11:41:12.000000000 +0200 +++ new/mpc-1.2.1/src/pow.c 2020-10-12 18:07:15.000000000 +0200 @@ -696,7 +696,6 @@ if (mpfr_underflow_p () || mpfr_overflow_p ()) { /* under- and overflow flags are set by mpc_exp */ mpc_set (z, u, MPC_RNDNN); - ret = ret_exp; inex_re = MPC_INEX_RE(ret_exp); inex_im = MPC_INEX_IM(ret_exp); if (mpfr_inf_p (mpc_realref (z))) diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/src/sqrt.c new/mpc-1.2.1/src/sqrt.c --- old/mpc-1.2.0/src/sqrt.c 2020-07-23 12:01:49.000000000 +0200 +++ new/mpc-1.2.1/src/sqrt.c 2020-08-25 15:30:38.000000000 +0200 @@ -20,13 +20,6 @@ #include "mpc-impl.h" -#if MPFR_VERSION_MAJOR < 3 -#define mpfr_min_prec(x) \ - ( ((prec + BITS_PER_MP_LIMB - 1) / BITS_PER_MP_LIMB) * BITS_PER_MP_LIMB \ - - mpn_scan1 (x->_mpfr_d, 0)) -#endif - - int mpc_sqrt (mpc_ptr a, mpc_srcptr b, mpc_rnd_t rnd) { diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' --exclude Makefile.in --exclude configure --exclude config.guess --exclude '*.pot' --exclude mkinstalldirs --exclude aclocal.m4 --exclude config.sub --exclude depcomp --exclude install-sh --exclude ltmain.sh old/mpc-1.2.0/tests/asin.dat new/mpc-1.2.1/tests/asin.dat --- old/mpc-1.2.0/tests/asin.dat 2018-01-16 14:33:09.000000000 +0100 +++ new/mpc-1.2.1/tests/asin.dat 2020-09-29 10:39:01.000000000 +0200 @@ -131,3 +131,4 @@ - - 11 0xc9p-7 11 0xb5p-28 11 1 11 0x1p-41 N N - + 53 0x3243f6a8885a3p-49 53 0x16a09e667f3bcdp-552 53 1 53 0x1p-999 N N - + 2 1.5 2 0x1p-40 2 1 20 0xff802p-100 N N +- - 24 -0x1p-148 24 -0xc.75cp-20 24 -0x1p-148 24 -0xc.75cp-20 N N
participants (1)
-
root