I noticed also that it can save some time (including in many cases an ispseudoprime check) if you look at
data:image/s3,"s3://crabby-images/f56dd/f56ddaec89c2d92d99851ab1661d28bf6cbcca08" alt="$m = p^2qr \pmod{576}$ $m = p^2qr \pmod{576}$"
at the very start, and continue testing only if
data:image/s3,"s3://crabby-images/425b7/425b73ab25088f45a7b52105cc54874f9ce907ed" alt="$m \in \{ 9, 10, 25, 26 \}$ $m \in \{ 9, 10, 25, 26 \}$"
. That is enough to verify that the
data:image/s3,"s3://crabby-images/50b30/50b30c2f74ff08fd40cbe9cf99367ddc69925b59" alt="$p$ $p$"
of
data:image/s3,"s3://crabby-images/6522b/6522b9555d484b37acb2d34937a8695f4f037d12" alt="$32p$ $32p$"
is not divisible by 2 or 3, and that
data:image/s3,"s3://crabby-images/fa6f2/fa6f232cd082951b1bd236f38ce9735a08395e3a" alt="$32p \equiv \pm 2 \pmod{18}$ $32p \equiv \pm 2 \pmod{18}$"
. (I'm fairly sure I have the right values for
data:image/s3,"s3://crabby-images/40798/407985b5c08107435bc729d920ee794acb5a2d98" alt="$m$ $m$"
, after stepping through a handful of cases.)
I question these 4 values of yours. At least 9 and 10. Let's do the math:
data:image/s3,"s3://crabby-images/f8c3c/f8c3c13a4697f29c60f4dd95d5760addd31dd85e" alt="$i=9\cdot16=144, h=\operatorname{round}(i/32)\cdot32=160$ $i=9\cdot16=144, h=\operatorname{round}(i/32)\cdot32=160$"
,
data:image/s3,"s3://crabby-images/29548/29548bfd140a6d3eab5f3524178dfcb1a5b2da37" alt="$x=(h+2)/18=9, x\bmod6=3$ $x=(h+2)/18=9, x\bmod6=3$"
- not 1 or 5!
data:image/s3,"s3://crabby-images/30227/302278edca6ab82d5155d0d73ca84be76c0fd98a" alt="$i=10\cdot16=160, h=\operatorname{round}(i/32)\cdot32=160$ $i=10\cdot16=160, h=\operatorname{round}(i/32)\cdot32=160$"
,
data:image/s3,"s3://crabby-images/29548/29548bfd140a6d3eab5f3524178dfcb1a5b2da37" alt="$x=(h+2)/18=9, x\bmod6=3$ $x=(h+2)/18=9, x\bmod6=3$"
- not 1 or 5!
data:image/s3,"s3://crabby-images/92a00/92a005d648954c5e70bb5b8122e78320dbbedc29" alt="$i=25\cdot16=400, h=\operatorname{round}(i/32)\cdot32=416$ $i=25\cdot16=400, h=\operatorname{round}(i/32)\cdot32=416$"
,
data:image/s3,"s3://crabby-images/90f13/90f139ede6dab9e4e8c29a67eb67ed5891d3d720" alt="$x=(h-2)/18=23, x\bmod6=5$ $x=(h-2)/18=23, x\bmod6=5$"
- ok.
data:image/s3,"s3://crabby-images/1055b/1055bedb938638af43e4544f2e356fa81658d7fe" alt="$i=26\cdot16=416, h=\operatorname{round}(i/32)\cdot32=416$ $i=26\cdot16=416, h=\operatorname{round}(i/32)\cdot32=416$"
,
data:image/s3,"s3://crabby-images/90f13/90f139ede6dab9e4e8c29a67eb67ed5891d3d720" alt="$x=(h-2)/18=23, x\bmod6=5$ $x=(h-2)/18=23, x\bmod6=5$"
- ok.
The case
data:image/s3,"s3://crabby-images/e3fd1/e3fd1b4abf81175d9be75625dc7c838fd9bf0169" alt="$x\bmod6=3$ $x\bmod6=3$"
is excluded because 3 is already in 18 and the remaining unknown prime cannot be a 3 (then it would increase the power of 3 here and the divisors would definitely not be 12) and cannot have a remainder 3 modulo 6 (there is only one prime, 3 itself, which is already excluded).
No decisions are missed, but the work is half as slow as possible.
But: we don't need
data:image/s3,"s3://crabby-images/ccdf9/ccdf9fbc3e70c17610f2075d56d5cdda3cdb54c8" alt="$p^2qr$ $p^2qr$"
if they get further than 7 from
data:image/s3,"s3://crabby-images/a01ff/a01ff72c57c705c1262f889668ea826da4e86ce7" alt="$32x$ $32x$"
, i.e. 400-408 is unnecessary, as is 424-431.
This leaves only 409-423 modulo 576 acceptable:
Код:
? for(i=0,576-1, n=round(i/32); h=32*n; x=round(h/18); if(abs(h-i)<8 && (n%6==1 || n%6==5) && (x%6==1 || x%6==5), print1(i,", ")))
409, 410, 411, 412, 413, 414, 415, 416, 417, 418, 419, 420, 421, 422, 423,
Of all these, can actually be found in
data:image/s3,"s3://crabby-images/ccdf9/ccdf9fbc3e70c17610f2075d56d5cdda3cdb54c8" alt="$p^2qr$ $p^2qr$"
only such::
Код:
? m=vector(576); forstep(p=1,#m,2, if(p%6==3, next); forstep(qr=1,#m,2, if(qr%6==3, next); x=(p^2*qr)%576; m[x+1]=x)); print(select(x->(x>408 && x<424), Set(m)))
[409, 413, 415, 419, 421]
-- 25.11.2022, 14:34 --The calculation time of the pattern with the same LCM will increase by 12 times. This is with a naive linear approximation. Rather, the growth will be
data:image/s3,"s3://crabby-images/438e7/438e75470bc0ab8c25c7a5a631e18c6d151e6a2c" alt="$12^2$ $12^2$"
or so.
Для них можно ровно так же взять и ограничить простые, хоть до тех же 5e8. Это будет сильно дольше, но ведь всего один раз посчитать. И тогда интервал квадратичных переборов будет идентичен. А вся разница будет только из-за линейных переборов, которые должны давать примерно линейное время, т.е. всё же примерно в 12 раз, не 144.