Aritmetica modulare

Da testwiki.
Vai alla navigazione Vai alla ricerca
Copertina dell'edizione originale del trattato Disquisitiones arithmeticae di Carl Friedrich Gauss.

LTemplate:'aritmetica modulare (a volte detta aritmetica dell'orologio poiché su questo principio si basa il calcolo delle ore a cicli di 12 o 24) rappresenta un importante ramo della matematica. Trova applicazioni nella crittografia, nella teoria dei numeri (in particolare nella ricerca dei numeri primi) ed è alla base di molte delle più comuni operazioni aritmetiche e algebriche.

Si tratta di un sistema di aritmetica degli interi, in cui i numeri "si avvolgono su loro stessi" ogni volta che raggiungono i multipli di un determinato numero n, detto modulo. Per capire, si pensi al funzionamento di un orologio in formato da 12 ore: trascorse quest'ultime "si ricomincia" dal numero 1 a contare le ore. Dire "sono le 3 del pomeriggio" (formato 12 ore) equivale a dire "sono le 15" (formato 24 ore). Tradotto in termini matematici, significa che 153(mod12). Si legge, 15 è congruente a 3, modulo 12.

L'aritmetica modulare e la notazione usuale delle congruenze vennero formalmente introdotte da Carl Friedrich Gauss nel suo trattato Disquisitiones Arithmeticae, pubblicato nel 1801.

La relazione di congruenza

L'aritmetica modulare si basa sul concetto di congruenza modulo n.

Dati tre numeri interi a, b, n con n0, diciamo che a e b sono congruenti modulo n, oppure che a è congruo a b modulo n, se la differenza ab è un multiplo di n. In questo caso scriviamo

ab(modn).

In simboli la definizione di congruenza modulo n si può esprimere

ab(modn) k| ab=kn

Per esempio, possiamo scrivere

3814(mod12)

poiché 3814=24, che è un multiplo di 12.

Nel caso entrambi i numeri siano positivi, si può anche dire che a e b sono congruenti modulo n se hanno lo stesso resto nella divisione per n. Quindi possiamo anche dire che 38 è congruo a 14 modulo 12 poiché sia 38 sia 14 hanno resto 2 nella divisione per 12.

Proprietà delle congruenze

Relazione di equivalenza

La congruenza è una relazione di equivalenza tra numeri interi, come si evince dalle seguenti proprietà:

aa(modn),a, n0.
Dimostrazione: si ha aa=0 e, come è noto, ogni intero non nullo è divisore di 0. Quindi n divide aa.
ab(modn)ba(modn),a,b,n0.
Dimostrazione: se n divide ab , allora n divide anche l'opposto ba=(ab).
  • Proprietà transitiva: se a è congruo a b modulo n e b è congruo a c modulo n, allora anche a è congruo a c modulo n:
ab(modn)bc(modn)ac(modn),a,b,c,n0.
Dimostrazione: se n divide ab e n divide bc, allora, per la proprietà distributiva della divisione rispetto alla somma, n divide anche (ab)+(bc)=ab+bc=ac.

Invarianza rispetto alle operazioni aritmetiche

Un'altra importante caratteristica della relazione di congruenza è il fatto di essere preservata dalle usuali operazioni aritmetiche tra interi:

  • Invarianza per addizione: aumentando o diminuendo della stessa quantità due numeri congruenti modulo n, i nuovi numeri ottenuti sono ancora congruenti tra loro modulo n. Più sinteticamente
ab(modn)(a+c)(b+c)(modn),a,b,c,n0.
Dimostrazione: ab=ab+cc=(a+c)(b+c).
  • Invarianza per moltiplicazione: moltiplicando per una stessa quantità due numeri congruenti modulo n, i nuovi numeri ottenuti sono ancora congruenti tra loro modulo n.
ab(modn)acbc(modn),a,b,c,n0.
Dimostrazione: se n divide ab, allora n divide (ab)×c.
Nota: Si può invertire questa proprietà solo se MCD(n,c)=1.
  • Invarianza rispetto all'elevamento a potenza: elevando due numeri congrui modulo n alla stessa potenza k, i numeri ottenuti sono ancora congrui tra loro modulo n.
ab(modn)akbk(modn),a,b,k,n0.
Dimostrazione: se ab0(modn), la proposizione è banale. Se ab(modn), non è nullo, si supponga che ak1bk1(modn). Moltiplicando entrambi i termini per a grazie all'invarianza per moltiplicazione, avremo akbk1a(modn). Partendo dalla congruenza ab(modn) e moltiplicando entrambi i membri per bk1(modn), sempre grazie all'invarianza per moltiplicazione, si ottiene: abk1bk(modn). Confrontando le due espressioni e utilizzando le proprietà simmetrica e transitiva si deduce che akbk(modn). Poiché la proposizione è vera per k=1 e l'essere vera per k1 implica che essa sia vera per k, per il principio di induzione la proposizione è vera per ogni k.

Le classi di resto modulo n

Le proprietà riflessiva, simmetrica e transitiva descritte sopra indicano che la relazione di congruenza modulo n è una relazione di equivalenza e definisce quindi un insieme quoziente.

La divisione euclidea di un intero a per n, con n0, per cui

a=k×n+r

ovvero

ar=k×n

consente di suddividere l'insieme degli interi in n classi (sottoinsiemi) secondo la seguente relazione di equivalenza: si dice che un intero a è equivalente a r(modn) se e solo se la differenza ar è un multiplo relativo di n. Si definisce così l'insieme quoziente di rispetto a tale relazione di equivalenza e formato dalle n classi

[0],[1],,[n2],[n1]

chiamate classi di resto modulo n.

Ciascuna classe di resto [r] rappresenta, oltre a r stesso, tutti i numeri interi della forma a=k×n+r per qualche intero k.

Ad esempio, nella congruenza modulo 7, la classe di resto [5] rappresenta, oltre al numero 5, anche il numero 12 (=1×7 + 5), il numero 19 (=2×7 + 5), il numero 2308 (=329×7 + 5) ecc. Inoltre [5] rappresenta anche il numero -2 (= -1×7 + 5), il numero -9 (= -2×7 + 5) e così via.

L'aritmetica delle congruenze modulo n

Le invarianze descritte sopra rispetto a somma e moltiplicazione indicano che queste operazioni sono ben definite anche al quoziente. Queste operazioni continuano a soddisfare le proprietà commutativa, associativa e distributiva. Gli elementi neutri per l'addizione e la moltiplicazione sono le classi [0] e [1].

Le classi modulo n con la somma formano un gruppo abeliano: più precisamente, formano un gruppo ciclico finito. Con somma e prodotto formano un anello. Diversamente da quanto accade per i numeri interi, il prodotto di due elementi non nulli può essere nullo. Ad esempio:

[2][3]=[6]=[0] se n=6.

Questo non succede però quando n è un numero primo: infatti in questo caso le classi formano un dominio d'integrità e anche un campo.

Tra le proprietà delle operazioni troviamo le seguenti:

  • [a]+[b]=[a+b];
  • [ab]=[a][b].

Radici primitive

Template:Vedi anche A causa dell'eventuale presenza dei divisori dello 0, generalmente n{0} non è un gruppo con il prodotto. Infatti i divisori dello 0 non hanno inversi. Invece quando non esistono divisori dello 0 non nulli, cioè nei casi con n primo, la moltiplicazione forma un gruppo moltiplicativo e l'anello n è un campo. Tuttavia se ci si restringe alle classi i cui rappresentati sono coprimi con n, questa proprietà riappare. È facile dimostrarlo facendo ricorso all'identità di Bézout: se a è coprimo con n, esistono due interi x e y tali che

ax+ny=1

ossia, riducendo modulo n,

ax1modn

e quindi ogni a ha un inverso. Inoltre la moltiplicazione continua a essere interna all'anello e a possedere le proprietà associativa e commutativa, e la classe [1] è l'elemento neutro.

Un risultato importante, trovato già da Gauss, è che questo gruppo è ciclico se e solo se n è 2, 4, la potenza di un numero primo dispari oppure il doppio della potenza di un numero primo dispari. I generatori di questo gruppo ciclico sono a volte detti radici primitive modulo n.

Polinomi in aritmetica modulare

Template:Vedi anche Anche in n è possibile, attraverso le operazioni definite prima, parlare di polinomi. Le proprietà di questi differiscono in molti casi dalle proprietà "abituali" osservate quando si considerano polinomi su campi come o , oppure su anelli come . Ad esempio, il principio di identità dei polinomi (due polinomi assumono valori uguali se e solo se i loro coefficienti sono ad uno ad uno uguali) non vale, sebbene valga una sua versione modificata.

Anche nello studio di questo soggetto, così come nella maggior parte dell'aritmetica modulare, si distinguono due tipi molto diversi di comportamento di n: quando n è primo e quando n è composto. In quest'ultimo caso, non essendo n né un campo né un dominio d'integrità, il comportamento dei polinomi può essere molto "strano": ad esempio, la congruenza polinomiale di 2º grado x210mod8 ha quattro soluzioni (1, 3, 5 e 7) quando in campi infiniti come i razionali, i reali o i complessi il numero delle soluzioni non può superare il grado del polinomio.

Irriducibilità

Gli anelli p forniscono anche un modo per studiare l'irriducibilità dei polinomi a coefficienti interi e quindi, per il lemma di Gauss, anche di quelli a coefficienti razionali. Infatti se un polinomio è riducibile nell'anello [x] dei polinomi a coefficienti interi come f(x)=g(x)h(x), allora lo stesso vale modulo un qualsiasi primo p:

[f(x)]p[g(x)]p[h(x)]pmodp.

Questa proprietà può essere sfruttata per costruire un criterio di irriducibilità: se un polinomio non si fattorizza in p[x], con p primo che non divide il coefficiente del termine di grado massimo, allora non si fattorizza, ossia è irriducibile, nell'anello [x].

Il viceversa non è vero: f(x)=x2+1 è irriducibile in [x], ma in 5[x] si fattorizza come

x2+1(x+2)(x+3)mod5.

Equazioni diofantee

Allo stesso modo dello studio dell'irriducibilità dei polinomi, nello studio delle equazioni diofantee si studia a volte la stessa equazione modulo un intero n per fornire condizioni necessarie alla risolubilità dell'equazione stessa. Ad esempio l'equazione

x3+7y3=2

non può avere soluzioni intere, perché se esistesse una soluzione (x0,y0) questa sarebbe tale anche nell'anello delle congruenze modulo 7; cioè dovrebbe essere risolubile la congruenza

x3+7y32mod7
x32mod7

che non ha soluzioni, perché i possibili valori che assume x3mod7 sono 0, 1 e 6.

Notazione

L'insieme di tutte le classi di congruenza di modulo m è chiamato anello degli interi di modulo m e può essere indicato con le notazioni /m, /m oppure m.[1] Tuttavia, la notazione m è solitamente sconsigiata perché può essere confusa con quella che indica un numero p-adico e appartenente al sistema numerico corrispondente.

Note

Bibliografia

Voci correlate

Altri progetti

Template:Interprogetto

Collegamenti esterni

Template:Algebra Template:Teoria dei numeri

Template:Portale