Ask Your Question

Revision history [back]

click to hide/show revision 1
initial version

What is the computational cost of the Cornacchia's algorithm?

If we need to factor a number N

Given the Pythagorean quadruple (with n and m in Z)

d=36m^2+18m+4n^2+2n+3

a=24mn+6m+6n+1

b=2(3m+n+1)(6m-2*n+1)

c=2(3m+n+1)

a^2+b^2+c^2=d^2

then if:

1) N=d^2-c^2=a^2+b^2

2) N=d^2-b^2=a^2+c^2

3) N=d^2-a^2=b^2+c^2 (case N is even)

The factorization of N can be obtained using the Cornacchia's Algorithm.

What is the computational cost of the Cornacchia's algorithm?

def cornacchia(p, d):
    # Verifica se -d รจ un quadrato modulo p
    if not is_square(Mod(-d, p)):
        return None

    # Trova una radice quadrata di -d mod p
    r = sqrt(Mod(-d, p))

    # Algoritmo di Euclide esteso
    a, b = p, int(r)
    while b*b > p:
        a, b = b, a % b

    # Verifica se esiste soluzione
    x = b
    y2 = (p - x^2) // d
    if y2 >= 0 and is_square(y2):
        y = sqrt(y2)
        return (x, int(y))
    else:
        return None

# Esegui per p = 65, d = 1
cornacchia(725, 1)

(23, 14)

d=36m^2+18m+4n^2+2n+3 , a=24mn+6m+6n+1=-23 , b=2(3m+n+1)(6m-2n+1)=14 , c=2(3*m+n+1)

->

d-c=a=29

d+c=b=25

ab=2925=725