Hi Martin, Thank you so much for your kind help. It works! Kind regards, Santanu
On Mon, 22 Mar 2021 at 19:49, 'Martin R. Albrecht' via sage-support < sage-support@googlegroups.com> wrote: > Hi Santanu, > > With very high precision it goes through: > > #+begin_src jupyter-python :kernel sagemath > A = random_matrix(ZZ, 10, 10, x=-2^500, y=2^500) > A.echelonize() # make it interesting by turning into HNF > > from fpylll import FPLLL, IntegerMatrix, GSO, LLL > B = IntegerMatrix.from_matrix(A) > FPLLL.set_precision(20000) # 20000 bits of precision! > M = GSO.Mat(B, float_type="mpfr") > M.update_gso() > L = LLL.Reduction(M) > L.size_reduction() > C = B.to_matrix(matrix(ZZ, 10, 10)) # back to Sage's format > #+end_src > > HNF is pretty bad for precision, so it’s an extreme example. > > Cheers, > Martin > > > Santanu Sarkar <sarkar.santanu....@gmail.com> writes: > > Hi Martin, > > Thanks a lot. For entries upto 500 bits, it works fine. > > But for large entries, I am getting error. > > A = random_matrix(ZZ, 10, 10, x=-2^550, y=2^550) > > File "abc.sage.py", line 28, in <module> > > L.size_reduction() > > File "src/fpylll/fplll/lll.pyx", line 379, in > > fpylll.fplll.lll.LLLReduction.size_reduction > > fpylll.util.ReductionError: b'success' > > > > Kind regards, > > Santanu > > > > > > On Wed, 17 Mar 2021 at 15:47, 'Martin R. Albrecht' via sage-support < > > sage-support@googlegroups.com> wrote: > > > >> Hi there, > >> > >> You can do it by calling down to FPyLLL which (together with NTL) powers > >> lattice reduction in Sage. Here’s an example: > >> > >> #+begin_src jupyter-python :kernel sagemath > >> A = random_matrix(ZZ, 10, 10, x=-1, y=2) > >> A.echelonize() # make it interesting by turning into HNF > >> print("# Input") > >> print(A) > >> print() > >> > >> from fpylll import IntegerMatrix, GSO, LLL > >> B = IntegerMatrix.from_matrix(A) > >> M = GSO.Mat(B) > >> M.update_gso() > >> L = LLL.Reduction(M) > >> L.size_reduction() > >> C = B.to_matrix(matrix(ZZ, 10, 10)) # back to Sage's format > >> > >> print("# Output") > >> print(C) > >> print() > >> #+end_src > >> > >> #+RESULTS: > >> #+begin_example > >> # Input > >> [ 1 0 0 0 0 0 0 0 0 41] > >> [ 0 1 0 0 0 0 0 0 0 34] > >> [ 0 0 1 0 0 0 0 0 1 27] > >> [ 0 0 0 1 0 0 0 0 1 96] > >> [ 0 0 0 0 1 0 0 0 0 38] > >> [ 0 0 0 0 0 1 0 0 1 78] > >> [ 0 0 0 0 0 0 1 0 1 1] > >> [ 0 0 0 0 0 0 0 1 1 91] > >> [ 0 0 0 0 0 0 0 0 2 69] > >> [ 0 0 0 0 0 0 0 0 0 100] > >> > >> # Output > >> [ 1 0 0 0 0 0 0 0 0 41] > >> [ -1 1 0 0 0 0 0 0 0 -7] > >> [ -1 0 1 0 0 0 0 0 1 -14] > >> [ -1 -1 -1 1 0 0 0 0 0 -6] > >> [ -1 0 0 0 1 0 0 0 0 -3] > >> [ 0 0 0 -1 0 1 0 0 0 -18] > >> [ 0 0 0 0 0 0 1 0 1 1] > >> [ 0 0 0 -1 0 0 0 1 0 -5] > >> [ 1 0 0 -1 0 0 0 0 1 14] > >> [ 0 0 0 -1 0 0 0 0 -1 4] > >> #+end_example > >> > >> > >> Cheers, > >> Martin > >> > >> Santanu Sarkar <sarkar.santanu....@gmail.com> writes: > >> > Dear all, > >> > In Sagemath, is it possible to change a basis > >> > of a lattice which is size reduced? That is my interest is only on > >> > 1st condition of LLL basis. > >> > > >> > > >> > Kind regards, > >> > Santanu > >> > >> > >> -- > >> > >> _pgp: https://keybase.io/martinralbrecht > >> _www: https://malb.io > >> > >> -- > >> You received this message because you are subscribed to the Google > Groups > >> "sage-support" group. > >> To unsubscribe from this group and stop receiving emails from it, send > an > >> email to sage-support+unsubscr...@googlegroups.com. > >> To view this discussion on the web visit > >> > https://groups.google.com/d/msgid/sage-support/871rcet773.fsf%40googlemail.com > >> . > >> > > > -- > > _pgp: https://keybase.io/martinralbrecht > _www: https://malb.io > > -- > You received this message because you are subscribed to the Google Groups > "sage-support" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to sage-support+unsubscr...@googlegroups.com. > To view this discussion on the web visit > https://groups.google.com/d/msgid/sage-support/87mtuwzrbw.fsf%40googlemail.com > . > -- You received this message because you are subscribed to the Google Groups "sage-support" group. To unsubscribe from this group and stop receiving emails from it, send an email to sage-support+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/sage-support/CAOe8sPLNzAmFsTLRvK-GEkFcbkutV0%2BkB%3DoZYHda8i6MzZBpJA%40mail.gmail.com.