I can't recall if I mentioned the following things related to performance already, apologies if I did, and apologies if some of it is out-of-date information to the SAGE group who've already been working on this:
1) I'm told Magma uses some version of Kash/Kant for algebraic number theory, or at least did at some point (at least by mentioning this online someone from the Magma group may be able to correct my misconception if it is wrong). However Magma gets a lot of its speed from algorithms of Klaus Fieker (?) which I have heard talks on at U of Sydney. I seem to recall he embeds the number field in a very very large field which has a nice representation, then tries to get information that way. I'm sure he has numerous papers on the subject. I was a young undergraduate when I saw these and couldn't explain them if I tried. At any rate, the difficulty with this approach is you cannot always tell a priori whether this is going to beat the algorithms used by say Pari. And often it does not. Beware!!! I am told (hopefully reliably) the Magma group are currently working on dramatically improving the speed of their algebraic number theory. 2) Many algorithms rely critically on factoring the discriminant, which often dominates the runtime as I understand it. SAGE has a perfect opportunity to beat Magma by using a potent cocktail of factoring routines including GMP-ECM, an implementation of Sam Wagstaff's variations on the SQUFOF theme which I have implemented in FLINT (twice the speed of Pari and Magma at factoring) and of course, for larger discriminants without small factors, my quadratic sieve, once it is done. One should also have a good implementation of Pollard- Brent, which I don't have yet. Magma are apparently working on improving their quadratic sieve. But I really can't see them beating us there. Good luck :-) 3) Clearly some routines require fast polynomial arithmetic. FLINT *cough cough*. The Magma group also claim to be broadly working on improving their "core arithmetic" over the next few years. But I am quite certain there isn't substantial work being done on improving the speed of polynomial arithmetic at this instant. I'd like to see them working on it, but I'm relatively sure Allan Steel has more interesting projects on the go at present. I look forward to the day he returns to polynomials. FLINT is getting closer to being usable. I just finished profiles of FLINT polynomial division against NTL. It is fair to say FLINT is slaying NTL everywhere (up to 25 times faster at points and typically twice the speed). We can actually do *much* better, but this will wait until post FLINT 1.0. We certainly beat Magma everywhere. That leaves only pseudo-division and poly GCD to go before FLINT 1.0 and I've already done the algorithm research for both. Pseudo-division can be done using a slight variant of the algorithm I came up with for doing polynomial division and poly GCD isn't that hard given all the work we've put into the lower level stuff. So as much as we've been saying FLINT will be released soon for many months now, it really is getting close now. So please consider using FLINT to implement some of the fast algebraic number theory routines. FLINT essentially has a development interface for doing even faster implementations of such things than might be possible via the eventual SAGEified interface to FLINT. Routines could be written in FLINT then be pyrexed into SAGE. If there is a substantial effort put into beating Magma at algebraic number theory, I'm pretty sure it is not going to be enough to pyrex existing open source packages. Magma really has done something special in this area and unfortunately the open source community have fallen woefully behind both in the range of algorithms available and in the performance arena. It's certainly something we have the tools to fix though. Bill. --~--~---------~--~----~------------~-------~--~----~ To post to this group, send email to sage-devel@googlegroups.com To unsubscribe from this group, send email to [EMAIL PROTECTED] For more options, visit this group at http://groups.google.com/group/sage-devel URLs: http://sage.scipy.org/sage/ and http://modular.math.washington.edu/sage/ -~----------~----~----~----~------~----~------~--~---