hermann on Thu, 27 Nov 2025 08:52:50 +0100


[Date Prev] [Date Next] [Thread Prev] [Thread Next] [Date Index] [Thread Index]

Re: gaussian integer modulus / Pollard's rho method on gaussian integers


On 2025-11-14 00:22, hermann@stamm-wilbrandt.de wrote:
...
from Robert Chapman and transpiled it to Pari/GP:
https://github.com/Hermann-SW/RSA_numbers_factored/blob/main/pari/RSA_numbers_factored.gp#L142-L220

Now I tried to use GP t_COMPLEX instead of a vector of two numbers for
gaussian integers. And the code tells so much more how and what is
done:

\\ signed k (mod n) in range -floor(n/2)..ceil(n/2)
smod(k,n)=my(m=k%n);if(2*m>n,m-n,m);

\\ componentwise signed mod of gaussian integer
gismod(a,n)=smod(real(a),n)+I*smod(imag(a),n);

\\ gaussian integer w (mod z)
gimod(w,z)={
  my(u=w*conj(z),n=norml2(z));
  w-z*((u-gismod(u,n))/n)
};
...

I looked at this again, and realized what is going on.
The code does the same [w/z = w*conj(z)/norml2(z)] as

qr = w/z
gi = round(real(qr)) + I*round(imag(qr)));
r = w - gi*z

but completely keeping everything a t_INT during computation
since (u-gismod(u,n)) is guaranteed to be a multiple of n.

I tried to use "\" for that reason, but GP errors with
"_\_: forbidden division t_COMPLEX \ t_INT."

I know there is no Gaussian Integer type in GP.
But could a meaningfully renamed "gimod()" function for "Gaussian integer mod" be made part of GP?

Regards,

Hermann.