7 #include "cln/integer.h"
18 const cl_I square (const cl_I& x)
21 // x Fixnum -> direkt multiplizieren
22 // sonst: zu DS machen, multiplizieren.
24 { var sint32 x_ = FN_to_L(x);
25 // Werte direkt multiplizieren:
28 mulu32((uint32)x_,(uint32)x_,hi=,lo=); // erst unsigned multiplizieren
29 if (x_ < 0) { hi -= 2*(uint32)x_; } // dann Korrektur für Vorzeichen
30 return L2_to_I(hi,lo);
33 var const uintD* xMSDptr;
35 var const uintD* xLSDptr;
36 I_to_NDS_nocopy(x, xMSDptr = , xlen = , xLSDptr = , cl_false,);
38 var uintC erglen = 2*xlen;
40 num_stack_alloc(erglen,ergMSDptr=,ergLSDptr=);
42 var uintD MSD = mspref(xMSDptr,0);
44 { mspref(ergMSDptr,0) = 0; mspref(ergMSDptr,1) = 0; len--; }
45 cl_UDS_mul_square(xLSDptr,len,ergLSDptr);
47 { subfrom_loop_lsp(xLSDptr,ergLSDptr lspop xlen,xlen);
48 subfrom_loop_lsp(xLSDptr,ergLSDptr lspop xlen,xlen);
50 return DS_to_I(ergMSDptr,erglen);
52 // Bit complexity (x of length N): O(M(N)).