Annotation of OpenXM_contrib/pari/CHANGES, Revision 1.1.1.1
1.1 maekawa 1: AW = Aleksander Wittlin
2: BA = Bill Allombert
3: BD = Bill Dally
4: BH = Bruno Haible
5: DB = Dominique Bernardi
6: DC = Dan Christensen
7: DE = Denis Excoffier
8: DF = David Ford
9: GH = Guillaume Hanrot
10: GN = Gerhard Niklasch
11: GT = Glenn Thobe
12: HC = Henri Cohen
13: IS = Igor Schein
14: IK = Iwao Kimura
15: IZ = Ilya Zakharevich
16: KO = Kiyoshi Ohgishi
17: LG = Louis Granboulan
18: MS = Michael Stoll
19: OR = Olivier Ramare
20: OV = Oliver Voigt
21: PM = Peter Montgomery
22: TP = Thomas Papanikolaou
23: XR = Xavier Roblot
24: YU = Yoshiaki Uchikawa
25:
26: ===========================================================================
27: Done for version 2.0.17.beta (released ??/??/99):
28: Fixed
29: XR 1- typo in zarchstar (result possibly incorrect when more than two places)
30: 2- check_unit not severe enough ([;] --> session could die !)
31: 3- wrong error message when using global var as argument to user function
32: 4- typo in boundfact(t_FRAC) --> SEGV
33: 5- buchall: don't compute xarch if not needed
34: 6- remove limit on string size + silent overflow, e.g Str(10^5000)
35: 7- "break status" not checked often enough: [break, 1] --> SEGV
36: 8- rewrote errcontext (use print_text to fit messages on terminal)
37: BD 9- added workarounds against some MSVC annoyances (Windows version)
38: IZ 10- typo in Gnuplot.h
39: 11- typo in Configure ("2>&1 >/dev/null" replaced by ">/dev/null 2>&1")
40: 12- simplified incgam[23] + typo (mulrr --> gmul)
41: IZ 13- typo in LD_LIBRARY_PATH setting (benches)
42: 14- inconsistency in gadd(0., FRAC) (should give 0. if FRAC small enough)
43: 15- libraries/headers ordering inconsistent in Configure (report: IZ and KO)
44: 16- typo in ff_poltype [symptom: (Mod(1, y^2 + 1)*x + 1)*x --> garbage]
45: 17- qfbprimeform(4, [2]) --> SEGV
46: 18- overflow in factorcantor(2*x^3+3*x^2+x, 2^31-1)
47: 19- memory corruption in apell1 + no garbage collection,
48: rewrote the function to parallel apell0, replaced hashing by sorting,
49: use Montgomery's trick, removed the p < 10^25 limit
50: IS 20- cc -64 warning in mp.c:vals()
51: 21- bad free in gp_expand_path
52: 22- extract([;], "..") --> SEGV
53: 23- not enough GC in hnfall
54: 24- recover gracefully when precision too low in lindep/algdep
55: IS 25- cleaned up unused variables, fixed some missing casts
56: 26- algdep(x) --> undefined behavior when x exact. Replace by decimal
57: approximation
58: IS 27- C++ keywords (new, class) occurred as variable names
59: 28- arguments of ideallistarch not checked
60: 29- Mod(t_FRAC or t_PADIC, t_INT) --> garbage
61: 30- gcmp1(t_REAL) always false: polylog(2, 1) --> error
62: 31- (spurious) compiler warnings about variables used before initialization
63: 32- memory (possibly) freed twice in buchall + unsafe allocation of matcopy
64: 33- online help for matsnf not updated
65: 34- rnfequation() didn't check its arguments correctly
66: 35- removed sprious special case in compute_class_number()
67: 36- typo in the compatibility macros mpabsz / mpnegz (missing ;)
68: 37- "lost pointers in gerepile" in bnfisprincipal(Q, ...)
69: 38- bnfisprincipal(..., Pol(0)) accepted
70: 39- [Configure] Makefile name didn't necessarily match object directory
71: 40- zetak(nfz, integer + 0.) --> stack corruption
72: 41- for(i=1, ..., zetak(nfz, any complex number)) went slower and slower
73: 42- poltchebi(.,y), pollegendre(.,y) didn't work
74: 43- confusing "array index out of allowed range" message (e.g [1-0])
75: IS 44- fixed obscure compiler optimization bugs in smithall() and eint1()
76: GN 45- weird results in ellisoncurve() due to misguided precision heuristics
77: 46- typo in forvec([],...): lisexpr() --> lisseq()
78: 47- check arguments in ploth()
79: XR 48- rare bug in bnrL1 (wrong value!)
80: 49- precision problems in polredabs
81: 50- division by 0 in rnfordmax [typo in mymod()]
82: 51- removed all dangerous occurences of constpi/consteuler (cf 41-)
83: 52- typo in det() [forgot to divide by a pivot]
84: 53- divide by 0 error in lllgramintern (precision problem)
85: 54- suminf(k=1,suminf(j=1,.067^(k+j)/k^4/(k+j))) ran forever
86: 55- factor(2*x + 2) --> [2*x + 2, 1] (instead of stripping the content)
87: 56- (ultra-rare) stack corruption in mpqs_solve_linear_system()
88: 57- rl_refresh_line() prototype changed across readline's versions
89: 58- incorrect handling of INTMODs modulo integers of different magnitude
90: XR 59- matsnf(3 x 3 matrix, 4) --> SEGV
91: 60- some pathological bnfinit() computations (strive to get maximal rank)
92: XR 61- precision problems in nfsqff() [increase precision for T2-norm bound]
93: 62- time wasted checking generators of the form [x,0,...,0] in polredabs
94: 63- variables deleted too late in freeall()
95:
96: Changed
97: XR 1- modulus choice in bnrstark
98: 2- make sure that addii(x,y) returns gzero, not icopy(gzero)
99: 3- cutoff in ellap to use Jacobi sums (457 --> 100)
100: 4- pariputsf("%Z",(long)g): removed the casts (not needed)
101: 5- cleaned up hnfspec
102: 6- look for at least MIN_EXTRA extra relations in buchall
103: 7- simplified calling interface to hnfspec/add
104: 8 Used hnfspec in bnfsunit, changed the way S-units are found
105: 9- output of bnfsunit modified (removed res[3], made res[2] suitable
106: for hnfadd)
107: 10- listput and listinsert now return the inserted element, not the list
108: 11- check_break_status rewritten: was very inefficient
109: 12- Used parser code DG whenever it was possible (moved reorder to init.c)
110: 13- faster isunit()
111: 14- added GC in expr()
112: 15- buchall(): increase subfactorbase without starting over
113: GN 16- minor tuning in pollardbrent() for huge integers (call ECM sooner)
114: 17- renamed directories dos -> Odos, o.xxx.xxx --> Oxxx.
115: Moved win32/* --> Odos
116: OR 18- new version of pari.el
117: XR 19- new modular round 4 implementation (nilord2)
118: BA 20- improved algorithms in galconj.c
119:
120: Added
121: 1- an optional argument to next()
122: 2- MANIFEST
123: YU 3- support for FreeBSD ELF binary format
124: 4- file CVS.DOC
125: 5- support for Windows CE (Nigel Smart + coworkers)
126: BA 6- functions related to Galois theory: galoisinit, galoisfixedfield, etc
127: 7- [library] trivial function realun()
128:
129: Removed
130: 1- #define HIGHBITM1 (useless)
131: 2- files config/tar_[include | exclude] (obsoleted by MANIFEST)
132:
133: ===========================================================================
134: Done for version 2.0.16.beta (released 29/06/99):
135:
136: Fixed
137: 1- paricfg.tex (needed to compile INSTALL.tex) missing if Configure is
138: not run. Added a test in parimacro.tex
139: 2- non-portable casts in galconj.c
140: 3- 64-bit graph benches (extra spaces)
141: IZ 4- typos in plotgnuplot.c
142: 5- unnecessary plothsizes in "graph" bench (fails if no X server)
143: 6- typo in ff_poltype
144: IZ 7- check rectwindow in rectcopy and rectclip
145: IZ 8- /opt/local/lib missing in Configure's library path
146: IZ 9- [Math::Pari] needs pariErr->die _before_ pariErr->flush
147: IZ 10- wrong valence code for plotcolor, plotclip
148: IS 11- obscure inlining bug (pgcc 1.1.3 -O3) in stark.c:ComputeKernel0()
149: 12- gcc -E doesn't define __GNUC__. Add it explicitly to KERNELCPPFLAGS
150: 13- whatnow(sigmak) didn't tell the arguments have been swapped
151: 14- [1]~ * [[1]] --> SEGV
152: 15- lim=(av+ x * bot) >> y can overflow if large addresses are available
153: (e.g Linux...). Use lim_stack() instead
154: 16- algdep(I,1), lindep([I,1]) entered an infinite loop
155: 17- removed the maxHastad (= 50) limit in algdep/lindep
156: 18- typo in polrootspadic(,,1) --> SEGV
157: 19- GC not frequent enough in idealval
158: 20- in split_ideal (isprincipal), LLL-reduce first if ideal is big
159: 21- factorpadic(,,,1) didn't work anymore
160: 22- round 2 (= nfbasis(,2)) used too much memory
161: 23- idealval did not accept all types of ideals
162: GN 24- unsafe stack handling in auxdecomp
163: 25- polroots[mod|padic] returned a t_VEC, not a t_COL (as polroots)
164: 26- check coeffs of polynomials with coeffs in nf (rnf* functions)
165: 27- typos in polredabs0 (get_Bnf + nf_RAW in storeallpols)
166: BA 28- nfgaloisapply could forget to clean up the stack
167: 29- typo in gp_rl.c (rl_save_prompt <--> rl_restore_prompt)
168: DE 30- arch="sun4" non reconnu par Configure
169: 31- uninitialized variable (prec) in quadhilbertimag
170: IS 32- pari.el.in was not updated when gphelp was moved from miscdir to bindir
171: 33- rnfkummer(bnrinit(bnfinit(y^2-y-1),101,1),[1,0;0,2]) --> gerepile error
172: IZ 34- update gnuplot interface
173: a) Strings were put too low in gnuplot terminal;
174: b) Allow setting of output file sizes, as in plotterm("gif=300,200");
175: c) Allow querying of possible output terminals, via plotterm("?")
176: d) Update to newer Gnuplot-interface-layer (Gnuplot.h)
177: allows compilation on Linux (stdout was bad as an initializer),
178: corrects bugs in processing of terminal options
179: 35- in buchall, allow minfsb to increase before doubling cbach
180: (bnfinit(x^4+5*239*x^2+5*239^2) couldn't be computed)
181: 36- bnfnewprec can't handle bnf = bnfinit(,2) --> SEGV (now, error)
182: 37- typo in pseudorem (didn't recognize 0 properly)
183: GH 38- weird bugs in thue() on alpha: typo int <--> long in thue.c
184: 39- bnrisconductor assumed moduli had small norm (< VERYBIGINT)
185: 40- bnfnewprec didn't accept imaginary quadratic fields ("missing units")
186: 41- inefficiency in zarchstar (VERYBIGINT --> BIGINT)
187: (rnfconductor(bnfinit(y^3+972*y-12),x^2+x+1) ran forever)
188: 42- too much memory used in rnfordmax (+ removed some inefficiencies)
189: 43- try to recover in nffactormod if input not prime (SEGV)
190: 44- SEGV in nffactormod if degree(pol) > 100
191: 45- factornf(p(x), q(x)) was accepted (and produced incorrect objects)
192: 46- nfisincl / nfisiso made use of the bug above
193: 47- subgrouplist(bnr) with trivial ray class group --> SEGV
194: 48- background color was assumed to be "white" (by gphelp and gp)
195: Made it "transparent" by default
196: 49- pages shifted by 1 in User's Manual's table of contents
197: 50- Mod(x, x^2+1) + x return Mod(2*x, x^2+1), not x + Mod(x,x^2+1)
198: (fixed gadd, gmul, gdiv)
199: 51- for certain flag combinations buchrayall unsuitable for gerepileupto
200: (+ cleaned up the code)
201: 52- ^C in smithclean corrupt existing objects
202: 53- silent overflow in qfbhclasso
203: 54- nfreducemodpr didn't check its arguments
204: 55- confusing error messages when precision too low in initell
205: 56- polx[0] modified in nfsubfields(P(y))
206: 57- various memory optimizations in bnrstark
207: 58- incorrect debugging output in calc_bloc (at \g6)
208: 59- rare memory corruption when garbage collecting in mppgcd
209: 60- type t_STR not treated correctly in changevar
210: 61- C-long overflow in ellan
211: 62- memory use in the incgam* functions
212: 63- bad input bug: qfperfection(indefinite matrix) --> SEGV
213: 64- mateigen dropped some eigenvectors when precision was too low
214:
215: Changed
216: 1- err() --> parierr() [conflict with system library in Redhat 6.0]
217: 2- use Doud's algorithm in elltors [initial patch: HC]
218: 3- new (internal) function get_mul_table (for nfinit, padicff)
219: 4- disable LD_LIBRARY_PATH before running benches
220: 5- strtoGEN() --> strtoGENstr() + added flag
221: 6- optimized stack usage in pollardbrent (in place)
222: 7- don't try to compute units in buchrayall if bnf doesn't contain them
223: 8- simplified misc/gprc.* (esp. colors)
224: 9- use C long to keep track of exponent in regula
225: 10- src/kernel/sparcv7/level0.s --> level0.S + include preprocessing stuff
226: 11- extended matsnf flags: immediate cleanup (backward compatible)
227: 12- arguments swapped in veceint1
228: 13- allow @ markers (??keyword@) in extended help (was apropos only)
229: 14- do all computations in mppgcd in place (as in Changed-6)
230: OR 15- new pari.el (cf emacs/pariemacs.txt)
231: 16- search multiple lines in apropos extended help (???key)
232:
233: Removed
234: 1- make test duplicated the "make bench" computations. Removed the
235: test and dotest targets
236: 2 -veceint1() function. Can be reached in library mode or using a flag to
237: eint1
238:
239: Added
240: 1- default 'secure'
241: 2- optional flag to Str()
242: 3- expand environment variables in filenames
243: 4- TODO file
244: 5- man page for gphelp
245: 6- Trivia section in the pari/gp man page
246:
247: ===========================================================================
248: Done for version 2.0.15.beta (released 21/05/99):
249:
250: Fixed
251: 1- ?? (TeX mode) didn't work anymore
252: 2- rl_save_prompt incorrectly detected on a.out systems
253: 3- allow extra_relation() (bnfclassunit) to abort
254: 4- allow cbach to double once more before triggering PLEASE REPORT
255: (introduced in 2.0.14)
256: 5- check for non-monic pol in smallbuchinit
257: 6- vecex<TAB> --> SEGV on some Linux systems (typo in match_concat)
258: 7- exceedingly rare but possible overflow in forvec(, flag == 1)
259: 8- factorff(x^7-3,3,y^3+2) --> SEGV
260: DC 9- ghpelp doesn't exit when problems arise in TeX processing
261: 10- made idealprimedec random again (also use det_mod_P_n to compute norm)
262: 11- inefficiencies in nfeltval (computing norm is a waste of time)
263: 12- did same prime twice when collecting garbage in modulargcd (=> error)
264: 13- ffinit(huge prime,) output a weird error message
265: 14- highly inefficient memory use in nfsubfields
266: IS 15- [cygwin] typo in Makefile generation
267: 16- file leak in mpqs (COMB)
268: 17- allow prime_to_ideal to be called with a t_INT argument (for quadray)
269: 18- typo in nf_shanks (calling Fp_shanks with wrong parameters)
270: 19- polun (possibly) destroyed in bnrstark
271: IS 20- keep logfile in synch with screen output
272: 21- reset DEBUGLEVEL correctly on ^C (was sometimes set to 0)
273: 22- bnrstark does not require anymore the modulus to be the conductor
274: 23- check bnrstark's arguments in the right order (bnrstark(1,0) --> SEGV)
275: 24- inefficiencies in idealval (removed element_mulh)
276: 25- idealadd unsuitable for gerepileupto
277: HC 26- quadray should work in all cases now and give better polynomials
278: XR 27- bnrstark should return smaller polynomials
279: 28- very inefficient pseudo-remainder routine (psres)
280: 29- forstep(x=a,b, 1/2, ...) --> SEGV (signe -> gsigne)
281: IS 30- [Cygwin] Configure fix (use $HOSTTYPE instead of uname -m)
282: 31- polcoeff(a*x^-1*y^-1+O(x^2)+O(y^2),-1,y) --> 0
283: HC 32- (false) accuracy problem in mpsc1 ("truncation error")
284: 33- don't use mpqs_diffptr in mpqs_find_k, set it in mpqs_create_FB
285: 34- (very rare) "precision loss in truncation" in buchall
286: 35- C-long overflow in zarchstar
287: 36- C-long overflow in zprimestar
288: 37- (old versions of) GNU as not recognized correctly
289: BA 38- ?? in TeX mode could not process some sections (missing macros)
290: 39- factor(polynomial with t_PADIC coeffs) didn't work (factorpadic
291: assumed coeffs were integers)
292: 40- T=[1,x; x,1]; charpoly(T,Z) produced object with wrong variable
293: ordering
294: 41- polrootsmod(x^n,p) could corrupt the stack
295: 42- Warnings/errors from HPUX and AIX native compilers
296: OR 43- many problems in the emacs interface pari.el (introduced in 2.0.14)
297: 44- factorpadic treated only monic polynomials
298: 45- gphelp TeX mode (use general macros instead of a specific file)
299: 46- under readline, input lines of length > 2048 could trigger SEGV
300: 47- more thorough check in checkbid (accepted prime ideals->SEGV)
301: GH 48- possible stack corruption in thueinit(totally real field)
302: XR 49- various problems in bnrstark (infinite loop in fincke_pohst)
303: 50- in doc/Makefile: removed GNU-style make macros + put a missing TAB
304: 51- sloppy garbage collecting in hnfperm
305: 52- HPUX+cc: work around a compiler bug (wr_float)
306: 53- warnings in make_emacs_tags (perl5.005)
307: 54- Configure --static should not disable install()
308: 55- in rare cases reduction not complete in lllgramall (off-by-1 error)
309: 56- addshiftw (polynomial case) could produce non-normalized polynomials
310: 57- take content into account in modulargcd as in srgcd (not normalized)
311: GH 58- uninitialized variable in poldisc0 (purify warning)
312: 59- inefficiencies in round 4: modular computations [more needed!]
313: (starting from a patch by DF+XR)
314: GN 60- lllintpartial did not output the right matrix
315: 61- huge memory leaks in bnrstark
316: 62- signed int overflow in allocatemem
317: 63- parisize (local to gp/gp.c) not updated properly
318: 64- *sol not properly initialized in subresall
319: 65- in idealpowred, check whether |n| < 16, not n < 16 (would slow down
320: bnfinit a lot when class number is large)
321: 66- polrootsmod(x^6-10,25) --> SEGV (now error message)
322: 67- SEGV when renormalizing zero series in gdiv
323: XR 68- unify precision choice in bnrstark (4 different formulae used...)
324: GN 69- infinite loop in mpqs (64bits machines + harsh compiler) when more
325: factors were found than were hoped for (1 <--> 1L)
326: GN 70- SIGFPE in buchall (double didn't fit in 32-bit integer)
327: 71- also check sign in real0 (internal: called by gauss_pivot)
328: 72- use current realprecision in plot() (was fixed: 28 digits)
329: 73- memory use in subgrouplist(bnr)
330: 74- in bnfcertify: "Too many iterations in isprincipal"
331: 75- auto detect precision in quadhilbertimag ("overflow in I+R")
332: 76- error message numbers in src/kernel/m68k/mp.s
333: 77- polroots(x^3-x-422!) --> "impossible R-> dbl conversion"
334: 78- not enough modular reductions in buchrayall (bnrinit)
335: 79- technical argument in quadclassunit not read correctly
336: 80- factor(x^3-1 + 0.*I) --> gerepile error
337: GN 81- gp -p (close to a p^2) --> p possibly missing in the prime table
338: 82- until narrow class group in quadclassunit is implemented, non-zero
339: flag raises an error
340: IZ 83- some code numbers in functions_basic (for Math::Pari)
341: 84- precision problem in initell (AGM)
342: 85- "impossible assignment I-->S" in ellrootno
343: 86- missing break in poltype (factor)
344:
345: Changed
346: 1- ?? (no arguments) opens the users'manual in xdvi
347: 2- print readline version in header on startup
348: 3- compute multiplication table first in element_mulvec[row]
349: 4- nf[5][7] is now stored in two-element form (faster ideal inversion)
350: 5- install gphelp in BINDIR, not MISCDIR
351: 6- simplified output of trivial matrices
352: 7- replaced square_free_factorization by mysquare_free_factorization
353: 8- call LLL before using idealtwoelt
354: GH 9- choose random elements in idealtwoelt, and allow bigger ones in two_elt
355: 10- cleaned up lllgramall/lllgramintern + give quality ratio as argument
356: 11- in rnflllgram, try to survive lllgram errors (findmin)
357: 12- simplified rnfpolredabs (simple interface to polredabs). Should be
358: much more efficient
359: 13- replace many gdiv by 1 ginv + many gmul in sqred1intern
360: 14- optimized polredabs (always do the initial polred now: it is for free)
361: 15- more efficient ideal multiplication in random_relation (bnfinit)
362: 16- library names nfhermite[mod|basis] <--> nfhnf[mod|basis]
363: 17- subgrouplist function (use Birkhoff algorithm)
364: 18- improve recovery in lllgramintern
365: 19- improved checkgenerator in polredabs (look directly for double roots)
366: 20- for consistency, return S-units in t_POL format (as fundamental units)
367: IZ 21- revamp gnuplot autodetection by Configure
368: BA 22- nfgaloisconj(nf, 4) uses Allombert's algorithm instead of Kluners's
369:
370: Added
371: 1- install-doc target
372: 2- make install makes a symlink pari.1 --> gp.1
373: 3- ??tutorial/refcard opens tutorial/refcard.dvi in xdvi
374: 4- posibility to extract the complement in vecextract
375: HC 5- Ducos's subresultant algorithm (polresultant(,,2))
376: HC 6- accept a "vector of steps" in forstep
377: 7- examples/classno.gp
378: XR 8- new function bnrL1
379: 9- new function gdivexact (used in subresultant, Gauss-Bareiss...)
380: 10- new function bnfnewprec
381: 11- optional argument to \l and \e shortcut
382: 12- nfinit,polred[abs] accept input of the form [pol, HNF basis fro Z_K]
383: 13- q-Pascal triangle (matpascal(n,q))
384: 14- file src/basemath/subgroup.c, new function forsubgroup()
385: IZ 15- function plotclip
386: IZ 16- new file examples/taylor.gp (nice example for plotclip)
387: BA 17- new file galconj.c
388:
389: ===========================================================================
390: Done for version 2.0.14.alpha (released 05/03/99):
391:
392: Fixed
393: 1- factormod(2*x+1, 2) --> "factor for general pol. not implemented"
394: IK 2- gphelp could leak temporary files
395: BD 3- for native Win32 build: buffer overflow in get_home, incomplete
396: paricfg.h, typo in try_pipe (#endif misplaced)
397: 4- nfsubfields: could miss subfields if index > 1
398: 5- removed 3 useless setrand(1) in subfields.c
399: 6- rare and obscure memory bug in inverseimage (lost pointers in gerepile)
400: 7- memory bug in factorpadic4 (prime not copied before result)
401: 8- memory consumption in round2 (allbase)
402: GT 9- m68k version: duplicate symbols from mp.c
403: IS 10- Cygwin: in mpqs.c, open files in binary mode (otherwise fseek goes crazy)
404: 11- bnfisprincipal().gen gives the expected answer
405: IZ 12- signatures for Math::Pari in highlvl.c / init.c + GNUPLOT
406: set-output-file problem
407: 13- if we think readline needs libiberty, check whether it's installed first
408: DB 14- PowerMac: header inclusion in highlvl.c, lround def'd in system headers
409: XR 15- rnfkummer makes sure to return an integer
410: XR 16- rnfconductor accepts polynomials with rational coeffs
411: 17- polredabs + internal precision change --> nfnewprec forgets nf[5][1]
412: 18- don't log lines twice when pariecho is set
413: 19- glitches in content() (e.g content("a") --> SEGV)
414: 20- get_sep(2) reacted incorrectly to empty strings
415: 21- rootmod could destroy its argument
416: 22- Fp_pow_mod_pol(x, 1,...) should return gcopy(x), not x
417: 23- galoisconj1 computed wrongly the precision needed (+ prototype change)
418: IZ 24- remove __OPTIMIZE__ dependence (define GCC_INLINE instead)
419: 25- off-by-1 error in apell1
420: 26- misleading error message in minimalexponent()
421: XR 27- in nffactor, forgot to update precision when increasing exponent
422: (+ various typos)
423: 28- sparc + non-gcc --> kernel2 possibly not included: compilation failure
424: 29- when echo is set don't print prompt if line is empty
425: 30- ellpointtoz sometimes return -x instead of x
426: 31- gp -b 1 --> hangs gp
427: DE 32- many glitches in manual
428: 33- mathnf(x, 3) when x hasn't maximal rank (SEGV)
429: 34- differences in buchall 32bit/64bit (PRECREG too high. bnfinit(x^13-6))
430: 35- various inefficiencies in nfshanks ("module too large in nfshanks")
431: 36- memory leak in buchall (= bnf*)
432: 37- "not a definite matrix in lllgram" after a call to bnf*
433: 38- typo in factorff(x^3+2,3,y^2+1) --> SEGV
434: 39- [internal] missing tags (e.g zprimestar) after make ctags
435: 40- idealstar(*, big prime) --> cryptic error msg (more tolerant now)
436: 41- have Mod(0,1)^-1 return Mod(0,1) (fixes znstar(prime))
437: 42- ginv(-1/2) --> 2
438: 43- heap leak when using local()
439: 44- overflow in addssmod
440: 45- changed the syntax of round()
441: 46- sqrt(1. + O(x)) --> infinite recursion
442: IZ 47- don't create GP variables when expanding strings
443: 48- internal variable 'parisize' not properly updated after allocatemem()
444: IS 49- config/display didn't work properly with ActivePerl
445: IS 50- Configure didn't handle most recent Cygwin
446: 51- polinterpolate([],[]) --> SEGV
447: 52- adapted gp_rl.c to readline 4.0
448: 53- glitches in whatnow database (new file src/gp/whatnow.c)
449: 54- all warnings from gcc 2.8.1
450: 55- uninitialized tetpil in gscal() (bnfreg(x^2+1))
451: 56- precision problems in polgalois (degree > 7)
452: 57- config/locatelib prompted a lot of useless work (returning too many
453: libraries) and could pick up the wrong library
454: 58- very rare bug in nfbasis (discriminant ok, but wrong basis)
455: 59- quadclassunit: make sure sub factor base is big enough (oo loop)
456: 60- more flexible "colors" default (initial work IZ)
457:
458: Changed
459: 1- x.fu outputs polynomials (as all bnf* functions), not polmods
460: 2- improved mppgcd (including vali)
461: 3- improved division vector/scalar
462: 4- \x to print a * in front of out-of-stack moduli (t_[INT|POL]MOD)
463: IZ 5- better commandline usage message
464: 6- don't buffer log messages going to pari.log
465: 7- accept [nf, t_POLMOD] where nf is expected
466: 8- poldisc() and quadgen() accept an optional variable name
467: 9- when defining user function check for duplicate variable names
468: 10- [internal] is_entry always uses function_hash (use is_entry_intern)
469: OR 11- pari.el updated (see emacs/pariemacs.txt)
470: 12- removed shiftl from lgcdii
471: 13- use roots_to_pol in polgalois
472: 14- precision heuristic in gauss_get_prec
473: 15- cleaned up lllall and lllgramall
474: 16- sort the output of nffactor, nfroots, factorff and factornf
475: 17- nfgaloisconj now guaranteed to find all conjugates (use nffactor)
476: 18- Removed flag 1 in nfisisom/nfisincl: function checks its arguments,
477: and uses the best algorithm (both guaranteed complete). Changed the
478: names (nfiso/nfincl) in library mode to match GP usage
479: 19- gerepile(ltop,lbot,0) no longer returns ltop - lbot
480: 20- improved floor and round(t_FRAC)
481: 21- removed some duplicate code from nffactor
482: 22- passing a pointer to GEN in a GP funciton now explicitly requires an &
483: IZ 23- more verbose error messages for online help
484: 24- increased a bit poltschirnaus's period
485: 25- DOS version: don't use more for external help
486: 26- cleaned up buchall code
487: 27- removed unnecessary gres from polarit1.c:to_fq()
488:
489: Added
490: 1- apropos command in gphelp (-k switch), ??? under GP
491: 2- function global()
492: 3- function gp_variable to use sums, etc in library mode
493: 4- [internal] new functions mulmat_real
494: 5- new functions gerepileupto[leaf|int]
495: 6- function znlog()
496: IZ 7- added default(color, "yes" / "no")
497: 8- --static flag to Configure
498:
499: Removed
500: 1- isinclfast/isisomfast
501: 2- rounderror
502:
503: ===========================================================================
504: Done for version 2.0.13 alpha (released 14/12/98):
505: Fixed
506: IK 1- Configure hangs on FreeBSD systems
507: RD 2- Roland's patch (2.0.11: Fixed- 42) had been incorrectly applied
508: 3- stack corruption in glcm (if operands > 10^155)
509: 4- index wrap-around in polsubcyclo (n > sqrt(2^31))
510: 5- incorrect placement of strings in psdraw
511: 6- memory corruption in rhoimag0
512: 7- fix up memory debug mode (\gm) when switching to alternate stack
513: 8- memory corruption (new_chunk + mulii) in gmul/gdiv (t_FRAC)
514: 9- escape chars in GP strings sometimes parsed twice (e.g Str("\\") --> "")
515: 10- nfinit(x^18+16) --> impossible inverse mod(0,2) (bug in eltppm()
516: introduced in 2.0.12)
517: 11- weird SEGVs due to variable handling (changed the 'bloc' structure)
518: 12- moved highlvl.c to src/gp (libpari was missing symbols from plotport)
519: 13- polcyclo ignored its second argument (introduced in 2.0.12)
520: TP 14- minor fixes in paridecl.h (poldivres, gredsp: C++ compiler exits)
521: HC 15- still sign problems in resultant (see 2.0.12: Fixed-58)
522: 16- (Solaris):GNU ld doesn't like empty object files: remove kernel2.o
523: IZ 17- make bench forgot to treat the install() BUG in a special way
524: 18- factor(x^2 + I) --> SEGV (also with t_QUADs)
525: 19- factornf(x^3+1,y^2-1) --> stack doubling (now output error msg)
526: IZ 20- for Math::Pari fix valence of factormod()
527: IZ 21- outfile rename pari_outfile (conflict with gnuplot headers)
528: 22- DEBUGLEVEL could be modified and not reset upon interrupt
529: IK 23- make perl -wc gphelp happy
530: 24- incorrect use of gettime() in the library (nffactor) --> wrong timings
531: (in particular for the 'nfield' bench)
532: 25- polred/polredabs used different types for output. Made both t_VEC
533: 26- remove duplicate polynomials in polredabs(x,4) and polred
534: XR 27- precision fixes in modules/[nffactor|stark].c
535: 28- in compatible mode, \precision didn't work anymore
536: 29- typo in Round4 (case "p small" and "p huge" were swapped)
537: 30- incorrect prototype for conductor in compatible mode
538: 31- factor((x^2-1)/2) --> SEGV (factpol assumed integer entries)
539: 32- memory usage in Round2: nfbasis(*, 2) (also cleared some inefficiencies)
540: IK 33- typo in primitive_pol_to_monic
541: 34- deplin did not check its arguments
542: 35- quadray() assumed variable "y" was not in use
543:
544: Changed
545: 1- glength() returns a C-long integer
546: 2- in hnfmodid(x,d) reduce mod d immediately
547: 3- allow vector(n), and matrix(n,m) (filled with 0s)
548: 4- under GP, wait for input if line ends with '=' (cf \)
549: 5- wait for input when a line ends with an '=' sign
550: 6- modified extended help to (potentially) search the whole manual
551: 7- in nfdisc, specific error message if discriminant is 0
552: 8- use divide_conquer_prod() in factorback()
553: IZ 9- in test suite, add setrand(1) in front of poltschirnaus
554: IZ 10- M-( bound by default
555: IZ 11- improved gnuplot support
556: 12- improved gcmp[1|_1](t_REAL)
557: OR 13- new pari.el (see emacs/pariemacs.txt)
558:
559: Added
560: 1- members e, f, p, gen for prime ideals
561: 2- mathnf([M, M2]) computes mathnf(M), updating M2 (equivalent to
562: v=mathnf(M,1) then M2*v[2], but much faster if M2 is small or over a
563: finite field)
564: 3- local() keyword for user function definitions in GP
565: IZ 4- new functions plotfile(), plotpointsize()
566: IZ 5- splines for ploth (flag 256)
567:
568: Removed
569: 1- \k metacommand
570:
571: ===========================================================================
572: Done for version 2.0.12 alpha (released 06/11/98):
573:
574: Fixed
575: 1- GNU as incorrectly treated by Configure
576: GN 2- various fixes in mpqs.c (incl. file descriptor leak)
577: GN 3- [From 2.0.11- Fixed 14] floating point exponents: 1E1 --> possibly 0.1
578: 4- 1 % Pol(2) still wasn't right [cf 2.0.11- Fixed 31]
579: 5- src/test/dotest for DOS boxes (running sh)
580: 6- removed unreachable err() in factor()
581: 7- system() is defined under EMX, so make it available for DOS
582: 8- possibly use / as path separator under EMX, check COMSPEC and EMXSHELL
583: 9- compatible = 3 downcased all the following lines in gprc and caused
584: incorrect behaviour of preprocessing statements
585: 10- unified default commands + better checks (e.g: default(log,0)->SEGV)
586: 11- memory leak in gp_main_loop: bufferlisit wasn't reset on error
587: 12- gptimer() not initialized properly if ^C was first command
588: 13- extra space (sometimes) output by command line completion in DOS
589: version
590: 14- modifying histsize could corrupt the history stack
591: 15- incorrect error messages in gsqr
592: 16- not enough garbage collection in rootmod (polgcdnun)
593: TP 17- compilation using cc -64 on 64-bit SGI
594: IS+GN 18- "(hit return to continue)" message did not flush stdin
595: GN 19- ECM rewrite
596: 20- incorect absi_cmp in buch3.c
597: 21- useless garbage collecting in sqred2
598: 22- O(1)^(1/2) --> SEGV
599: 23- forvec(i=[],...) --> SEGV
600: GN 24- deriv(x*y, y) --> 0
601: GN 25- inefficient GC in ispseudoprime()
602: 26- fixed some (not all) compiler warnings (char * --> unsigned char *)
603: 27- exp(too large number) now gives a meaningful error message
604: AW 28- getrusage still not detected on FreeBSD 2.2.5
605: GN 29- off by 1 error in initprimes() (--> not enough calculated primes)
606: 30- inefficiencies in factor(t_POL)
607: HC 31- bug in rnfelementabstorel for Mod(scalar, t_POL)
608: HC 32- typo in gaussmoduloall
609: 33- idealred(principal ideal) always returned an archimedean part
610: HC 34- idealpowprime wrong for negative powers
611: 35- typo in binomial(n,k) (wrong answer if n<=k)
612: 36- online help for polinterpolate
613: 37- incorrect garbage collecting in quickmulii/quicksqri
614: 38- reformatted the output in test mode (gp -test)
615: 39- polroots((x-7)*(x-8)*(x+16)) took far too much time
616: 40- ellap assumed ell was given in characteristic 0
617: IZ 41- outlook of plot function (better labels, better choice of chars)
618: RD 42- when factoring over a non prime finite field and found a p-th power,
619: forgot about Frobenius
620: GN 43- rare memory bug in ellfacteur
621: 44- gscalmat was not suitable for gerepileupto
622: 45- polredabs(,2) didn't handle non-monic polynomials
623: 46- check for various overflows (x ^ 1000000, etc.)
624: 47- printtex(I) --> missing closing brace
625: 48- setisset() did not check that elements were strings
626: 49- typo in gdiv(t_POLMOD, t_POLMOD) with different variables
627: KO 50- missing ; in level1.h (Windows specific code)
628: 51- forprime(p=0,10,) indeed started at p=0
629: 52- (cf 2.0.11 Fixed-1) put back 3 cgeti in galois.c (were necessary)
630: 53- factorpadic could overstate the precision of the result
631: 54- (very) rare memory corruption in allhnfmod (when cleaning up)
632: PM 55- prototypes in paridecl.h (fussy IRIX compiler), cc -64 in MACHINES
633: 56- factormod implemented for all primes (p = 2 and p > 2^31 called
634: factorcantor which was much slower)
635: 57- check for unsuitable input in [factor|roots] (SEGV for multivar. pol)
636: 58- polresultant sometimes gave the wrong sign
637: 59- extraneous space in err(impl,"") (= "sorry,... not implemented")
638: 60- aliases treated incorrectly during error recovery (--> obscure bugs)
639: 61- obscure bug when normalizing rational functions with real coeffs
640: (corrected content())
641:
642: Changed
643: 1- paricfg.h in dos and win32 extracted by Configure before the release
644: (to get version number right)
645: 2- GPRC logic: try $GPRC, then look in $HOME, /etc (/ and C:/ under EMX)
646: 3- make sure the output of pari_unique_filename() doesn't exist already
647: 4- use a stack of files to gracefully handle errors/interrupts without
648: leaking file descriptors
649: 5- replaced fixed-size buffers by dynamically allocated ones (es.c/gp.c)
650: 6- rename INSTALL.QUICK --> INSTALL.DOC (updated)
651: Changelog --> CHANGES (looks better under DOS)
652: 7- mention ?12 in the header
653: 8- use ; (instead of :) as PATH separator under DOS, OS/2 or Windows (for
654: drive letter)
655: GN 9- ECM tunings
656: 10- check for overflow in cget* (instead of silent wraparound)
657: 11- gp_main_loop cut into (improved) pieces
658: 13- simplified normalizepol
659: 14- Warn when trying to replace an existing function with install
660: (previously error)
661: 15- new function mpcopy. replaced some inlined function (rcopy, absi,
662: absr, negi, negr) by compatibility macros
663: 16- gphelp now uses GPDOCDIR and GPTMPDIR
664: 17- improved rational arithmetic by computing smaller gcds (gredsp removed)
665: GN 18- improvements in MPQS (use less memory, count relations precisely)
666: 19- text-mode (non-TeX) extended help printed screen by screen
667: 20- retuned integer multiplication, and made polkaramul the default
668: polynomial multiplication
669: XR 21- stark.c rewritten
670: IZ 22- updated the pariperl interface
671: 23- improved handling of t_INTMODs (less GC)
672: 24- improved (a lot) factoring/root finding for intmod polynomials
673: 25- modified poldivres to avoid computing remainder when useless
674: 26- removed inefficient shiftl/shiftlr from the kernel
675: 27- from the same sources, Configure can now simultaneously run on
676: different architectures
677: 28- polynomial factorizer now sorts the factors (increasing degree)
678: 29- ?an_obsolete_function now calls whatnow
679: 30- .pol operates also on t_POLMOD
680: 31- random() argument can have arbitrary length
681: IZ 32- with gnuplot, pick a sensible terminal when X11 is not around
682: IZ 33- change valences for use with Math::PARI
683: IZ 34- various interface patches (new file highlvl.c, different prototype
684: for foreignAutoload...)
685: 35- optimized permute()
686: 36- setrand, getrand, getstack, gettime return a C long, and not a GEN
687: 37- pari_randseed no longer global. Don't reset random number generator
688: when entering certain functions
689: 38- improved smallvectors() (correcting the "not enough storage" bug)
690: 39- improved computation of special polynomials ([sub]cyclo,tchebi,legendre)
691: 40- read() and extern() are timed as a whole now
692: 41- check if LONG_IS_64BIT is correctly defined in pari_init (in case we
693: include the wrong pari.h)
694: GN 42- use Lehmer-Jebelean to compute inverse mod p (TODO: extended gcd)
695: 43- moved subcyclo() to bibli2.c
696: 44- improved polredabs, suppressed flag 8
697: 45- improved ground(), case t_REAL
698: 46- modified the internal SMALL nf structure (add matrix M, for polredabs)
699:
700: Removed
701: 1- doc/Makefile.SOS, since make should succeed even if Configure failed
702: 2- many error messages from the analyzer (referer*, trucer1,
703: matvecter...), better handled by talker2
704: 3- obsolete test %_ in bench
705: 4- polkaramul(), which is now the default multiplication
706: 5- factmoder error message
707: 6- obsolete function polredabsfast
708:
709: Added
710: 1- `pipes' for DOS running EMX, i.e extern() and extended help are
711: available (perl needed for the latter)
712: 2- file handling functions pari_fopen, pari_fclose, pari_unlink
713: 3- new default `debugfiles'
714: 4- file README.DOS
715: IZ 5- target etags in top Makefile
716: 6- target ctags
717: IZ 7- gnuplot support
718: HC 8- elliptic functions package (ellzeta, ellwp, ellsigma)
719: HC 9- quadray function, extending quadhilbert
720: 10- files src/basemath/polarit3.c and src/gp/highlvl.c
721: 11- user-defined member functions
722: 12- possibility to choose sizeof(long) at Configure time when the
723: hardware suports it (eg. MIPS)
724:
725: ===========================================================================
726: Done for version 2.0.11 beta (released 30/07/98):
727: Fixed
728: 1- removed all dummy cgeti (--> new_chunk)
729: 2- stack corruption in gcarreparfait (t_INTMOD)
730: 3- incorrect Fq-loop in apprgen9
731: 4- removed useless normalize in gdivgs, gdiv
732: 5- some {} Warnings from gcc -Wall (unjustified, but doesn't hurt)
733: 6- incorrect zero series return by deriv
734: 7- gaffsg(, t_PADIC) misused the valuation (symptom: deriv((1+O(2^2))*x^2)
735: 8- online help for ellinit
736: GN 9- default gp built without X11 in presence of some versions of xmkmf
737: 10- ggval: zero series + simplified the code in there
738: 11- subst(O(q),q,x) --> O(q)
739: 12- newtonpoly did not treat correctly zero coefficients
740: IK 13- getrusage incorrectly detected (at least on Linux/FreeBSD machines)
741: 14- constante() used far too much memory (+ an int should have been a long
742: + an lg should have been an lgefint). Reading in a huge bnf needs much
743: less memory now
744: 15- y[2] checked in divri instead of is_bigint (see 2.0.10, Changed 2)
745: 16- powgi, default case: missing gcopy + incorrect gerepilemany if y==NULL
746: Also, uniformized random GC with gpowgs
747: 17- stack corruption in hil(x,y,p) when typ(x) > typ(y)
748: 18- SEGV if DISPLAY was unset and hi-res routine under X11 is called
749: GN 19- ispseudoprime(negative integer)
750: 20- removed -static from the CFLAGS of profiling version (didn't build)
751: 21- linear algebra routines involving polynomials with real coeffs
752: 22- compiles properly under DOS + EMX
753: GN 23- Warnings from C++ compiler (include unistd.h and sys/ioctl.h where
754: needed)
755: 24- znprimroot(0) --> infinite loop
756: GN 25- various fixes in mpqs
757: GN 26- add safety parentheses to macros in paricom.h
758: 27- polroots needed too much precision (two extra words)
759: 28- factor(1. * x + I) ---> rubbish or SEGV (bug in polynomialtype automat)
760: 29- possible address wrapparound in gerepile* (cast to ulong)
761: 30- in gerepile: useless special case for t_SER
762: 31- Pol(1) % 1 returned 1, not 0
763: 32- matdet([x1,1,1/x1; x2,1,1/x2 ; x3,1,1/x3]) returned wrong result
764: (call to gdeuc should have been gdiv in all cases in det())
765: 33- SEGV in powmodulo (access garbage pointer just before exiting)
766: GN 34- various problems in rho and mpqs
767:
768: Changed
769: 1- simplified detint, fibo
770: 2- simplified GC and optimized gmul: t_SERxt_SER, t_POLxt_POL, and gsqr
771: (same types)
772: 3- streamlined binomial
773: 4- replaced all abusive cmpsi by the relevant egalii
774: 5- prototype for error types [gmuler|gadder|gdiver][fi], assign[ri]
775: using new function type_name
776: 6- uniformized the test suites (make test*,bench,...)
777: GN 7- add random GC in mppgcd. Use modified plus-minus algorithm (new cgcd)
778: 8- format of bench files (to reduce size)
779: 9- cleaned up factor and polynomialtype
780: 10- matdet tries to return a significant 0 when called with a
781: non-invertible argument, e.g
782: matdet([1+O(3),1+O(3);O(3),O(3)]) --> O(3), not 0
783: 11- made the output of make bench/test slightly more informative
784:
785: Removed
786: 1- mpkaramul
787: 2- error messages expter1 and gaffer13
788:
789: Added
790: 1- misc/gprc.dos a sample gprc for DOS boxes
791: 2- Configure --prefix=dir is now recognized (in addition to -p)
792: ===========================================================================
793:
794: Done for version 2.0.10 beta (released 09/07/98):
795: Fixed
796: 1- integer factoring engine (ECM): sisprime killed N
797: XR 2- file closed twice in MPQS
798: GN 3- bad argument checking in [next|prec]prime
799: BD 4- warnings from MSVC compiler
800: 5- warnings from purify (vpariputs + puissii)
801: 6- sample program and Makefile in examples/
802: 7- v=...; forvec(a=v, v=...) ==> SEGV
803: LG 8- support for HP running NextStep
804: GN 9- have checkmemory (in cget*) check for overflows
805: LG 10- avoid a bug in cc compiler (version 4.2) under Solaris (in factmod())
806: LG 11- some missing prototypes and typecasts (for C++)
807: GN 12- add LOCAL_HIREMAINDER in mulssmod (factor(17!+1) => SEGV on some PCs)
808: 13- non portable pari_is_rwxdir
809: GN 14- lots of typos in the documentation
810:
811: Changed
812: GN 1- add debugging output to ECM
813: 2- forvec implementation (+ new flags)
814: GN 3- rewrote the integer factorizer (use Pollard-Brent + improved ECM +
815: new MPQS code from 2.0.9)
816: 4- disabled pari-matched-insert under Emacs
817: 5- reorganized vecsort & co
818: 6- in library mode, classno3 --> hclassno
819: XR 7- improved the nffactor module
820: HC 8- elllseries (use ellglobalred + ellrootno)
821:
822: Added
823: 1- new function in library mode lisGEN()
824: HC 2- new GP function ellrootno
825:
826: Removed
827: 1- error message vecsorter2
828: 2- functions vecindexsort, veclexsort (use vecsort with flag)
829:
830: ===========================================================================
831: Done for version 2.0.9 alpha (released 16/06/98):
832:
833: Fixed
834: 1- typo in qfbhclassno (SEGV when result in (1/3)Z)
835: 2- too much memory allocated in factmod /factcantor (use clones)
836: 3- removed the -DREADLINE_LIBRARY hack, use <readline/readline.h> and
837: not <readline.h>
838: 4- version 2.0.8 did not compile with readline 1.*
839: 5- after gaffect(0, padic), padic was unsuitable for further gaffect
840: 6- length(a string) gave number of non code words, not string length
841: 7- factorpadic(polynomial of degree one) did not convert coeffs to padics
842: 8- reduction mod p^r forgotten in gaffsg(s,t_PADIC)
843: 9- default(realprecision,,1) did not return # significant digits
844: 10- typo in nfmodprinit (return x instead of 1-x)
845: 11- matinverseimage did not check its arguments
846: 12- mathess([;]) --> SEGV
847: 13- matid(-100) --> SEGV
848: 14- mateigen([;]) --> SEGV
849: 15- matmultodiagonal([;],Mat(1)) --> SEGV
850: 16- vecextract([;],"..") --> SEGV
851: 17- introduced in 2.0.8 (Added 3-): aliases/user function + <TAB> ==> SEGV
852: GN 18- (t_RFRAC) ^ t_INT took an unreasonable amount of time
853: 19- prevent quick succession of ^C from corrupting memory in recover()
854: 20- hyperu could enter an infinite loop due to round-off errors
855: XR 21- matadjoint(Mat(n)) returned Mat(n), not Mat(1)
856: 22- matadjoint([;]) returned [[;]] (???)
857: 22- wrap some long error messages
858: XR 23- inefficiencies in rnfpolredabs
859: XR 24- nffactor (wrong format for discriminant computation + problems with
860: unseparable polynomials + compute disc only once)
861: HC 25- typos in kummer.c
862: GN 26- check environment variable LINES, not ROWS
863: 27- introduced in 2.0.7 (Fixed 7-): lift(Mod(O(2^0)*x, x^3 - 2)^4) was a
864: zero polynomial with non-zero sign (=> pb when normalizing in poldivres)
865: 28- timer always returned 0 if times() was used (e.g linux-alpha)
866: 29- kill'ing the argument of a user function corrupted the function
867: 30- make clean did not remove pariinline.h
868: 31- incorrect memcopy in identifier, case 's' (removed * sizeof(long))
869: 32- online help for ?. (nf.nf does not exist)
870: 33- lisseq0: gnil not respected after break/next. avma=av too brutal
871: after return
872: 34- ellwp assumed precdl > 3
873: 35- under emacs, \c + hit return froze emacs (Emmanuel Kowalski)
874: 36- (f()= f()=x); f; didn't set f properly
875: GN 37- comments in anal.c
876: 38- qflllgram([;]) --> SEGV
877: 39- no online help for bernfrac
878: 40- from 2.0.6 (Fixed-8): in padicff2, forgot to raise ideal to power e
879:
880: Changed
881: 1- improved (trivially) gneg (case t_INTMOD), gtopoly
882: 2- use macro is_bigint() instead of tests (ulong)x[2] < VERYBIGINT
883: (led to typos as in Fixed-4 in 2.0.8)
884: 3- improved poldivres by replacing many gsub by 1 gneg + many gadd
885: 4- in pvaluation check for small integer
886: 5- internal function rnfelement_*mod (prhall=NULL instead of gzero)
887: 6- improved mathess
888: 7- added error message "inconsistent data in" in parierr.h
889: 8- gpui[gs] renamed to gpow[gs]
890: GN 9- improved probable-primality tests ('end matching')
891: 10- moved pseudo primality and ECM stuff into ifactor1.c
892: GN 11- raise to an integer power using left-shift binary (new functions
893: powi and powgi)
894: 12- add some details in the online help headers
895: GN 13- nextprime, precprime now accept real arguments
896: TP 14- improved the alpha micro kernel (addllx and subllx)
897: 15- simplified poltschirnaus
898: 16- cleaned up identifier(): #ifdef __hpux__ + call_fun() modified
899: 17- taylor() improved (one gerepile removed)
900: 18- unified the treatment of zero series
901: 19- gerepilemany faster and more efficient memory-wise (copy to heap first)
902: GN 20- improved stack checking in lllgramall
903:
904: Removed
905: 1- global variable defaultpadicprecision
906: 2- function compute_prhall (nfmodprinit is better)
907: 3- function [g]pseudopremier (miller[rabin] better)
908:
909: Added
910: 1- function egalii
911: 2- support for cygwin32 in Configure (Andy Stubbs)
912: 3- new function gunclone to delete a clone (killbloc should be used by
913: the analyser only)
914: 4- comments in anal.c
915: TP/XR 5- new function factorint(), using MPQS (_experimental_)
916:
917: ===========================================================================
918: Done for version 2.0.8.alpha (released 07/05/98):
919:
920: Fixed
921: 1- improved garbage collecting in polroots
922: 2- zetak did not check its nfz argument properly
923: 3- warnings from MSVC
924: GN 4- isprime() did not work for numbers in [2^(BIL-1), 2^BIL-1]
925: GN 5- precprime sometimes missed a prime
926: 6- quaddisc(x in Q\Z) did not always work
927: 7- powering of zero series
928: 8- factorization of null matrices (SEGV)
929: 9- mateigen for non-diagonalizable matrices (SEGV)
930: GN 10- infinite loops in some arithmetical functions when arg = big prime
931: GN 11- cleaned up paridecl.h
932: 12- gimag/greal for type t_RFRAC/t_RFRACN (fix: Terje Sparre Olsen)
933: GN 13- ordinal numbers to number components seen through \x
934: HC 14- lllgram: incorrect gabage collecting in first "warnmem"
935: 15- theta(q exact, z) entered infinite loop
936: 16- typo in gdiventres (x<-->y in last line)
937: MS 17- gtrunc for p-adics when valp(x) < 0
938: MS 18- polresultant(u+v,u-v,v) => x + u; polresultant(u+v,u-v) => 2*u
939: MS 19- issquare(Pol), where Pol(0) = 0
940: IZ 20- use 15 points (by default) for recursive plotting as documented
941: 21- matsnf for singular matrices (supersedes a patch by GN)
942: LG 22- micro kernel support for HPUX
943: LG 23- compilation with Sun's C++ compiler (version 4.2)
944: 24- SEGV when factoring polynomials of huge degree (removed expos[100],etc)
945: 25- garbage collection in gpuigs
946: GN/BH 26- micro kernel support for ix86 running SunOS
947: HC 27- handling of 0x0 matrix in some hnf* functions
948: HC 28- bug in discrayabslist* (try bnrdisclist(bnfinit(y^2-2),200,,1) in 2.0.7)
949:
950: Changed:
951: 1- moved hnf and snf from base1.c to alglin2.c (base1.c too big)
952: 2- use gexpo in linear algebra functions when entries contain real
953: numbers (work for inexact polynomial entries now). Still does not
954: work properly for p-adics
955: GN 3- in sigma() fall back to numbdiv() or sumdiv() when k < 2
956: 4- made comments started in file through read("file") local to file
957: (not so \r file)
958: 5- valuation(0) now returns VERYBIGINT instead of raising an error
959: MS 6- simplified gegal in case t_FRAC
960: IZ/GN 7- faster initprimes, using less memory
961: LG 8- improved Configure
962:
963: Added:
964: 1- new function write1
965: MS 2- new Lisp-like quote operator 'a
966: IZ 3- readline: electric parentheses, move across balanced expressions,
967: add formal arguments to completion of GP command (when unique)
968: 4- micro-kernel for hppa
969: 5- quiet mode (gp -q) to suppress headers
970:
971: ===========================================================================
972: Done for version 2.0.7.alpha (released 21/03/98):
973:
974: Fixed
975: XR 1- SEGV in get_regulator for imag. quad. fields
976: 2- "beautified" output (still ugly, less buggy, ok for simple objects)
977: 3- error during "print()" could change output default
978: 4- SEGV when syntax errors in gprc
979: 5- make install failed when libpari.$sodest had been removed
980: 6- moved term_width and term_heigth to es.c
981: HC 7- inefficiency in mulii (Karatsuba used too easily)
982: XR 8- many problems in stark.c
983: XR 9- bugs in rnfpolredabs (+ new flag)
984: GN 10- _many_ typos in tutorial and user's manual. New, much nicer, layout
985: 11- whatnow not robust enough + faulty call by err_new_fun ==> SEGV
986: 12- idealadd treated incorrectly the 0 ideal
987: 13- default(realprecision) gave wrong value when format had been changed
988: 14- bnfs structure was inefficient for applications (inverted 2nd comp.)
989: 15- buffersize was incorrectly updated during complicated read()
990: 16- one-line comments "ignored" if buffersize too small
991: 17- using eval on object containing killed variables caused a SEGV
992: 18- contfrac lost last term when first parameter was rational and
993: numerators were supplied
994: 19- problems when dividing with polynomials/series whose leading coeff is
995: non-exact 0
996: BD 20- missing #ifdef ZCAT in es.c
997: BD 21- check in paricom.h whether min / max are already defined
998: BD 22- universal_constants freed early in freeall() (problems on Windows NT)
999: BH 23- update Makefile.dos (nf.h --> parinf.h)
1000: BH 24- changed kernel/ix86/level0asm.c (FUNBEGIN/FUNEND + ALIGN)
1001: 25- cleaned the gauss_pivot functions + garbage collecting in gauss()
1002: 26- mathnfmod did not check its second argument
1003: 27- since 2.0.4 (item 24) install did not work anymore on FreeBSD + gp-dyn
1004: 28- cleaner malloc in plotX.c (to remove Warnings when debugmem > 0)
1005: 29- slightly optimized matdet (gsub --> gadd(,gneg))
1006: 30- ? x=1; Pol(1)
1007: *** variable name expected: x,n,
1008: ^---
1009: is fixed everwhere (wherever an optional variable name is expected)
1010: setting "x" to some value is now safe
1011: IZ 31- nicer looking plot() function
1012: 32- warnings while building for m68k arch
1013: 33- sqrt(Mod(1,2)) went into an infinite loop
1014: 34- ?? did not resolve aliases
1015: 35- besselk near integers entered an infinite loop
1016: 36- p-adic sqrt (bad valp)
1017: 37- hnfmodid could output wrong results (wrong diagonal) and wreck the
1018: powering of prime ideals
1019: 38- added garbage collecting in izeta
1020: 39- ??a_number now works as gphelp
1021: 40- in prettymatrix format, matrices 0xn and nx0 are always printed as [;]
1022: 41- 1 - "a" ==> SEGV
1023:
1024: Changed
1025: 1- reorganized output functions (es.c)
1026: 2- have mulir check if integer is small
1027: 3- part of GENtostr inlined (check_output_length())
1028: HC 4- functions where it makes sense now admit an optional argument for
1029: "variable number" (intformal, deriv, things having to do with
1030: polynomials, etc)
1031: 5- lines of any length can be input interactively (previously 1k at most)
1032: 6- remove {} and \ from readline history
1033: 7- improve treatment of sample programs in gphelp -d
1034: 8- uniformized debugmem messages
1035: 9- simplify the coinit function (Michael Somos)
1036: 10- changing the function set through default(compatible,) no longer
1037: resets installed functions
1038: 11- renamed nfker-->nfkermodpr, nfgauss-->nfsolvemodpr
1039: 12- simplified/extended dummycopy
1040: 13- listput gives more informative error messages
1041:
1042: Added
1043: 1- default: lines
1044: HC 2- (made known to GP) functions nfmodprinit, nfkermodpr & nfsolvemodpr
1045: XR 3- function bnrstark
1046: 4- install code D& (optional pointer)
1047: 5- function name_var (to use after fetch_var)
1048: 6- concatenation of lists (or row vectors) of objects (overloaded concat)
1049: 7- ranges for vecextract (eg. vecextract(x, "1..3"))
1050:
1051: Removed
1052: 1- useless code 'F' in analyzer
1053: 2- perl directory (moved the files in ./perl to ./doc)
1054: ===========================================================================
1055: Done for version 2.0.6.alpha (released 22/02/98):
1056:
1057: Fixed
1058: 1- \x (voir2) did not always print the correct number of words
1059: 2- in changevar, type POLMOD, modulus and polynomial were interchanged
1060: 3- all occurences of former header file names in the documentation
1061: 4- (from 2.0.5. item C5) using allocatemem in a script aborted file reading
1062: 5- expanded the documentation for bnrrootnumber
1063: 6- factor(pol. with rational non integer coeff) could corrupt the stack
1064: 7- Euler gave wrong results when prec > 80502 digits (also cleaned up Pi)
1065: 8- cleaned up ggcd, grando0, tayl and factorpadic2
1066: 9- is_scalar_t --> is_const_t in gvar/gvar2
1067: IZ 10- Configure and example Makefile for OS/2
1068: 11- idealprincipal did not accept n x 1 matrices
1069: 12- idealhnf(nf,a,b) did not work for quadratic fields
1070: 13- matsolve[mod]([;],.) could corrupt the stack or accept incorrect input
1071: 14- modules/galois.c unnecessarily included <sys/stat.h>
1072: BH 15- symbol name problem in level0asm.c (cancels patch by IZ)
1073: XR 16- fixes in stark.c
1074: 17- cleaned all occurences of HIGHVALPBIT and HIGHEXPOBIT
1075: 18- serconvol assumed main variable was "x"
1076: 19- (x + O(x^2))^(3/2) gave a stupid error message
1077: 20- types not checked correctly in gtoser
1078: 21- check more seriously arguments to default()
1079: 22- in Makefile: added some missing $(RM), changed an "ln -s" in $(LN)
1080: 23- extra '\n' after print1 + sequence of warnings
1081: 24- simplified a statement in addii()
1082: 25- typo in classno() (classno(-200183): "division by 0") + cleaned classno
1083: 26- all compiler warnings + most of lint's
1084: 27- make install would not work anymore if emacs was not found
1085: 28- HNF reduction not always complete when rank is small compared to dim
1086: 29- gphelp -d did not handle ~ properly (+ cosmetic changes)
1087:
1088: Removed
1089: 1- unused files src/kernel/ix86/{asmi386.h,asmi386inline.h}
1090: 2- useless macro gcopyifstack and global variable RAVYZARC
1091: 3- useless error message gcder1
1092: 4- useless (undocumented) function fasthnf
1093:
1094: Changed
1095: 1- simplified isonstack
1096: 2- extended valid inputs for matsolvemod
1097: 3- don't output a '\n' before an empty matrix
1098: 4- mpsincos no longer static (so that it can be installed)
1099: 5- reorganized gp_initrc() to cater for for non-UNIX arch
1100: 6- the "obsolete function" message now launches whatnow() directly
1101: (and caters for the special cases "i" and "o" now)
1102: 7- improved stack management in hnf/allhnfmod/fasthnf
1103: 8- moved powering functions to trans1.c
1104: 9- disable logfile while reading .gprc
1105: 10- (slightly) the output of whatnow()
1106:
1107: Added
1108: BH 1- support for DOS build using EMX (dos directory + fixes)
1109: 2- function cotan() and bernfrac()
1110: 3- a code for pointers (&) for analyzer and install()
1111: 4- ??readline now includes info about completion and online help
1112:
1113: ===========================================================================
1114: Done for version 2.0.5.alpha (released 07/02/98):
1115:
1116: Fixed
1117: BH 1- LOCAL_HIREMAINDER added twice more in mp.c
1118: LG 2- some symbols declared extern in gp_rl.c to avoid compiler warnings
1119: LG 3- isprime could corrupt the stack (isprime_proto removed)
1120: LG 4- possible redeclaration of macro from system header (MAX in bibli1.c)
1121: 5- typos in the user's manual
1122: 6- removed unused error numbers and fixed their ordering in mp.s
1123: 7- a ; or : after read/extern was not always correctly taken into account
1124: 8- a bug in polroots (possible SEGV in very rare cases) (Paul Zimmermann)
1125:
1126: Changed
1127: LG 1- (huge) reorganization of PARI kernel and headers
1128: 2- logfile example in gprc.dft to take advantage of "time expansion"
1129: XR 3- stark units module rewritten
1130: HC 4- rnfpolredabs improved
1131: 5- errors now cause GP to close any file it was reading instead of going on
1132: 6- increased the static limit for the number of files opened simultaneously
1133:
1134: Added
1135: XR 1- function bnrrootnumber
1136:
1137: ===========================================================================
1138: Done for version 2.0.4.alpha (released 26/01/98):
1139:
1140: Fixed
1141: 1- recovery on startup was not correctly disabled
1142: GN 2- pari.el (see emacs/pari.el-changes)
1143: 3- "" missing around a DLLD caused Configure to fail if shared library not
1144: available
1145: 4- component of GEN could be created before its root in gadd(t_SER, t_SER)
1146: 5- nffactormod did not like big primes
1147: 6- removed the `.' binary concat operator introduced in last update
1148: (broke semantics). Instead Str() argument evaluated in string context
1149: 7- solve did not find some obvious zeroes (solve(x=-2,1,x) for instance)
1150: 8- Configure -pg did not work
1151: 9- 68k version didn't work: corrected mp.s, moved some code & defines
1152: 10- subst(x,variable(x),1) did not work
1153: 11- flag acted contrary to doc in matsolvemod
1154: 12- in rare cases the prompt could still start at column > 1
1155: 13- bnfissunit much faster now
1156: 14- idealval could make mistakes with non-integers
1157: 15- Mat([1])[1,] gave a stack error
1158: 16- zetakinit(x-1) as well
1159: 17- zetakinit(K, even integer) gave a wrong result whenever r1(K)>0
1160: 18- typo in whatnow(hermite) and ?bnfsunit
1161: 19- missing newline in user error after print1
1162: 20- various typos and omissions in chapters 1, 2 and 5 of manual
1163: 21- (x-x)==(y-y) returned FALSE
1164: 22- polfactormod(f,0) gave a SIGFPE
1165: 23- some missing #ifdef UNIX
1166: BH 24- install() now works for gp-sta under Linux and OSF
1167: BH 25- gcc Warnings in gp.c + es.c
1168: BH 26- problems when installing from a different non-priviledged account
1169: BH 27- inefficiencies in mpinline.h (replace memory access by a constant)
1170:
1171: Changed
1172: 1- when logging mode is on, record command line as well as result, and
1173: flush buffer often
1174: 2- subdirectory lib now called misc. Changed some filenames in it
1175: 3- defaults psfile and logfile are now run through strftime
1176: 4- for benches total time now taken into account ([BUG] was excluded)
1177: 5- noerr is now the LAST error message (for CLISP interface)
1178: 6- cleaned path expansion (default(path,...))
1179: 7- renamed types.h and cast.h (prefixed by "pari")
1180: 8- renamed type Rect to PariRect
1181: DB 9- kernel/kerPPC.s replaced by kernel/kerPPC.c
1182: 10- made static the arrays in check_isin() (for the Mac port)
1183: BH 11- overflow/hiremainder use local variables as much as possible
1184: 12- prompt not printed during a batch job, unless echo is set
1185: commands not echoed twice in interactive mode
1186:
1187: Added
1188: 1- gplogfilter script in misc
1189: 2- check for strftime in Configure
1190: 3- support for alpha running linux (include portability fix on keralpha.s)
1191: 4- file MACHINES
1192: 5- made message for "array index out of range" error more precise
1193: 6- more frequent garbage collecting in mathnf
1194: BH 7- inline asm for i386
1195: GN 8- support for native compiler on AIX
1196:
1197: Removed
1198: 1- support for dynamic linking on AIX (did not work)
1199:
1200: ===========================================================================
1201: Done for version 2.0.3.alpha (released 13/01/98):
1202:
1203: Fixed:
1204: 1- rare bug in gadd (PADIC + PADIC) which caused one of the arguments
1205: to be overwritten
1206: 2- typos in refcard
1207: 3- galois.c still couldn't compile on the HP (_INCLUDE_POSIX_SOURCE)
1208: 4- introduced in 2.0.2: item 14 used gexpo incorrectly (bnfinit sometimes
1209: did not give units it could have computed)
1210: 5- replaced INFINITY by pariINFINITY in rootpol.c (cancels Warning on OS/2)
1211: 6- on OS/2, target ../gp-$dft in o.xxx/Makefile could not be built
1212: (extraneous $exe_suff)
1213: 7- command line switches so that one can enter them with or without white
1214: space (new function read_arg in gp.c)
1215: 8- setdcolors so that it can't unset disable_colors if we are under emacs
1216: 11- random did not check its argument correctly (random(2^32) was accepted)
1217: 12- b=10; for(a=1,b, b=2) exited immediately, whereas the upper bound is
1218: supposed to be evaluated only once
1219: 13- reorganized the error recovery system (initially because errpile could
1220: cause SEGV on Linux systems)
1221: 14- typo. problems in doc and refcard (interletter spacing in $nfz$...)
1222:
1223: Changed:
1224: 1- Reorganized Makefile.SH: extraction twice as fast
1225: 2- pari.menu and pariemacs.txt rewritten, pari.el updated
1226: 3- expanded the man gp.1 to mention command line switches
1227: 4- the implied input from non-interactive input command (like extern and
1228: read) does not go into the GP history (%x) anymore (it never went into
1229: readline's). The final output (value of last expression evaluated) of
1230: course still does!
1231: 5- updated chapter 5 of the User's Manual (removed obsolete information)
1232:
1233: Added:
1234: 1- better settings for handling the Meta key under readline in
1235: examples/Inputrc
1236: YU 2- support for shared libraries under FreeBSD
1237: 3- colors under Emacs
1238: 1) emulate exactly the "colors" default after a M-x gp
1239: 2) .gp files edited get a special highlighting
1240: 4- a flag to default() to get the result under GP
1241: 5- overloaded the "." (member) operator to concatenate as strings if LHS is
1242: a string
1243: 6- .gprc accepts some limited preprocessing directive (#if READL and
1244: #if EMACS (and #ifnot as well)). Updated lib/gprc.default to reflect the
1245: changes
1246:
1247: Removed:
1248: 1- some unused, undocumented functions (allocatemem(), checksqid())
1249: made static some other (op_ReIm)
1250:
1251: ===========================================================================
1252: Done for version 2.0.2.alpha (released 15/12/1997):
1253:
1254: Fixed:
1255: 1- typos in the documentation for the random() function
1256: 2- removed an extra -emacs flag in pari.el
1257: 3- decodefactor was incorrectly remembered by whatnow (it's factorback now)
1258: 4- test mode did not prevent all prompt expansion (==> bug in make test)
1259: 5- gphelp stopped abruptly when meeting a cross-referencing macro
1260: 6- zetainit now aborts cleanly when disc. too big (caused memory fault)
1261: 7- exceedingly rare bug in the printing of real numbers (missing decimals)
1262: 8- too early rounding in polroots which in rare cases made GP think some
1263: error had happened
1264: 9- text overflowed the manual pages (and tutorial) on non-A4 paper
1265: 10- polred incorrectly assumed that nf arguments were totally real (in a non
1266: critical part: that just led to some unnecessary computations)
1267: 11- polred(f,2) could try to overwrite universal integer gzero
1268: 12- check if we are using GNU as or GNU ld in Configure
1269: 13- empty -R argument to $CC when building GP without graphics (==> link
1270: failed)
1271: 14- bnfinit acts sensibly when fundamental units are too large (before:
1272: "overflow in R*R")
1273: 15- cleaned up buch2.c (removed ideallllredpart1, removed gerepile in
1274: class_group_generators(), not_given now called from getfu)
1275: 16- nfgaloisconj(...,2) was unusable (tried an illegal multiplication)
1276: 17- is_totally_split was very inefficient (==> nfgaloisconj was very slow)
1277: 18- some unimportant typos (gexpo) in polgalois
1278: 19- compiling without readline gave a Warning in gp.c (already_hist)
1279: 20- some make programs don't like $< (suppressed from doc/Makefile)
1280: 21- ellap sometimes assumed wrongly that coeffs of the curve were integers
1281: 22- flag 0 and 1 in ellap had been mixed up
1282: 23- print an extra \n before an error message if last output did not
1283: include it
1284: 24- component(any non recursive type) gave a SEGV
1285: 25- suminf / prodinf / prodeuler assumed they treated a real expression
1286: 26- lindep / algep had problems with numbers having a rational component
1287: 27- last significant digits of bessel* and hyperu were wrong (now only the
1288: last one is)
1289: 28- expi now returns a long as documented (expi(gzero) returned 0 on 64-bit
1290: machines!)
1291: 29- g++ could not compile libpari.a (casts missing, extraneous extern "C",
1292: faulty inline, etc.)
1293: 30- cleaned up the enums in gp.h
1294: 31- incorrect target veryclean in doc/Makefile
1295:
1296: Changed:
1297: 1- '_' is now valid in GP identifiers
1298: 2- removed subsections from table of contents. pages in the manual are now
1299: numbered consecutively
1300: 3- gexpo now accepts exact 0 arguments (return -HIGHEXPOBIT)
1301: gexpo for complex numbers now return max(gexpo(Re), gexpo(Im))
1302: 4- parts of lib/gprc.default
1303: 5- the second argument of subgrouplist is now optional
1304:
1305: Removed:
1306: 1- buggy label/goto functions
1307: 2- (now unused) error messages: labeler, gexpoer2
1308: 3- _ as shorthand for conj()
1309: 4- (useless, undocumented) function gnormalize
1310: 5- some files in the lib directory (functions, gp)
1311:
1312: Added:
1313: 1- some files in the lib directory (README, pari.xbm, xgp)
1314:
1315: ==============================================================================
1316: Done for version 2.0.1.alpha (released 29/11/1997):
1317:
1318: Fixed:
1319: 1- multiple factors forgotten when factoring univariate pols over Z
1320: 2- extraneous modifications of the random seed (period of random
1321: generator was ridiculously small for some buchxxx functions). Change
1322: the bench results (in a non essential way)
1323: 3- bad terminal size determination
1324: 4- aliases incorrectly killed (possible SEGV)
1325: 5- incrementing/decrementing array elements with the (valid) syntax
1326: v[i]++ / v[i]-- caused a weird error message
1327: 6- subgrouplist() could end up by a SEGV on Linux systems
1328: LG 7- on HP-UX, flag -Aa not taken into account in Configure (caused it to
1329: fail on has_TIOCGWINSZ.c)
1330: LG 8- added a missing #define _INCLUDE_POSIX_SOURCE in galois.c
1331: (7 & 8 independently fixed by OV)
1332: GN 9- the script examples/cl.gp called vecconcat() instead of concat()
1333: GN 10- make install-sta rebuilt gp-sta unnecessarily
1334: GN 11- many, many typos in the tutorial
1335: 12- tu / fu applied incorrectly to a bnfclassunit
1336: 13- bnfclassunit did not output a valid object (matrix whose elements were
1337: rows instead of columns)
1338: 14- conversion bug from t_QUAD to t_REAL/t_COMPLEX
1339: 15- off-by-1 error in the history recovery after an error
1340: 16- in fprintferr() (debug messages), embedded %Z did not work correctly
1341: 17- rnfequation over Q yielded a SEGV
1342: 18- string() in compatibility mode corrupted the stack
1343: 19- it is now safe to have colours in prompt and input line under readline
1344: 20- default colours restored upon exiting
1345: 21- default colors in lib/gprc.default used 0 instead of -1 for "no color"
1346: 22- psi and lngamma could give wrong results when the argument was not real
1347: 23- the make test-graphic bench was missing a newline
1348: 24- Pol(break) gave a SEGV
1349: 25- x=1; Pol(1) gave a stupid error message
1350: IZ 26- tutorial.tex was unnecessarily rebuilt
1351: 27- typos in ggcd (cases nobody will ever access: gcd of a non-reduced
1352: LG fraction with an intmod, etc.)
1353: LG 28- incorrect handling of integrals of vectors
1354: 29- gcd of polynomials with non-exact coeffs gave stupid results (they are
1355: still often wrong, since the mathematical notion is rather imprecise)
1356: 30- typos in rnfkummer (incorrect flag handling)
1357: 31- typo in idealpowprime (negative exponent gave wrong denominator)
1358: 32- multiplication t_COMPLEX x t_COMPLEX used 4 mult. instead of 3
1359: 33- some modular functions (j, f, f2) rewritten to take advantage of new eta
1360: function (trueta)
1361:
1362: Changed:
1363: 1- ?? (gphelp) starts in detex mode (-d) from a console window. tmp files
1364: now placed according to the $TMPDIR environment variable (in /tmp by
1365: default)
1366: 2- /usr/local/lib/pari/data is a better place for the Galois resolvents
1367: (which are not included yet in the standard distribution)
1368: 3- The example for prompt in gprc.default to discuss escape sequences under
1369: readline
1370: 4- Configure now starts by searching the toplevel directory for a temporary
1371: readline installation
1372: 5- The output of default(colors) was confusing. It is a string now
1373: 6- third argument of polinterpolate can be arbitrary and is now optional
1374: ("x" by default) (it had to be numeric)
1375: 7- directory configure renamed config, some of the Makefiles in there as
1376: well (to avoid confusion)
1377: 8- the low_stack macro to facilitate dynamic stack expansion
1378: 9- if, back to GP main loop, the last command was a print1(), output an
1379: extra newline. This way the prompt is guaranteed to be anchored on
1380: column 1 (suppresses a readline display bug as well)
1381: 10- Due to 9, pari.el now supposes the prompt starts in col. 1
1382: 11- Better handling of version numbers (LG)
1383: 12- decodefactor() renamed to factorback()
1384:
1385: Removed:
1386: 1- The (unused, undocumented) Malloc_Procs functions and macros
1387: 2- The (now unused) error message numvarer
1388: 3- some (useless, undocumented) targets in the top Makefile
1389: 4- (useless, undocumented) function polgcd()
1390:
1391: Added:
1392: 1- This file !
1393: 2- new flags -ch, -cb, -cu (colour support) to gphelp (see its header)
1394: IZ 3- OS/2 (+ enough tools...) supported by Configure
1395: 4- file examples/Inputrc (example of .inputrc for readline)
1396: 5- Weber f1 function implemented
1397: 6- Karatsuba multiplication t_REAL x t_REAL (development code, not used by
1398: PARI yet). Test it with install if you wish
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>