Funzione unidirezionale

Da testwiki.
Versione del 13 mar 2025 alle 11:03 di imported>FrescoBot (Bot: numeri di pagina nei template citazione)
(diff) ← Versione meno recente | Versione attuale (diff) | Versione più recente → (diff)
Vai alla navigazione Vai alla ricerca

Una funzione unidirezionale (funzione one-way in inglese o semplicemente OWF) è una funzione matematica "facile da calcolare" ma "difficile da invertire"[1][2].

"Facile da calcolare" significa che esistono algoritmi che possono calcolare la funzione f(x) in tempo polinomiale (nella dimensione dell'input). "Difficile da invertire" significa che nessun algoritmo probabilisticamente polinomiale (classe di complessità temporale PP) può calcolare una controimmagine di f(x) a meno di una probabilità trascurabile, quando x viene scelta in modo casuale.

Si noti che, a differenza del concetto di difficoltà più comunemente diffuso nella teoria della complessità computazionale, "difficile", nel contesto delle funzioni unidirezionali, si riferisce alla difficoltà nel caso medio e non a quella nel caso peggiore.

Definizione formale

Una funzione f:{0,1}*{0,1}*è unidirezionale se esiste un algoritmo che in tempo polinomiale mappa x in f(x) per ogni x{0,1}* e per ogni algoritmo casuale PPT A, ogni polinomio p() e per valori di n sufficientemente grandi si ha che:

Pr[f(A(f(x)))=f(x)]<1p(n),

dove la probabilità è sulla scelta delle x da una distribuzione discreta uniforme su {0,1}n e sulla casualità di A.

Funzione unidirezionale debole

Una funzione unidirezionale debole, invece, è tale per cui ogni algoritmo casuale PPT A che prova a calcolare una qualsiasi preimmagine di f(x) fallisce con probabilità non trascurabile. In modo formale, si dice che f è una funzione debolmente unidirezionale se è calcolabile in tempo polinomiale ed esiste un polinomio p tale che per ogni algoritmo casuale A e per valori di n sufficientemente grandi:

Pr[f(A(f(x)))f(x)]11p(n),

dove la probabilità è sulla scelta delle x da una distribuzione discreta uniforme su {0,1}n e sulla casualità di A

Permutazione unidirezionale

Una funzione f è una permutazione unidirezionale se:

  • è una funzione unidirezionale
  • è biettiva

Congettura OWF

Le funzioni unidirezionali sono una delle primitive più rudimentali della moderna crittografia e la loro esistenza è necessaria per la stragrande maggioranza degli oggetti crittografici di interesse. L'esistenza delle funzioni unidirezionali, infatti, è equivalente all'esistenza dei generatori pseudocasuali[3], delle funzioni pseudocasuali[4], delle firme digitali[5], delle prove a conoscenza zero per ogni linguaggio NP[6] e di molti altri oggetti.

L'esistenza delle funzioni unidirezionali, inoltre, implica che P ≠ NP[7].

Candidati

Esistono numerosi candidati per le funzioni unidirezionali. Alcuni di essi sono[8][9]:

Note

Bibliografia

Voci correlate

Collegamenti esterni

Template:Portale