Matrice di WalshIn matematica, una matrice di Walsh è una matrice quadrata, avente come numero delle righe e delle colonne una potenza di , con i valori possibili degli elementi della matrice limitati a e , tale che il prodotto scalare fra due righe distinte (o fra due colonne distinte) sia zero. La matrice di Walsh può essere ottenuta a partire da una matrice di Hadamard ordinata naturalmente mediante la formula ricorsiva sotto riportata. Nella matrice di Hadamard ordinata sequenzialmente si risistemano le righe in modo che il numero dei cambiamenti di segno sia in ordine crescente. Ogni riga di una matrice di Walsh è associata a una funzione di Walsh. La matrice di Walsh e la funzione di Walsh sono usate per calcolare la trasformata di Walsh e hanno applicazioni nelle implementazioni efficienti di alcune operazioni che servono al processo dei segnali. FormuleOrdinata naturalmenteLe matrici di Hadamard di dimensione per sono ottenute mediante la seguente formula ricorsiva e in generale per , dove denota il prodotto di Kronecker fra matrici. Ordinata sequenzialmenteL'ordinamento delle righe della matrice di Walsh può essere ottenuto a partire dall'ordinamento della matrice di Hadamard applicando in primo luogo la permutazione a bit invertito e poi la permutazione del codice di Gray. Utilizzo nella tecnologia CDMATeorizzazioneNella tecnologia CDMA (Code Division Multiple Access) che sta alla base di tecnologie più conosciute come l'UMTS si fa uso delle matrici di Walsh a causa delle loro particolari proprietà. L'obiettivo è quello di identificare in modo univoco quando un terminale sta iniziando una comunicazione, per far ciò le opzioni sono due:
La seconda idea, per quanto controintuitiva, è quella su cui si basano il CDMA e derivati. L'unico accorgimento necessario per far funzionare il tutto, è quello di prendere dei codici ortogonali tra di loro. In questo modo, immaginando le comunicazioni come uno spazio multidimensionale dove ogni codice ha il suo asse, facendo il prodotto scalare su tutti gli assi disponibili, se il punto trovato sull'asse corrisponde all'origine, non c'è stata comunicazione, viceversa c'è stata comunicazione e il prodotto scalare del punto indica esattamente quale parola è stata utilizzata. Semplifichiamo l'idea con un esempio tridimensionale dove ci sono le comunicazioni col codice "x", quello "y" e quello "z".
Se invece di 3 dispositivi ne abbiamo "n", basta aumentare il numero degli assi passando da uno spazio tri-dimensionale ad uno spazio "n-dimensionale". Spostandoci quindi da questa rappresentazione "spaziale" dell'idea proposta all'effettivo utilizzo pratico, si è pensato di utilizzare le matrici di Walsh. Era infatti necessario creare dei linguaggi ortogonali tra di loro in modo tale che tutte le loro parole di un codice si situino sul suo asse ma non in quello degli altri codici, per non interferire con la comunicazione di un altro dispositivo. Le matrici di Walsh hanno proprio la proprietà fondamentale che ogni riga della matrice rappresenta un linguaggio che è ortogonale rispetto ai linguaggi di tutte le altre righe e che il suo inverso (ovvero, scambiando gli uni con zeri e viceversa, quindi passando da 1 1 0 0 a 0 0 1 1 per esempio) fa ancora parte del linguaggio. Nelle matrici di Walsh si utilizza la cifra -1 invece che lo 0 per contraddistinguere il messaggio inverso all'uno. Esso torna utile per motivi computazionali, ma da un punto di vista del calcolatore essi rappresentano la medesima informazione (ovvero, il messaggio opposto a 1). Un altro vantaggio molto utile delle matrici di Walsh è che sono particolarmente facili da "aumentare" se i nostri dispositivi aumentano come potenze di due. Nel paragrafo precedente si è infatti visto come la matrice H1 abbia al suo interno solo un 1, mentre la matrice H2 siano tutti 1, tranne l'ultimo che è -1. Induttivamente, basta infatti prendere la matrice di ordine immediatamente inferiore, metterla nei primi 2 campi e nel terzo così com'è e invertirla nel quarto. Sempre nel paragrafo precedente si vede quindi la "ovvia" generazione della matrice H4 che è generata da 3 matrici H2 "normali" più la quarta invertita (ed è presente la formula per generare matrici di Walsh grandi a piacere). Il problema principale che c'è nell'utilizzare questo tipo di matrici è che crescono come potenze di due. Se invece noi abbiamo solo 9 dispositivi (quindi non una potenza di due) la questione si complica. Infatti, con questo sistema l'unico modo è utilizzare 16 codici, assegnarne 9 e lasciare che gli altri 7 codici rimangano inutilizzati (il che corrisponde ad avere 7 dispositivi che di fatto non comunicano). Per quanto questo sistemi funzioni, non è economico da un punto di vista computazionale visto che spesso i dispositivi coinvolti non sono poche manciate, ma sono parecchi e per esempio la differenza tra 256 e 512 non è poca. Gli studi riguardo a questo tipi di matrici hanno portato ai seguenti risultati:
Utilizzo praticoLa domanda a questo punto è: come si utilizzano questo tipo di matrici nel protocollo CDMA? Innanzi tutto ricordiamo che ogni riga ha la proprietà fondamentale che la sua inversa è ancora una parola del linguaggio. Pertanto, per ogni codice abbiamo a disposizione 3 opzioni: trasmettere il codice dato dalla matrice di riferimento, trasmettere il suo inverso o non trasmettere. Spieghiamo l'utilizzo pratico tramite un esempio applicativo, anche questa volta utilizzando pochi dispositivi. Questa volta per semplicità ne useremo 4, utilizzeremo quindi la matrice vista in precedenza, ovvero la seguente: Saranno quindi disponibili 4 codici:
Supponiamo quindi per esempio:
Si sommano quindi le parole trasmesse (quindi solo quelle del primo, del secondo e del quarto dispositivo visto che il terzo non ha trasmesso) semplicemente mettendole una sopra l'altra e sommando per colonna, quindi: 1 1 1 1 + + + + -1 1 -1 1 + + + + 1 -1 -1 1 ↓ ↓ ↓ ↓ 1 1 -1 3 Pertanto il risultato, ovvero quello che verrà trasmesso, è: 1, 1, -1, 3. A prima vista sembra impossibile risalire da questo numero al messaggio trasmesso. Invece dato che il provider sa quanti dispositivi sono connessi alla rete e che codice stanno utilizzando per comunicare, basta soltanto che la centralina controlli se i dispositivi che sta gestendo hanno trasmesso qualcosa o meno ogni volta che gli arriva un segnale.
1 1 -1 3 * * * * 1 1 1 1 ↓ ↓ ↓ ↓ 1 1 -1 3
Se invece il valore trovato fosse stato negativo, la parola trasmessa sarebbe stata l'inversa, quindi (-1,-1,-1,-1). Se il valore fosse stato 0, allora il dispositivo non avrebbe trasmesso. Verifichiamo che è veramente così: proviamo a vedere se riusciamo a desumere cos'hanno trasmesso anche altri due dispositivi, il secondo (che ha trasmesso la parola inversa) e il terzo che non ha trasmesso nulla.
Questo sistema funziona molto bene visto che non richiede calcoli complessi e visto che la moltiplicazione e l'addizione sono le operazioni base di qualsiasi calcolatore quindi sono quelle implementate nel modo più veloce possibile. Questo sistema è molto superiore ai precedenti per due motivi fondamentali:
L'unico accorgimento che bisogna seguire per far funzionare il sistema correttamente, è quello di calibrare la potenza del segnale del dispositivo in base alla distanza dalla centrale. Se la distanza è alta la potenza sarà maggiore e viceversa. In questo modo la centrale riceve i segnali tutti con la stessa potenza e i segnali si sommano correttamente nel modo visto precedentemente, altrimenti i segnali più vicini avrebbero avuto un'influenza maggiore rispetto agli altri nel risultato finale. La centrale quindi, col suo segnale di potenza fissa di riferimento, è l'unica stazione che può decifrare i messaggi visto che il segnale dei dispositivi è calibrato in base alla distanza da lei e da nessun altro. Bibliografia
Voci correlateAltri progetti
|