next | previous | forward | backward | up | top | index | toc | packages | Macaulay2 website
RandomComplexes :: testTimeForLLLonSyzygies

testTimeForLLLonSyzygies -- test timing for LLL on syzygies

Synopsis

Description

We randomly choose an $r \times\ n$ matrix A over ZZ with entries up to the given Height, and take the time to compute B=ker A and an LLL basis of B.

i1 : setRandomSeed "nice example 2";
i2 : r=10,n=20

o2 = (10, 20)

o2 : Sequence
i3 : (m,t1,t2)=testTimeForLLLonSyzygies(r,n,Height=>11)

o3 = ({5, 2.91596e52, 9}, .0024276, .00093192)

o3 : Sequence
i4 : (m,t1,t2)=testTimeForLLLonSyzygies(15,30,Height=>100)

o4 = ({50, 2.30853e454, 98}, .00612932, .0594945)

o4 : Sequence
i5 : L=apply(10,c->(testTimeForLLLonSyzygies(15,30))_{1,2})

o5 = {{.00664164, .0170194}, {.00596728, .0050088}, {.00637648, .00836636},
     ------------------------------------------------------------------------
     {.00689204, .0135166}, {.00673716, .0200139}, {.01893, .0200838},
     ------------------------------------------------------------------------
     {.00628484, .0100478}, {.00632528, .00915476}, {.00551648, .00597896},
     ------------------------------------------------------------------------
     {.00731716, .0114598}}

o5 : List
i6 : 1/10*sum(L,t->t_0)

o6 = .00769883200000002

o6 : RR (of precision 53)
i7 : 1/10*sum(L,t->t_1)

o7 = .012065028

o7 : RR (of precision 53)

Ways to use testTimeForLLLonSyzygies :

For the programmer

The object testTimeForLLLonSyzygies is a method function with options.