Annotation of OpenXM_contrib/pari/Announce.2.0.alpha, Revision 1.1.1.1
1.1 maekawa 1:
2: Announcement of the Pari-2.0.ALPHA release
3:
4: This message is to announce the alpha release of version 2.0 of the
5: PARI/GP system. It can be found at:
6:
7: ftp://megrez.math.u-bordeaux.fr/pub/pari/unix/pari-2.0.alpha.tar.gz
8:
9: For those who do not yet know, PARI/GP is a package which is aimed at
10: efficient computations in number theory, but also contains a large number
11: of other useful functions. It is somewhat related to a Computer Algebra
12: System, but is not really one since it treats symbolic expressions as
13: mathematical entities such as polynomials, series, matrices, etc..., and
14: not as expressions per se. However it is often much faster than other
15: CAS, and contains a huge number of specific functions not found
16: elsewhere, essentially for use in number theory. In particular, and
17: especially so in the present release, there is a very large package for
18: working in general algebraic number fields.
19:
20: This package can be used in an interactive shell (GP) or as a C/C++
21: library (PARI).
22:
23: In addition, it is free!
24:
25: For all questions related to Pari itself, mail to
26:
27: pari@math.u-bordeaux.fr
28:
29: Enjoy!
30:
31: ========================================================================
32: From the README file:
33:
34: The ALPHA status means that bugs might still be lurking around, that
35: the documentation might not be absolutely accurate, and that some
36: features or function names might change on short notice. Apart from that
37: word of caution, we believe this version is stable enough to warrant an
38: immediate release.
39:
40: We think it is important for you and for us that you try this new
41: version and send us feedback, since we can then improve the BETA version
42: (scheduled in a few months) and finally the RELEASE version.
43:
44: To save us time and worries, this is a UNIX-only, source-code-only,
45: release. We will provide binaries for later, stabler, versions.
46:
47: ========================================================================
48: Some NEW features:
49:
50: I) The GP/PARI structure has been cleaned up.
51:
52: * The whole configuration process has been automated, and a Configure
53: file is provided. Just typing 'Configure' should see you home in most
54: cases.
55:
56: * PARI is now available as a dynamic library, thanks to Louis Granboulan.
57: (you can link gp with it should you wish to). This saves a tremendous
58: amount of disk space, and is generaly more convenient as you don't need
59: to re-link your files when updating the library (or when debugging.
60: or profiling, or...).
61:
62: * types now have a symbolic mnemotechnic name (e.g t_INT for an integer,
63: t_VEC for a vector, and so on).
64:
65: * General speed-up (depends on your applications, about 20% for our
66: generic testing file).
67:
68: * Experimental module loading structure (the actual function tree
69: has not yet been cut into modules, but for the GP specific functions).
70:
71: II) Many new or improved functions in the PARI library.
72:
73: * MANY class-field related functions. In particular:
74: - is it now possible to try and remove the GRH assumption on class group
75: computations.
76: - ray class groups computations (including discrete log).
77: - explicit defining equations in simple cases (Kummer extensions of prime
78: degree, quadratic base field).
79:
80: * roots is now entirely reliable, thanks to Xavier Gourdon.
81:
82: * some core routines have been optimized: Karatsuba fast multiplication,
83: a specific function gsqr() for squarings (twice as fast as
84: gmul(x,x) in the most favourable cases),...
85:
86: * input/output is much more flexible now:
87: - a function GENtostring has been added, generalizing gitoascii to any
88: PARI object (with a simpler syntax: GENtostring(g) returns a malloced
89: string containing g as gp would print it).
90:
91: - lisexpr has a relative flisexpr (for filtered lisexpr), which enables
92: you to use input containing whitespaces.
93:
94: - you can use GENs in formatted output, a la printf.
95:
96: * improved garbage collecting.
97:
98: * private variables can be created without an explicit lisexpr(), using
99: fetch_var() and delete_var().
100:
101: III) GP has been completely re-written:
102:
103: * lowercaps/uppercaps are now significant. All predefined constants
104: (Euler, I, Pi) have been renamed (as well, the o() notation for series
105: and padics has been superseded by O()).
106:
107: for (i=1,10, print(i)) will not yield an error anymore.
108:
109: * human-readable error messages, including a caret to indicate where
110: a GP syntax error occured.
111:
112: * function names were renamed according to a more logical scheme. The
113: file new.dico provides a translation (available under GP using "whatnow")
114:
115: * You can retrieve basic information from complicated objects using member
116: functions (you cannot define your own, though). For instance x.disc will
117: yield the discriminant of x, whether it was created by nfinit (aka
118: initalg), bnfinit (aka buchinit), ellinit (aka initell).
119:
120: * A .gprc file is available to set "permanent" defaults (such as
121: global variables, aliases, common functions, etc...). For instance,
122: you can put all your scripts in some special directories, and
123: point them out to GP using "path". See misc/gprc.dft for examples.
124:
125: The function "default" enables to change most defaults under gp.
126: For instance: default(compatible,2) will give you back the former gp
127: function names and helpmessages. (default(compatible,3) undoes the
128: lowercaps/uppercaps changes as well). Try "default".
129:
130: * the basic C idiosyncrasies such as for instance i++ (for i=i+1), i<<1
131: (for left shift) or i+=j (for i=i+j) are now allowed within GP scripts.
132: /* */ multi-line comments are understood.
133:
134: * lists and (primitive) string support have been added. Characters can be
135: quoted with the usual meaning. For instance, try
136: default(prompt,"\e[1mgp\e[m > ")
137:
138: As a result, set functions can now be used with arbitrary elements.
139:
140: * if your terminal supports color (variants of color_xterm for instance),
141: you can tell GP to highlight its output in different (user configurable)
142: colors. This is done by fiddling with the default "colors".
143:
144: * The familiar functions "break", "next" and "return" are now available.
145: These should supersede the buggy label/goto provided in old versions
146: of GP.
147:
148: * somewhat enhanced on-line help. Even more: if you have perl on your
149: system, try ?? function-name (?? bnfinit for instance). This is provided
150: by external scripts which can be used independently, outside of any GP
151: session.
152:
153: * If readline is installed on your system, a context-dependent completion
154: (not yet user-programmable) is now available (try hitting <TAB> here and
155: there). Try ?? readline.
156:
157: * many functions now have default arguments (shown between braces {} in
158: the on-line description). gp first reads user-supplied arguments, and
159: then fills in the arg list with these default values. Optional args can
160: be entirely omitted, comma included (for a function with no mandatory
161: arguments, even parentheses are optional !). For instance:
162:
163: Mat = Mat()
164: bnfclassunit(x^2+1,0) = bnfclassunit(x^2+1)
165: bnfclassunit(x^2+1,,[0.2,0.2]) = bnfclassunit(x^2+1,0,[0.2,0.2])
166:
167: The "else" part of the "if" function can be entirely omitted.
168: if (a,1) is now correct; of course, the former syntax if (a,1,) is
169: still valid.
170:
171: * functions "extern" and "system" have been added to interface with
172: external programs (UNIX only). You can do for instance
173: extern("myprog"), or system("ls -l *.gp").
174:
175: * even better, "install" enables you to load any function provided by
176: a dynamically linked library, and have the GP interpreter use it. This
177: makes it easy to have your own customized version of GP with your own set
178: of functions on startup (you can document them using "addhelp").
179:
180: * On 32-bit machines, maximum number of variables has been increased from
181: 254 to 16382. Arrays can have up to 16777215 elements (instead of 65535).
182: In addition vector/matrix operations in GP now perform orders of
183: magnitudes faster than in version 1.39
184:
185: =============================================================================
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>