I see that the ticket

http://trac.sagemath.org/sage_trac/ticket/4533

has been closed. Thank you for the effort, now divisors in SAGE is
much faster!! However, the one that packed in SAGE 3.2 is still about
3 times slower than that in PARI. I wonder if all the improvements
have been implemented in 3.2. or we need to wait for 3.2.1?

PARI/GP (on a really old machine)

for(i=1,1000, divisors(3293479734242732472))
time = 1,433 ms.

SAGE (on the same machine)
sage: %timeit divisors(3293479734242732472)
100 loops, best of 3: 4.93 ms per loop

Thanks!




On Nov 16, 12:26 am, Robert Bradshaw <[EMAIL PROTECTED]>
wrote:
> On Nov 15, 2008, at 11:57 PM, pong wrote:
>
> > I was a bit reluctant to post this question here since "support"
> > shouldn't mean teaching me how to write programs. But Jason Grout
> > suggested me to post it here anyway.
>
> Short snippets of code (like the one below) are very useful. It's  
> hard to give a good answer without something concrete to go on. I am  
> also curious what kind of input you're giving it. (Highly composite I  
> suppose?)
>
> > Here is a very short script that I want to maximize the speed
>
> > def lspec(n):
> >       return sorted([k if k^2 < 2*n else 2*n/k for k indivisors
> > (odd_part(n))])
>
> > At first, I think I can make it faster by avoiding computing k^2 in
> > the for loop by replacing k^2 > 2*n  by
> > k > r where r = sqrt(RDF(2*n)) is computed once outside the for loop.
> > However, it looks like comparing two entities of different types is
> > veryslowin SAGE so I ended up with a slower script if a do that.
>
> Try setting r = (2*n).isqrt(), which is an integer. You can also  
> write 2*n//k which will do exact division (since you know the result  
> is an integer). After making these two changes it seems to run in  
> exactly the time it takes to computedivisors(odd_part(n)). The  
> divisorsfunction looks horribly inefficient, it's probably only ever  
> been used for small inputs. I've made a ticket
>
> http://trac.sagemath.org/sage_trac/ticket/4533
>
> > Also I tried to replace k by 2*n/k only for those k indivisors
> > (odd_part(n)) whose squares are > 2*n (instead of doing a list
> > comprehension) but the resulting script is not any faster.
>
> > Thanks in advance
>
> > P.S. I implemented the algorithm using PARI/GP, the result is almost
> > 200 times faster.
>
> That is quite the difference. Hopefully this gives us a good goal as  
> to how fast we can list thedivisorsof a number.
>
> - Robert
--~--~---------~--~----~------------~-------~--~----~
To post to this group, send email to sage-support@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-support
URLs: http://www.sagemath.org
-~----------~----~----~----~------~----~------~--~---

Reply via email to