321 lines
12 KiB

diff -r -c3 LiDIA-1.3.orig/Readme LiDIA-1.3/Readme
*** LiDIA-1.3.orig/Readme Wed Feb 5 21:51:10 1997
--- LiDIA-1.3/Readme Sun Jan 25 00:44:29 1998
***************
*** 157,164 ****
o mpqs: large prime variant for quadratic sieve in the class
rational_factorization.
! o You can now choose gmp as the integer arithmetic of the kernel.
! This LiDIA - release contains gmp version 2.0.2.
--- 157,164 ----
o mpqs: large prime variant for quadratic sieve in the class
rational_factorization.
! o You can now choose gmp or cln as the integer arithmetic of the kernel.
! This LiDIA release contains gmp version 2.0.2 and cln version 1997-09-06.
diff -r -c3 LiDIA-1.3.orig/config/CONFIG.in LiDIA-1.3/config/CONFIG.in
*** LiDIA-1.3.orig/config/CONFIG.in Wed Feb 5 12:02:16 1997
--- LiDIA-1.3/config/CONFIG.in Sat Jan 24 18:42:57 1998
***************
*** 42,48 ****
#
# The Kernel And The Interface To Be compiled
#
! # Possible Integer Interfaces Are: libI, lip, gmp
#
# Possible Memory Managers Are: malloc, dentzer, boehm,
# default (no manager)
--- 42,48 ----
#
# The Kernel And The Interface To Be compiled
#
! # Possible Integer Interfaces Are: libI, lip, gmp, cln
#
# Possible Memory Managers Are: malloc, dentzer, boehm,
# default (no manager)
***************
*** 149,155 ****
LIDIA_INSTALL_DAT = ${LIDIA_INSTALL_DIR}/lib
#
! # OS/2 Compatability Section
#
CXX-off =
--- 149,155 ----
LIDIA_INSTALL_DAT = ${LIDIA_INSTALL_DIR}/lib
#
! # OS/2 Compatibility Section
#
CXX-off =
***************
*** 166,171 ****
--- 166,172 ----
# Make Command Macros
#
# AR -- the archiver command
+ # ARX -- the archiver extract command
# RM -- command used to remove files
# RMR -- command used to remove directories
# CP -- command used to copy files
***************
*** 178,183 ****
--- 179,185 ----
#
AR = @AR@
+ ARX = ar x
RM = @RM@
RMR = @RMR@
CP = @CP@
diff -r -c3 LiDIA-1.3.orig/config/CONFIG.os2 LiDIA-1.3/config/CONFIG.os2
*** LiDIA-1.3.orig/config/CONFIG.os2 Tue Jan 21 14:55:44 1997
--- LiDIA-1.3/config/CONFIG.os2 Sat Jan 24 18:43:28 1998
***************
*** 137,142 ****
--- 137,143 ----
# Make Command Macros
#
# AR -- the archiver command
+ # ARX -- the archiver extract command
# RM -- command used to remove files
# RMR -- command used to remove directories
# CP -- command used to copy files
***************
*** 147,152 ****
--- 148,154 ----
# TOUCH -- command used to create an empry file
#
AR = ar ru
+ ARX = ar x
RM = del /N
RMR = del /N
CP = xcopy
diff -r -c3 LiDIA-1.3.orig/config/bin/integer-sh LiDIA-1.3/config/bin/integer-sh
*** LiDIA-1.3.orig/config/bin/integer-sh Tue Oct 22 22:25:57 1996
--- LiDIA-1.3/config/bin/integer-sh Sun Jan 25 00:47:13 1998
***************
*** 7,15 ****
echo " "
echo "You will now be asked for the integer arithmetic that "
! echo "will be used in the kernel of LiDIA (gmp, libI, lip)."
echo " "
echo "gmp - written by Torbjorn Granlund"
echo "libI - written by Ralf Dentzer"
echo "lip - written by Arjen Lenstra"
echo " "
--- 7,16 ----
echo " "
echo "You will now be asked for the integer arithmetic that "
! echo "will be used in the kernel of LiDIA (gmp, cln, libI, lip)."
echo " "
echo "gmp - written by Torbjorn Granlund"
+ echo "cln - written by Bruno Haible (based on gmp)"
echo "libI - written by Ralf Dentzer"
echo "lip - written by Arjen Lenstra"
echo " "
***************
*** 23,35 ****
do
echo -n "integer arithmetic ? [$INTEGERS] : "
read ANSWER
! if test "$ANSWER" = "gmp" -o "$ANSWER" = "lip" -o "$ANSWER" = "libI" ; then
INTEGERS=$ANSWER
SUCCESS=y
elif test "$ANSWER" = "" ; then
SUCCESS=y
else
! echo "Please choose gmp, libI, or lip."
INTEGERS="libI"
fi
done
--- 24,36 ----
do
echo -n "integer arithmetic ? [$INTEGERS] : "
read ANSWER
! if test "$ANSWER" = "gmp" -o "$ANSWER" = "cln" -o "$ANSWER" = "lip" -o "$ANSWER" = "libI" ; then
INTEGERS=$ANSWER
SUCCESS=y
elif test "$ANSWER" = "" ; then
SUCCESS=y
else
! echo "Please choose gmp, cln, libI, or lip."
INTEGERS="libI"
fi
done
diff -r -c3 LiDIA-1.3.orig/doc/manual/FIG/lidia_model.fig LiDIA-1.3/doc/manual/FIG/lidia_model.fig
*** LiDIA-1.3.orig/doc/manual/FIG/lidia_model.fig Tue Feb 27 11:57:01 1996
--- LiDIA-1.3/doc/manual/FIG/lidia_model.fig Sun Jan 25 00:48:58 1998
***************
*** 55,61 ****
4 0 -1 0 0 2 16 0.0000000 4 225 2085 1200 2850 parameterized classes\001
4 0 -1 0 0 2 16 0.0000000 4 225 1365 1200 4035 simple classes\001
4 0 -1 0 0 2 16 0.0000000 4 165 930 1200 5220 interfaces\001
! 4 2 -1 0 0 12 12 0.0000000 4 180 2100 9000 6375 (libI, lip, gmp, mm)\001
4 2 -1 0 0 12 12 0.0000000 4 180 1365 9000 5175 (bigint, gmm)\001
4 2 -1 0 0 12 12 0.0000000 4 180 2940 9000 3975 (bigrational, bigfloat, ...)\001
4 2 -1 0 0 12 12 0.0000000 4 180 3675 9000 2775 (vector, matrix, power series, ...)\001
--- 55,61 ----
4 0 -1 0 0 2 16 0.0000000 4 225 2085 1200 2850 parameterized classes\001
4 0 -1 0 0 2 16 0.0000000 4 225 1365 1200 4035 simple classes\001
4 0 -1 0 0 2 16 0.0000000 4 165 930 1200 5220 interfaces\001
! 4 2 -1 0 0 12 12 0.0000000 4 180 2100 9000 6375 (libI, lip, gmp, cln, mm)\001
4 2 -1 0 0 12 12 0.0000000 4 180 1365 9000 5175 (bigint, gmm)\001
4 2 -1 0 0 12 12 0.0000000 4 180 2940 9000 3975 (bigrational, bigfloat, ...)\001
4 2 -1 0 0 12 12 0.0000000 4 180 3675 9000 2775 (vector, matrix, power series, ...)\001
diff -r -c3 LiDIA-1.3.orig/doc/manual/bibliography.tex LiDIA-1.3/doc/manual/bibliography.tex
*** LiDIA-1.3.orig/doc/manual/bibliography.tex Fri Jan 24 13:22:31 1997
--- LiDIA-1.3/doc/manual/bibliography.tex Sun Jan 25 00:55:48 1998
***************
*** 151,156 ****
--- 151,159 ----
\IT{A rigorous subexponential algorithm for computation of class groups},
Tech. report, IBM Research Report, San Jose, CA, 1989.
+ \bibitem{haible} B. Haible:
+ \IT{CLN, a Class Library for Numbers}, 1997.
+
\bibitem{HLConF} G.H. Hardy and J.E. Littlewood:
\IT{\em Partitio numerorum {III}: On the expression of a number as a sum of
primes}, Acta Math. {\bf 44} (1923), 1--70.
diff -r -c3 LiDIA-1.3.orig/doc/manual/installing.tex LiDIA-1.3/doc/manual/installing.tex
*** LiDIA-1.3.orig/doc/manual/installing.tex Wed Feb 5 17:33:40 1997
--- LiDIA-1.3/doc/manual/installing.tex Sun Jan 25 00:58:30 1998
***************
*** 309,316 ****
of the kernel.
\item BIGINT\\
This is used to decide which integer arithmetic is to be compiled with
! {\LiDIA}. At the moment we support three possibilities: \TT{gmp}, \TT{libI},
! and \TT{lip}. We suggest that you use the \TT{gmp} with the GNU g++
compiler and \TT{libI} otherwise. Use \TT{lip}, if you have chosen
\TT{libI} during the configuration process and TARGET has been set
to c by configure. In this case, no \TT{libI} assembler code is
--- 309,316 ----
of the kernel.
\item BIGINT\\
This is used to decide which integer arithmetic is to be compiled with
! {\LiDIA}. At the moment we support four possibilities: \TT{gmp}, \TT{cln},
! TT{libI}, and \TT{lip}. We suggest that you use the \TT{gmp} with the GNU g++
compiler and \TT{libI} otherwise. Use \TT{lip}, if you have chosen
\TT{libI} during the configuration process and TARGET has been set
to c by configure. In this case, no \TT{libI} assembler code is
diff -r -c3 LiDIA-1.3.orig/doc/manual/overview.tex LiDIA-1.3/doc/manual/overview.tex
*** LiDIA-1.3.orig/doc/manual/overview.tex Wed Jan 29 19:32:32 1997
--- LiDIA-1.3/doc/manual/overview.tex Sun Jan 25 00:57:36 1998
***************
*** 19,24 ****
--- 19,25 ----
\newcommand{\libi}{{\bf libI}}
\newcommand{\gmp}{{\bf GNU gmp}}
\newcommand{\lip}{{\bf lip}}
+ \newcommand{\cln}{{\bf cln}}
\newcommand{\bigint}{{\bf bigint}}
***************
*** 70,76 ****
It is a serious problem to decide which multiprecision integer package
and which memory manager should be used in \LiDIA. There are
competing multiprecision integer packages, for example the
! \gmp\ package \cite{gnump}, the \libi\ package \cite{dentzer} and
the \lip\ package \cite{lenstra}. Some of those packages are more
efficient on one architecture and some on others. Also, new
architectures lead very fast to new multiprecision packages. We decided
--- 71,78 ----
It is a serious problem to decide which multiprecision integer package
and which memory manager should be used in \LiDIA. There are
competing multiprecision integer packages, for example the
! \gmp\ package \cite{gnump}, the \cln\ package \cite{haible},
! the \libi\ package \cite{dentzer} and
the \lip\ package \cite{lenstra}. Some of those packages are more
efficient on one architecture and some on others. Also, new
architectures lead very fast to new multiprecision packages. We decided
***************
*** 112,120 ****
whole functionality of the interface can be used in the kernel.
Currently, we support the multiprecision integer packages
\libi\ \cite{dentzer}, Arjen Lenstra's \Index{lip} package \cite{lenstra}
! (available by anonymous ftp via \TT{flash.bellcore.com:/pub/lenstra}) and GNU's
\IndexSUBTT{GNU}{gmp} arithmetic \cite{gnump} (available by anonymous
! ftp via \TT{prep.ai.mit.edu}).
The second \LiDIA\ level is the \BF{interface} through which {\CPP}
applications on higher levels have access to the kernel. By that
--- 114,123 ----
whole functionality of the interface can be used in the kernel.
Currently, we support the multiprecision integer packages
\libi\ \cite{dentzer}, Arjen Lenstra's \Index{lip} package \cite{lenstra}
! (available by anonymous ftp via \TT{flash.bellcore.com:/pub/lenstra}), GNU's
\IndexSUBTT{GNU}{gmp} arithmetic \cite{gnump} (available by anonymous
! ftp via \TT{prep.ai.mit.edu}), and CLN (available by anonymous ftp from
! \TT{ma2s2.mathematik.uni-karlsruhe.de:/pub/gnu}).
The second \LiDIA\ level is the \BF{interface} through which {\CPP}
applications on higher levels have access to the kernel. By that
diff -r -c3 LiDIA-1.3.orig/include/LiDIA/bigint.h LiDIA-1.3/include/LiDIA/bigint.h
*** LiDIA-1.3.orig/include/LiDIA/bigint.h Tue Oct 29 17:47:17 1996
--- LiDIA-1.3/include/LiDIA/bigint.h Sat Jan 24 20:29:16 1998
***************
*** 51,56 ****
--- 51,57 ----
bigint(long l);
bigint(unsigned long ul);
bigint(const bigint & a);
+ bigint(const integer_type_name & II) : I (II) {} // cln needs this
~bigint();
/**
Only in LiDIA-1.3/src/interfaces/integers: cln
diff -r -c3 LiDIA-1.3.orig/src/interfaces/integers/gmp/bigint.c LiDIA-1.3/src/interfaces/integers/gmp/bigint.c
*** LiDIA-1.3.orig/src/interfaces/integers/gmp/bigint.c Fri Jan 10 18:19:00 1997
--- LiDIA-1.3/src/interfaces/integers/gmp/bigint.c Sat Jan 24 17:41:29 1998
***************
*** 610,616 ****
void invert(bigint & a, const bigint & b)
{
! if ((a.I._mp_size == 1 || a.I._mp_size == -1) && a.I._mp_d[0] == 1)
mpz_set(&a.I, &b.I);
else
lidia_error_handler("bigint", "invert::inverting of a non-unit.");
--- 610,616 ----
void invert(bigint & a, const bigint & b)
{
! if ((b.I._mp_size == 1 || b.I._mp_size == -1) && b.I._mp_d[0] == 1)
mpz_set(&a.I, &b.I);
else
lidia_error_handler("bigint", "invert::inverting of a non-unit.");
Only in LiDIA-1.3/src/kernel/integers: cln
diff -r -c3 LiDIA-1.3.orig/src/simple_classes/factorization/mpqs.c LiDIA-1.3/src/simple_classes/factorization/mpqs.c
*** LiDIA-1.3.orig/src/simple_classes/factorization/mpqs.c Tue Jan 28 14:00:36 1997
--- LiDIA-1.3/src/simple_classes/factorization/mpqs.c Sat Jan 24 17:45:17 1998
***************
*** 17,23 ****
//extern "C" int system(char*);
#endif
! #if !defined(__GNUG__)
#include <signal.h>
#else
#define SIGHUP 1 /* hangup */
--- 17,23 ----
//extern "C" int system(char*);
#endif
! #if defined(__linux__) || !defined(__GNUG__)
#include <signal.h>
#else
#define SIGHUP 1 /* hangup */