Unifikation (Logik)
aus Freepedia, der freien Wissensdatenbank
Unifikation ist eine Methode zur Vereinheitlichung prädikatenlogischer Ausdrücke. Diese hat insbesondere in der Computerlogik und Computerlinguistik eine größere Bedeutung erlangt. So nutzt etwa die Inferenzmaschine des PROLOG-Interpreters Unifikation. In der Computerlinguistik gibt es sogenannte Unifikationsgrammatiken, die sich auf dieses Konzept stützen.
Als Basisoperation liegt der Unifikation die Substitution zu Grunde. Im Rahmen der Prädikatenlogik bedeutet eine Substitution σ innerhalb eines gegebenen Ausdrucks die Ersetzung einer Variablen durch einen Term, in dem diese Variable nicht vorkommen darf. Die Variable wird gewissermaßen durch den Term "instanziiert".
Wird eine Menge von Ausdrücken <math>\{A_1,A_2,...,A_n \}</math> durch eine Substitution σ zu einem äquivalenten Ausdruck substituiert, d.h. <math> \sigma(A_1) \equiv \sigma(A_2) \equiv ... \equiv \sigma(A_n)</math>, so bezeichnet man σ als Unifikator dieser Ausdrucksmenge. Die Anwendung eines Unifikators auf diese Menge bezeichnet man als Unifikation.
Nicht alle Ausdrücke können unifiziert werden!
Beispiel
Gegeben seien die Ausdrücke <math>A_1 = (X, Y, f(Y) )</math> und <math>A_2 = (a, b, Z)</math>
Ersetzt man in <math>A_1</math> nun X durch a, Y durch b und in <math>A_2</math> Z durch f(b), so sind sie gleich oder unifiziert.
Kleinster gemeinsamer Unifikator
Zu einer Menge von Ausdrücken existieren gewöhnlich mehrere Unifikatoren. Man nennt einen Unifikator <math> \mu</math> kleinster gemeinsamer Unifikator oder allgemeinster Unifikator, wenn es für jeden anderen Unifikator <math> \sigma</math> eine Substitution <math>\tau</math> gibt mit <math>\sigma = \tau \circ \mu</math>
Mittels des Algorithmus von Robinson nach John Alan Robinson kann man zu unifizierbaren Ausdrücken einen kleinsten gemeinsamen Unifikator finden.
Weblinks
- http://i10www.ira.uka.de/fosys/lm/robinson/index.html - Universität Karlsruhe, Institut für Logik: schrittweise Demonstration des Algorithmus von Robinson mit Java-Applet



