130 likes | 296 Views
Modello. La logica del primo ordine consente di definire un modello di un insieme di formule, ossia una interpretazione che soddisfi ogni formula. Indecidibilità. Un problema è indecidibile se un qualunque algoritmo che tenti di risolverlo è incompleto (non considera tutti i casi) oppure
E N D
Modello La logica del primo ordine consente di definire un modello di un insieme di formule, ossia una interpretazione che soddisfi ogni formula
Indecidibilità Un problema è indecidibile se un qualunque algoritmo che tenti di risolverlo è • incompleto (non considera tutti i casi) oppure • scorretto (sbaglia qualcosa) oppure • non termina
Esempio x DogOwner (x) ( y OwnerPet (x,y)) Dog(y) • Dog Owner (Fred) È soddisfatta dalla costante Fred • Own Pet (Fluffy) È soddisfatta dalla costante Fluffy Ogni modello che soddisfi le 3 formule deve dedurre che Fluffy è un cane, altrimenti non è un modello
Osservazioni Fred è un DogOwner, ma se ha anche un gatto cosa succede? Si ha una contraddizione poiché non è stato definito nulla riguardo il gatto ed il suo possesso. DogOwner(Fred) OwnPet(Fred,Tom) Cat(Tom) Una volta detto che Tom è un gatto è necessario indicare al sistema che Cat e Dog sono due cosa differenti z Cat (z) (Dog(z))
Inconsistenza La base di conoscenza è ancora inconsistente infatti da x DogOwner (x) ( y OwnerPet (x,y)) Dog(y) si deduce che, in quanto posseduto da Fred, Tom è Dog Da z Cat (z) (Dog(z)) si deduce che essendo Cat, Tomnon è Dog
Problema • Una base di conoscenza deve essere in grado di dedurre la conoscenza implicita e di individuare eventuali errori logici connessi • La logica del primo ordine è uno strumento semanticamente accettabile • Tradurre la logica del primo ordine in un programma eseguibile da una macchina Il problema diventa
Indecidibilità nei KBMS • Per un Knowledge Based Management System (KBMS) calcolare tutte le formule valide di un insieme di formule è un problema indecidibile • Non esiste un algoritmo in grado di risolvere il problema • Nessun linguaggio di programmazione esistente è in grado di risolvere il problema
Linguaggi di programmazione Rappresentazione della conoscenza Basi di Dati Semantica operazionale, denotazionale, ecc. Logica del Primo Ordine Semantica Logica del primo ordine Sistemi di rappresentazione della conoscenza e loro linguaggi Modello Concettuale Diagramma Entità/Relazioni Unified Modeling Language • Reticolare • Gerarchico • Relazionale • A Oggetti • Record • Grafi Modello Logico • Frames • Reti semantiche
Sistemi di rappresentazione della conoscenza • (Knowledge Language) KL – ONE (1980) • LOOM (1985) • Classic ( primi anni 90)
Classic Poiché rappresentare tutta la conoscenza è un problema indecidibile si è pensato di adottare una • Espressività limitata Pertanto Classic comprende • costanti • predicati unari (classi) • predicati binari (legami tra classi) Il problema resta comunque indecidibile
Soluzione adottata da Classic • Costanti • Concetti (Predicati unari) • Ruoli (Predicati binari) • Sintassi • Formule • Asserzioni su individui (concetti, ruoli)
Esempio • Asserzione su individui: Primitivo di Manduria Vino Rosso in una base di dati sarebbe l’aggiunta di una tupla alla relazione Vino Rosso • Asserzione binaria: Primitivo di Manduria Produttore Cantina Sociale Pliniana Individuo Concetto Ruolo
Definizione di Concetti Vino Rosso = Vino And (Fills Colore Rosso) In una base di dati sarebbe una query Chianti = Vino And (Fills Colore Rosso) And (Fills Provenienza Toscana) La base di conoscenza è in grado di fare deduzioni: Esempio Primitivo Vino Rosso ruolo individuo