390 likes | 529 Views
Classificazione e segmentazione di testi: modelli generativi e condizionali a confronto. Sommario. Makov Model Hidden Markov Model Evaluation Problem Decoding Problem Learning Problem Classificazione e Segmentazione di testi con HMM DATAMOLD Limiti dei Modelli Generativi
E N D
Classificazione e segmentazione di testi: modelli generativi e condizionali a confronto
Sommario • Makov Model • Hidden Markov Model • Evaluation Problem • Decoding Problem • Learning Problem • Classificazione e Segmentazione di testi con HMM • DATAMOLD • Limiti dei Modelli Generativi • Modelli Condizionali • Conditional Random Field • MALLET
Markov Model • Qualsiasi ambito in cui occorre una sequenza di eventi può produrre pattern interessanti … • Come modellare il processo che potrebbe averli generati? • Un processo di Markov è un processo che si sposta da uno stato all’altro in base ai precedenti n stati. • Non equivale ad un processo deterministico, dato che la scelta è fatta in modo probabilistico.
First Order Markov Model Matrice delle transizioni Vettore delle probabilità iniziali Quando non basta un processo di Markov? E’ necessario estendere il modello per rappresentare processi in cui le osservazioni sono probabilisticamente legate ad un sottostante processo di Markov.
b b b b 21 22 23 24 b b b b 31 32 33 34 Hidden Markov Model
Definizione di HMM (1) • N, stati del modello. • M, numero di simboli distinti osservati. Corrispondono all’output fisico del sistema. • L’insieme delle probabilità di transizione (distribuzione).
Definizione di HMM (2) • L’insieme delle probabilità di emissione dei simboli, cioè distribuzione di probabilità in ogni stato. • la distribuzione iniziale di stato.
HMM: esempio Gli stati nascosti sono modellati come un processo di Markov del primo ordine. Gli archi tra gli stati nascosti e quelli osservabili rappresentano la probabilità di generare (ed osservare) un particolare stato visibile essendo in un certo stato nascosto.
Assunzioni… • Assunzione di Markov La scelta dello stato successivo dipende solo dallo stato corrente. • Assunzione di stazionarietà Le probabilità di transizione sono indipendenti dal tempo in cui avviene la transizione. • Assunzione di independenza dell’output L’osservazione corrente è statisticamente indipendente dalle precedenti
= Pr( osservazione | stato nascosto è j ) x Pr(tutti I cammini verso j al tempo t) Evaluation Problem • Dato un HMM completamente definito, con probabilità di transizione ed emissione note, si vuole determinare la probabilità che una certa sequenza di stati sia generata dal modello. • Algoritmo Forward Le probabilità parziali per l’osservazione finale tengono conto della probabilità di raggiungere questi stati tramite tutti i possibili path. La somma di queste probabilità parziali è la somma di tutti i possibili paths attraverso il reticolo, quindi è la probabilità di osservare la sequenza dato il modello.
Algoritmo Forward • INIZIALIZZAZIONE (t=1) • INDUZIONE (si assume ricorsivamente di conoscere il primo termine del prodotto) • TERMINAZIONE (la somma di tutte le probabilità parziali dà la probabilità delle osservazioni, dato il modello)
Il calcolo coinvolge principalmente i termini: Complessità Ad ogni t ci sono solo N stati da considerare, quindi ogni calcolo coinvolge solo N valori precedenti, indipendentemente dalla lunghezza della sequenza.
È la massima probabilità di tutte le sequenze che terminano nello stato i al tempo t, ed il migliore percorso parziale è la sequenza a cui corrisponde questa probabilità. Decoding Problem • Dato un HMM e un set di osservazioni, si vuole determinare la più probabile sequenza di stati nascosti per le osservazioni, cioè che potrebbe aver generato quelle osservazioni. • Applicazioni: segmentation, NLP task. • Algoritmo di Viterbi • Si definisce la probabilità parziale, cioè la probabilità di raggiungere un particolare stato intermedio nel reticolo. Rappresenta la probabilità del piùprobabilepath verso uno stato al tempo t. Ognuno di questi path migliori parziali ha associato una probabilità, che è la probabilità del più probabile path verso quello stato.
Algoritmo Viterbi (1) • INIZIALIZZAZIONE (t=1) • INDUZIONE Si tratta di cercare il path che termina in AX, BX o CX che ha la massima probabilità (sotto l’assunzione di Markov).
Algoritmo Viterbi (2) • In che stato dev’essersi trovato il sistema al tempo t-1 se è arrivato ottimamente nello stato i al tempo t? • TERMINAZIONE (qual è lo stato più probabile al tempo t=T) • BACKTRAKING
Considerazioni • Ipotesi di invarianza temporale delle probabilità→ riduzione della complessità del problema (evitando la necessità di esaminare tutti i possibili percorsi nel reticolo). • La Σ presente nell’algoritmo forward è rimpiazzata dall’operatore di max perché si cerca il più probabile cammino per la posizione corrente, non la probabilità totale. • L’algoritmo di Viterbi “guarda” l’intera sequenza prima di decidere il più probabile stato finale (backtraking). • Gode della proprietà di fornire la migliore interpretazione rispetto all’intero contesto delle ossservazioni.
LEARNING PROBLEM • Conoscendo solo il “guscio” di un HMM ( il numero di stati visibili e nascosti, ma non le probabilità di transizione ed emissione), e date delle osservazioni di training, si vogliono determinare i parametri del modello. • Generare un HMM da una sequenza di osservazioni (training set). • La quantità da massimizzare durante il processo di learning, dipende dal tipo di applicazione. Ci sono diversi criteri di ottimizzazione per il learning, ad esempio Maximum Likelihood (ML).
LEARNING PROBLEM • Inizialmente, l’algoritmo indovina i valori dei parametri, e man mano li ridefinisce cercando di ridurre gli errori. • Il nome deriva dal fatto che, per ogni stato in un reticolo di esecuzione, calcola la probabilità `forward' di arrivare a questo stato (data la corrente approssimazione del modello) e la probabilità `backward' di generare lo stato finale del modello, rispetto alla approssimazione corrente.
LEARNING PROBLEM Iterativamente, si usa la stima per migliorare la probabilità di osservare la sequenza rispetto al nuovo modello calcolato. Il risultato finale è la stima di massima verosimiglianza del HMM.
S={S1 ,S2,..} X={X1 ,X2,..} Labelling con HMM • HMM si possono usare per classificazione e segmentazione di testi: (identificare la più probabile sequenza di label per le parole in una frase,..). • Scegiere la sequenza che massimizza la probabilità condizionata di una sequenza di label data la sequenza di osservazioni p(y|x). • Poiché definiscono una distribuzione di probabilità congiunta sugli stati e le osservazioni, la più appropriata sequenza di label per ogni sequenza di osservazioni è ottenuta trovando gli stati che massimizzano p(s|x). dovremmo enumerare tutte le possibili sequenze di osservazioni a meno di non fare ipotesi molto forti di indipendenza sulle osservazioni!!
Segmentazione di testi: DATAMOLD • HMM :per la segmentazione automatica di testo in record strutturati (indirizzi postali, records bibliografici, elenco telefonico..). • Sistemi rule-based: problema della estrazione di field a causa della grande varianza nella struttura dei record. • DATAMOLDO: tool che usa la tecnica statistica degli HMM.
DATAMOLD (2) Training: • Scegliere la struttura del HMM (nodi, dizionario,..) • Struttura naive: uno stato per ogni elemento. Ignora le relazioni sequenziali nello stesso elemento!! • Struttura innestata: esterna + interna. • Apprendere le probabilità • Approccio ML Testing: data una sequenza, associare ad ogni simbolo un elemento. • Algoritmo di Viterbi (modificato) :per incorporare informazioni di dipendenza, rispetto al data base di relazioni semantiche.
Considerazioni • HMM e modelli generativi non sono i più appropriati per labelling. • Definendo una distribuzione di probabilità congiunta su osservazioni e labels dovrebbero enumerare tutte le possibili sequenze a meno di ipotesi di indipendenza sulle osservazioni. • ESIGENZE: inferenza trattabile & non ipotesi restrittive di indipendenza. • SOLUZIONE • Nell’identificare la migliore sequenza di stati per una data sequenza di osservazioni possiamo usare direttamente la probabilità condizionata. modelli condizionali, che definiscono una probabilità condizionata della sequenza di label data una sequenza di osservazioni (o equivalente mente degli stati date le osservazioni).
Maximum Entropy Markov Model(1) • Definiscono un unico insieme di cardinalità |S| di distribuzioni: • E’ una funzione specifica per un dato stato, quindi la scelta di St+1 dipende da St. • La sequenza di osservazioni è condizionata piuttosto che generata. Trattare le osservazioni come eventi condizionati significa che le probabilità di ogni transizione possono dipendere da feature non indipendenti e interagenti della sequenza di osservazioni.
Maximum Entropy Markov Model(2) • Il modello della funzione di transizione/osservazione è log-lineare: • Le feature functions fanno uso di binary features che esprimono caratteristiche delle osservazioni dei dati di training.
Lebel bias problem • MEMM usano un insieme di distribuzioni di probabilità definite per ogni stato, apprese separatamente. Ogni distribuzione definisce la probabilità condizionata del prossimo stato dato quello corrente ed il successivo elemento osservato. Necessità di un fattore di normalizzazione per ogni stato. Le osservazioni influenzano la scelta del prossimo stato ma non la probabilità con cui verrà scelto. • Per le transizioni con un solo arco uscente, l’osservazione potrebbe del tutto essere ignorata.
questo 4 2 [a] è [a] [c] 0 1 Il problema [b] è quello 3 5 [a] [d] Label Bias Problem: esempio • “Il problema è questo” P(4|2,questo)=P(5|3,quello)=1 • N.B: HMM non soffrono di questo problema.
Conditional Random Field • Sono un modello condizionale che consente di rilassare l’ipotesi di indipendenza (hmm) ed evitare il label bias problem (memm). • Specificano una singola distribuzione di probabilità sull’intera sequenza di label, data la sequenza di osservazioni, piuttosto che definire una distribuzione per stato. per applicazioni in cui la sequenza di label può dipendere da feature (delle osservazioni) interagenti. • La natura esponenziale della distribuzione consente alle feature di diversi stati di essere controbilanciate, cioè alcuni stati possono essere più importanti di altri. • Grafo non orientato globalmente condizionato su X.
Xi−2 Xi−1 Xi Oi−2 Oi−1 Oi CRF:funzioni potenziali • E’ possibile fattorizzare la disrtribuzione congiunta su Y (corrispondenti agli stati S) in un prodotto normalizzato di funzioni potenziali strettamente positive a valori reali, ognuna operante su un sottoinsieme delle variabili random corrispondenti ai vertici del grafo, i quali formano una cricca massimale. • Non ha una diretta interpretazione probabilistica, ma rappresenta vincoli sulla configurazione delle variabili random su cui è definita. • Lafferty definisce la probabilità di una sequenza di label y data una sequenza di osservazioni x come il prodotto normalizzato di funzioni potenziali del tipo: f: wordi−1 = Grace & posi = NNP f: posi−1 = NNP & posi = NNP & wordi = Road
CRF:funzioni potenziali • Per definire le feature fanction costruiamo delle feature real-valued delle osservazioni per esprimere caratteristche sulla distribuzione empirica dei dati di training che possiamo usare per modellare la distribuzione. • Una configurazione globale che ha maggiore probabilità soddisfa più vincoli di una configurazione con minore probabilità.
CRF • L’informazione dei dati di training è incapsulata nell’insieme di feature function. • Per stimare la distribuzione potenziale di un set di dati di training si sfrutta il principio di massima entropia. • L’entropia di una distribuzione è la misura dell’incertezza. • Assumendo l’insieme di TD i.i.d, il prodotto su tutte le sequenze di training, come funzione di è noto come likelihood: • Il training ML sceglie i valori dei parametri t.c il logaritmo del likelihood sia massimizzato.
CRF • Il log-likelihood per un CRF è definito come: • Uguagliando a zero si ottiene il vincolo del modello di massima entropia: Il valore atteso di ogni feature rispetto al modello è uguale al valore atteso sulla distribuzione empirica dei dati di training. • Si usa una tecnica iterativa.
Considerazioni • Rispetto agli HMM il modello definito dai CRF è più espressivo, consentendo arbitrarie ipotesi di indipendenza sulle osservazioni. • Condivide le proprietà di convessità generali dei modelli di massima entropia.
MALLET • Libreria di classi Java che offre supporto alle applicazioni di NLP, classificazione, clustering, estrazione di informazione, etc.. • Abbiamo utilizzato l’implementazione fornita sui CRF, sfruttando il modello per la segmentazione di records bibliografici. • FASE INIZIALE • ETICHETTE: autore, titolo, journal, volume, anno. • FEATURE: CAPITALIZED, LONGCAPITALIZED, MIXEDCAPS, LONGMIXEDCAPS, ALLCAPS, ALLDIGIT, FOURDIGIT, NUMERIC, ALFANUMERIC. • INPUT: dati etichettati con le appropriate label e feature
TRAINING & TEST (1) • TRAINING • INPUT (file) → SimpleTagger: crea un SimpleTaggerSentence2FeatureVectorSequence: estrae DataAlphabet e LabelAlfabet, crea FeatureVectorSequence e LabelSequence → costruisce una InstanceList sui dati di training e su questa invoca train: apprende i pesi (costi) per i nodi applicando l’algoritmo forwardbackward: crea la struttura del lattice → restituisce un CRF. • OUTPUT: crf (file)
TRAINING & TEST (2) • TEST • INPUT (file): esempi di test, con feature→ SimpleTagger → crea InstanceList sui dati di testing→ test → apply( crf, dati di test): applica viterbiPath(dati di test): restituisce la sequenza di output. • OUTPUT: risultato
nome dei pesi stato destinazione nome label stato sorgente Mallet:INFO INFO: Labels: O autore titolo journal volume anno INFO: O->O(O) O,O INFO: O->autore(autore) O,autore INFO: O->titolo(titolo) O,titolo INFO: O->journal(journal) O,journal INFO: O->volume(volume) O,volume INFO: O->anno(anno) O,anno State #0 "O" initialCost=0.0, finalCost=0.0 #destinations=6 -> O -> autore -> titolo -> journal -> volume -> anno
Mallet:INFO STATE NAME="O" (6 outgoing transitions) initialCost = 0.0 finalCost = 0.0 -> O WEIGHTS NAME="O,O" O -> O: <DEFAULT_FEATURE> = 0.0 -> autore WEIGHTS NAME="O,autore" O -> autore: <DEFAULT_FEATURE> = 0.0 -> titolo WEIGHTS NAME="O,titolo" O -> titolo: <DEFAULT_FEATURE> = 0.0 -> journal WEIGHTS NAME="O,journal" O -> journal: <DEFAULT_FEATURE> = 0.0 -> volume WEIGHTS NAME="O,volume" O -> volume: <DEFAULT_FEATURE> = 0.0 -> anno WEIGHTS NAME="O,anno" O -> anno: <DEFAULT_FEATURE> = 0.0 I pesi, weight set, sono inizializzati con un valore di default e per tutte le feature sono costruiti a partire dai predicati di input. Assumono valori da -Inf a Inf. Valori più alti rendono il path più probabile Vengono combinati con il vettore delle feature.