Sortenlogik entspringt der Intention, das (mengentheoretische) Universum (Grundmenge, Allklasse, bis hin zu einem Grothendieck-Universum) nicht als eine homogene Ansammlung von (mathematischen) Objekten zu betrachten, sondern diese auf verschiedene Klassen oder Typen aufzuteilen, die in diesem Zusammenhang Sorten genannt werden (ähnlich wie die Datentypen in vielen Programmiersprachen und Datenbanksystemen). Jedem Term einer logischen Formel wird eine Sorte zugeordnet. Unifikation von Termen ist nur dann zugelassen, wenn beide Terme von der gleichen Sorte sind; Substitution und Argumentübergabe können ebenfalls nur unter Berücksichtigung dieser Sorten erfolgen. Falsche Sortenzuordnungen werden also bereits als Syntaxfehler ausgewiesen.

Motivation Bearbeiten

Aus dem Blickwinkel der Prädikatenlogik (ohne Sorten) sind Sorten einstellige Relationen (Sortenprädikate), falsche Sortenzuweisungen erscheinen dann aber nicht mehr als Syntaxfehler, sondern nach Zuweisung einer Semantik als falsch. Die Sortenlogik stellt dagegen für diese Prädikate eine Spezialbehandlung der eben erwähnten Form zur Verfügung.

Im Gegensatz zur Prädikatenlogik zweiter Stufe mit Relationsvariablen bietet die Sortenlogik daher keine Steigerung der Mächtigkeit, etwa in Bezug auf Fragen nach Beweisbarkeit.[1] Da viele Deduktionschritte aber wegen der Sortenunverträglichkeit nicht in Betracht gezogen werden brauchen, verringert sich der Suchaufwand nach einem Beweis in der Praxis beträchtlich.

Mehrsortige Strukturen bilden ein mengentheoretisches Modell für die Datentypen in der Informationstechnologie, insbesondere bei Datenbanken, weshalb ihnen eine erhebliche praktische Bedeutung zukommt.[2] Darüber hinaus ist Mehrsortigkeit eine Möglichkeit, den mit Typentheorien verbundenen Belangen auf mengentheoretischer Basis Rechnung zu tragen.

Einordnung und Abgrenzung Bearbeiten

Es gibt prinzipiell verschiedene Möglichkeiten, diese Absicht zu realisieren. Den meisten Fällen gemeinsam ist

  • es gibt eine Menge   von Sorten (in der Informationstechnologie auch Datentypen genannt) [3]
  • es gibt eine Verallgemeinerung des Begriffs Signatur, um die mit den Sorten verbundene Zusatzinformation zu berücksichtigen.

Im gesamten Universum als Zusammenfassung aller Objekte einer Struktur werden dann in die Wertebereiche zu den verschiedenen Sorten abgegrenzt.

Die Algebraisierung der Sortenlogik wird in einem Artikel von Caleiro und Gonçalves[4] beschrieben und kann gut als eine Einführung in die Materie dienen.

Vielsortige Logik Bearbeiten

In der vielsortigen Logik wird die paarweise Disjunktheit der Wertebereiche (auch Trägermengen genannt) zu den verschiedenen Sorten vorausgesetzt.

Bei vielsortigen Signaturen kommen im Vergleich zu gewöhnlichen einsortigen Signaturen zu den Funktions- und Relations- und ggf. eigens ausgewiesenen Konstantensymbolen noch Bezeichnungen für die Sorten, d. h. die Wertebereiche hinzu. Jedes der Symbole wird jetzt nicht mehr nur durch die Stelligkeit gekennzeichnet, sondern durch die genaue Abfolge der Argumentsorten, und ggf. eine Wert- oder Bildsorte.[5] Eine n-stellige Relatione ist eine Teilmenge des n-fachen kartesischen Produktes einer Sequenz der Trägermengen. Der Argumentbereich einer n-stelligen Funktion ist ein ebensolches Produkt, dazu kommt noch eine der Trägermengen für das Bild (Funktionswert).

Beispiele Bearbeiten

  • Ein Beispiel bieten Taxa (Gruppen) biologischer Organismen, unter anderem   und  . Während eine Funktion   sinnvoll ist, würde das für eine ähnliche Funktion   im Allgemeinen nicht gelten. Sortenlogik erlaubt Terme der Art    , verwirft aber     als syntaktische Fehlkonstruktion.
  • Vielsortige Strukturen erster Stufe sind beispielsweise folgende heterogene Algebren:
    • Vektorräume über einem Körper (Links-, Rechtsvektorräume bei einem Schiefkörper, Bivektorräume) – mit den Sorten Skalar und Vektor
    • Moduln über einem kommutativen Ring (Links-, Rechtsmoduln bei beliebigem Ring, Bimoduln) – eine Verallgemeinerung des Begriffs (d. h. der Kategorie) Vektorraum
    • Algebren über einem Körper oder kommutativen Ring – als spezielle Vektorräume
    • Lie-Algebren und kommutative Algebren über einem Körper – beides spezielle Algebren über diesem Körper
    • Affine Räume[6] sind Beispiele für dreisortige Strukturen mit einem Punktraum   und einem Vektorraum mit Trägermenge   über einem Körper  , die Punkte sind mit den Vektoren über eine Parallelverschiebung genannte Operation verknüpft.

Definition Bearbeiten

Es seien   und   disjunkte Mengen von nichtlogischen Zeichen. Sei zudem   eine weitere davon disjunkte endliche und nichtleere Menge nichtlogischer Zeichen. Man nennt dann

  • jedes Zeichen in   ein Symbol und   eine Symbolmenge,
  • jedes Zeichen in   eine Sorte,

wenn durch eine Abbildung   jedem Symbol als Typ eine Sequenz (Tupel) von Sorten zugeordnet wird, und zwar:

  •   für alle   mit Stelligkeit  , und
  •   für alle  , mit Stelligkeit  .

  heißt dann eine mehr- oder vielsortige Signatur.[7]

Anmerkungen Bearbeiten

  1. Wie im einsortigen Fall wird jedes   als Funktionssymbol, jedes   als Relationssymbol (oder Prädikatsymbol) bezeichnet.
  2. Durch die vielsortige Signatur   wird zugeordnet
    • den Relationssymbolen   der Stelligkeit   ein Typ (Argumenttyp)   bestehend aus den   Argumentsorten   und
    • den Funktionssymbolen   der Stelligkeit   ein Typ   bestehend aus dem Argtumennttyp   (d. h. den   Argumentsorten wie bei den Relationen) und zusätzlich der Bildsorte  .
Die Sequenzen (Tupel) der Symboltypen (der Bildwerte von  ) lassen sich interpretieren als Wörter (Zeichenketten) über dem Sortenalphabet  . Mengentheoretisch handelt es sich um Elemente der Kleeneschen Hülle  .[8]
  1. Die nullstelligen Funktionssymbole   werden als Konstantensymbole der Sorte   interpretiert.
  2. Ggf. vorhandene nullstellige Relationssymbole  [9] werden analog als – aussagenlogische (oder boolesche) Konstantensymbole interpretiert.[10]:S. 16–19
  3. Ähnlich wie im einsortigen Fall mit der Stelligkeit kann man hier statt der Abbildung  , die jedem Symbol seinen Typ aus   zuordnet, deren Urbildfasern betrachten. Konkret sind dies die Familien   und   ; in Funktionschreibweise:
    •   ordnet jeder Sequenz von Sorten die Menge der Relationssymbole mit dieser Sequenz als Typ zu (die Länge der Sequenz ist dabei die Stelligkeit); und
    •   weist jeder nichtleeren Sequenz von Sorten die Menge der Funktionssymbole zu, wobei die jeweils letzte Sorte der Sequenz die Bildsorte bezeichnet und die anderen vorher den Argumenttyp.
Für die Kennzeichnung der Signatur genügt dann die Angabe des Sortenalphabets zusammen mit diesen beiden Familien  .[11][12]
  1. Statt   zur Kennzeichnung des Typs der Funktionssymbole wird auch   geschrieben.[13]:S. 5 Bei Verwendung der Schreibweise ist stets zu bedenken, dass hier Bezeichnungen, Symbole, Sorten(bezeichner) gemeint sind, nicht die Objekte, Funktionen, Wertebereiche (Trägermengen) selbst. Die Schreibweise ist insbesondere bei Überladung gültig (die Bildsorte ist durch den Argumenttyp eindeutig bestimmt).
  2. Das gleiche Relationssymbol kann für Relationen unterschiedlichen Argumenttyps verwendet werden. Das Gleiche gilt für Funktionssymbole. Man spricht dann von einem überladenen Relationssymbol (Prädikat) bzw. Funktionssymbol.[10]:S. 20 Betrachtet man dei Urbildfasern, dann sind die Menge der Relationssymbole und die Menge der Funktionssymbole zu jeder festen Bildsorte   bei Überladung nicht mehr notwendig paarweise disjunkt. Für einen festen Argumenttyp   sind jedoch weiterhin die Mengen der Funktionssymbole zu verschiedenen Bildsorten   disjunkt:  . Folglich bleiben auch in diesem Fall die Menge aller Relationssymbole   und die Gesamtheit aller Funktionssymbole   für jede Bildsorte   paarweise disjunkt.
    Die Typzuordnung   ist bei Überladung eine Multifunktion (  statt  ).[14] Aber auch in diesem Fall hat jedes Symbol bei festgelegtem Argumenttyp höchstens eine Bedeutung: Entweder ist es ein Relationssymbol, oder ein Funktionssymbol zu einer bestimmten Bildsorte  .
    Bezeichnet   die Menge aller Funktionssymbole mit einem bestimmten Argumenttyp   (also die Vereinigung über alle Bildsorten  ), dann sind die Einschränkungen von   auf einen bestimmten Argumenttyp ( ) als Abbildungen immer eindeutig. Auch im Fall von Überladung ist die Abbildung  , die jedem Funktionssymbol die Bildsorte (als letzte Koordinate der Multifunktion  , also   mit Stelligkeit  ) zuordnet, eindeutig.
    Eine Logik ohne Überladungen heißt strikt.[15]
  3. Eine Programmiersprache kann beispielsweise Ganzzahlen (int für integer) und Zeichenketten (string, mit lexikographischer Ordnung) zur Verfügung stellen. Das Kleinerzeichen < kann zum Vergleich zweier Ganzzahlen oder zweier Zeichenketten verwendet werden:  .[10]:S. 20 Als Beispiele für mehrsortig überladene Funktionssymbole können wieder max und min dienen, die auf verschiedenen Totalordnungen nebeneinander mit gleicher Bezeichnung vorkommen können. Die Funktionssymbole min und max können entweder auf n Argumente vom Datentyp int oder auf n Argumente vom Typ string angewendet werden. Die Bildsorte ist dann durch den Typ der Argumente festgelegt, nämlich gleich der Sorte eines jeden einzelnen Arguments, int oder string.
  4. Eine spezielle Bedeutung kommt – wenn vorhanden – der Sorte der logischen Wahrheitswerte   zu; übliche Bezeichnungen für diese sind   (oder  ). Relationen können entsprechend ihrer charakteristischen Funktion als Prädikate aufgefasst werden, siehe Relation, § Relationen und Funktionen. Entsprechend können Relationssymbole als boolesche Funktionssymbole mit Bildsorte   gedeutet werden.[16][17] Dadurch kann eine weitere Vereinfachung erreicht werden. Ein Beispiel ist die Disjunktheitsforderung der Symbolmengen pro Bildsorte bei Überladung (Wegfall der Relationen als Sonderfall). Bei der Definition der Begriffe Term und Ausdruck (auch genannt Formel) und in ihrem Gebrauch kommt der Sorte   eine Sonderrolle zu, siehe unten: § Terme in vielsortiger Logik und § Ausdrücke in vielsortiger Logik.

Variablensymbole bei Vielsortigkeit Bearbeiten

Auch für die Variablen muss eine Sorte spezifiziert werden. In der Literatur finden sich im Wesentlichen zwei Vorgehensweisen:

  1. Es wird eine einzige Variablenmenge   vorgesehen. Eine (ggf. nur partielle) Abbildung  , die Variablenbezeichnern eine Sorte zuordnet, heißt Variablendeklaration;[10]:S. 54 eine Variable aus dem Definitionsbereich der Variablendeklaration heißt deklariert. Bei der Interpretation kann diese im Skopus (Wirkungsbereich) des jeweiligen Quantors ersetzt werden durch eine lokale Variante (lokal modifizierte Variablendeklaration)   mit beliebigen   und
 [10]:S. 56 [18]
  1. Andere Autoren grenzen dagegen die Symbolmengen für die Variablen verschiedener Sorten streng voneinander ab und benutzen jeweils für jede Sorte eine eigene Menge an Variablensymbolen. Die Variablen werden z. B. durch einen Sortenindex gekennzeichnet. Die Zuweisung   einer Sorte zu einer Variablen ist fest und wird nicht lokal modifiziert.[19]

Die Zugehörigkeit einer Variable zu einer bestimmten Sorte ( ) wird in Anklang an das Typenurteil der Typentheorie syntaktisch als   notiert.[13]:S. 7

Variablensymbole der Prädikatenlogik zweiter Stufe
  • In der Prädikatenlogik zweiter Stufe gibt es zusätzlich Relationsvariablen und ggf. auch Funktionsvariablen. Bereits im einsortigen Fall muss diesen eine Stelligkeit zugeschrieben werden, im Fall der Vielsortigkeit ist diese wie bei den Raltions- und Funktionssymbolen zu einem Typ erweitert. In der Literatur werden (im einsortigen Fall) meist feste Zuordnungen (Stelligkeit) gewählt.[20][21][22] Entsprechend der Praxis in der Informationstechnologie sind aber auch (Stelligkeits- bzw.) Typdeklarationen mit lokalen Varianten möglich. Die Variablendeklaration   ist dann entsprechend zu erweitern mit Wertebereich   statt  .
  • Die Relationsvariablen der Prädikatenlogik zweiter Stufe lassen sich als Funktionsvariablen mit Bildsorte   interpretieren.
  • Die Variablen der Sorte   – wenn vorhanden – nennt man Aussagenvariablen.[23]:S. 1 Sie entsprechen nullstelligen Relationsvariablen.
  • In der monadischen Prädikatenlogik zweiter Stufe sind nur einstellige Relationsvariablen zugelassen. Im vielsortigen Fall sind diese durch die (einzige) Argumentsorte zu kennzeichnen.

Terme in vielsortiger Logik Bearbeiten

Definition

Bei gegebener Signatur   und Variablendeklaration   wird die Menge   der Terme der (nichtlogischn) Sorte   dann rekursiv definiert wie folgt:

  1. Jedes Variablensymbol   einer Sorte   ist per Deklaration ein Term der Sorte  
  2. Ist   ein ( -stelliges) Funktionssymbol vom Typ  , und ist weiter   ein Term der Sorte  ,   ein Term der Sorte  ,     ein Term der Sorte  , so ist   ein Term der Sorte  ,[10]:S. 59 insbesondere:
    • Jede Konstante   der Sorte   ist per Signatur ein Term der Sorte  

Die Menge aller Terme   ist gegeben durch die disjunkte Vereinigung der   über alle nichtlogischen Sorten  . Bei leerer Variablendeklaration kann der Index   entfallen:  .[24]:S. 4
Durch die Funktionssymbole werden Verknüpfungen verschiedenen Typs zwischen den Elementen der   bzw.   der verschiedenen Sorten  induziert, mit denen diese verschiedensortigen Mengen von Zeichenketten selbst zu einer heterogenen Algebra als Termalgebra bzw. Grundtermalgebra werden.

Anmerkungen
  • Infix-Notation bei zweistelligen Funktionen:   statt  , wie oben. Präfixform: Klammerfreie Polnische Notation, ebenfalls wie oben. Seltener: Postfixnotation.[25]
  • Punktnotation   statt  ,   statt   (wie in der objektorientierten Programmierung).
  • Neuerdings gewinnt die Baumdarstellung von Termen zunehmend an Bedeutung.[26]

Ausdrücke in vielsortiger Logik Bearbeiten

Definition

Sei gegeben eine Signatur   und eine Variablendeklaration  . Eine atomare Formel (auch atomarer Ausdruck) ist

  •   für alle Terme   derselben Sorte  .
  • Alle Aussagenvariablen, sofern diese Sorte zugelassen ist.[23]:S. 1 f
  •   für alle  -stelligen Relationssymbole vom Typ  , wenn   Term der Sorte  ,   Term der Sorte  ,     Term der Sorte   ist.
  • Nullstellige Relationssymbole (logische Konstanten), sofern zugelassen.

Ausdrücke (bzw. Formeln) allgemein sind in der mehrsortigen Logik wie folgt rekursiv definiert:

  • Jeder atomare Ausdruck ist ein Ausdruck.
  • Sind   und   Ausdrücke, so sind auch  ,  ,  ,   Ausdrücke.
  •   und   sind Ausdrücke, wenn   eine Sorte,   ein Variablensymbol, und   ein Ausdruck ist, in dem die lokale Variable   der Sorte   vorkommt.[27][10]:S. 66–68
Anmerkung

Relationen können als Prädikate aufgefasst werden, d. h. als (Boolesche) Funktionen mit gleicher Stelligkeit und Argumenttyp sowie dem Wertebereich  , d. h. der Bildsorte   (siehe Relation, § Relationen und Funktionen). Werden die Junktoren als Symbole für ein- und zweistellige Boolesche Funktionen (in Präfix- bzw. Infix-Notation) aufgefasst, dann sind Ausdrücke – abgesehen von solchen mit Qantoren – quasi ‚Terme der Sorte  ’.

Interpretation Bearbeiten

Semantik einer vielsortigen Signatur

  sei eine vielsortige Signatur mit der Menge   der Funktionssymbole (Konstanten als nullstellige Funktionen) und der Menge   der Relationssymbole (ggf. auch nullstellige, d. h. logische Konstanten).
Sei  [28]  und   eine Abbildung mit folgenden Maßgaben:

  •   sei für jede Sorte   ein Wertebereich (Grundmenge)
  •   eine Relation für jedes  ,[29] und
  •   eine Funktion (Verknüpfung) für jedes  .[30]

Dann nennt man   eine Interpretationsfunktion und   eine vielsortige Struktur der Signatur   oder  -Struktur.[31]

Überladung

Im Fall von Überladung wird Eindeutigkeit hergestellt, indem zum Relations- bzw. Funktionssymbol noch der Argumenttyp angegeben wird:

 ,
 .

Dabei ist die Stelligkeit   hier gegeben ist durch die (Wort-)Länge   des Argumenttyps  , und   ist die durch den Argumenttyp eindeutig bestimmte Bildsorte  
Es handelt sich um partielle Abbildungen, nur für Typen   mit   bzw.   kann es überhaupt Zuweisungen der Symbole zu Relationen bzw. Funktionen gegeben.

Interpretation

Eine (ggf. nur partielle) Abbildung   auf  , die deklarierte Variablen   aus   auf Elemente der zugehörigen Sorte   (d. h. aus dem Wertebereich  ) abbildet, heißt eine Belegung der vielsortigen  -Struktur  .[32][24]:S. 9

Für eine Interpretation   der Signatur   werden jetzt die Komponenten   benötigt.

Bei vorhandener Interpretation und Variablenbelgung (was ggf. eine Variablendeklaration voraussetzt) kann dann Sorte und Wert der Terme bestimmt werden (siehe Term, § Termauswertung), sowie die Gültigkeit logischer Ausdrücke beurteilt werden (siehe Term, § Gültigkeit von Ausdrücken).

Termauswertung und Gültigkeit von Ausdrücken (Formeln)

Ordnungssortierte Logik Bearbeiten

In der ordnungssortierten Logik sind die den Sorten   zugeordneten Wertebereiche   im Gegensatz zur vielsortigen Logik nicht notwendig disjunkt. Stattdessen ist die Menge der Sorten   mit einer partiellen Ordnung   versehen,[33] so dass für alle Sorten   gilt: Wenn  , dann  . Dadurch wird die Sorte   zu einer Untersorte der Sorte   (Obersorte) erklärt.[13]:S. 5 [34] Diese Logik ist Grundlage der Vererbung von Klassen (Klassenhierarchie) in der objektorientierten Programmierung.

Ordnungssortierte Logik kann wie vielsortige Logik in gewöhnliche einsortige Logik umgesetzt werden. Die Sortenzugehörigkeit   wird wieder übersetzt in ein einstelliges Prädikat  , zusätzlich kommt für jeder Untersortenbeziehung   ein Axiom   hinzu.

Der umgekehrte Ansatz war erfolgreich in einem automatisierten Theorembeweis: 1985 konnte Christoph Walther ein Benchmark-Problem lösen, indem er es in ordnungssortierter Logik formulierte und dadurch den Aufwand um Größenordnungen reduzierte, da viele einstelligen Prädikate zu Sortierungen wurden.[35]

Beispiele Bearbeiten

  • Im obigen Beispiel wäre etwa
 ,
 ,
 ,
 ,
 ,
 ,
 ,
und so weiter.
  • Modellierung der Verhältnisse bei den Zahlenbereichen:
  (ganze Zahlen)   (rationale Zahlen)   (reelle Zahlen)   (komplexe Zahlen)   (Quaternionen)   (Oktonionen)   (Sedenionen),
  (algebraische Zahlen)  .
  • In manchen Programmiersprachen (wie Pascal und Modula-2) dienen ganzzahlige Intervalle als Datentypen: Seien   mit  , dann gilt für den Intervall-Datentyp  [36] Die (ungeprüfte) Zuweisung von beliebig ganzzahligen Werten an diesen Datentyp kann als syntaktisch falsch eingestuft werden.
  • Eine besondere Situation ergibt sich, wenn die Sorte   Überschneidungen mit anderen Sorten hat. Die Wahrheitswerte   und   können als 0 ins 1 gedeutet werden. Dann stehen diese für Relationen wie   und Funktionen (Verknüpfungen) wie   und   zur Verfügung. Ein Beispiel dafür in der Informationstechnologie ist C-Language.[37] In einer Erweiterung könnten die logischen Werte einer dreiwertigen Logik oder einfachen Fuzzy-Logik mit Zahlen aus dem reellen Intervall   gleichgesetzt werden, so dass in allen Fällen gilt:  

Vorgehensweise Bearbeiten

Durch   wird dann eine Sortenstruktur erzeugt mit einer nochmals erweiterten ordnungsorientierten Signatur, etwa  [38][39] Beispiele für ordnungssortierte Strukturen in der Mathematik sind

  •  ,  ,   und   als kommutative und assoziative Algebren über dem Ring der ganzen Zahlen   (d. h. als spezielle  -Moduln), da   Teilmenge dieser Zahlenbereiche ist,
  •   als unendlich-dimensionale assoziative und kommutative Algebra über dem Körper der rationalen Zahlen   (d. h. als spezieller  -Vektorraum mit Hamel-Basis), da  ,[40]
  •   als zweidimensionale assoziative und kommutative Algebra über dem Körper   (d. h. als spezieller  -Vektorraum), da  
  • Ein weiteres Beispiel bilden die verschiedenen Bereiche hyperkomplexer Zahlen, wie die Quaternionen   (respektive Oktonionen   bzw. Sedenionen  ), etwa als vierdimensionale assoziative nicht-kommutative Algebra (respektive acht- bzw. 16-dimensionale nicht-assoziative nicht-kommutative Algebra) über dem Körper  , der wie schon bei   eine Teilmenge darstellt.

Die Halbordnung   wird auf kanonische Weise fortgesetzt auf   wie folgt:

  genau dann, wenn
  •   und   haben die gleiche Stelligkeit (d. h. Tupel- oder Wortlänge), hier bezeichnet mit  
  • für alle   gilt  

Reguläre Signatur Bearbeiten

Eine ordnungsorientierte Signatur heißt regulär genau dann, wenn für jedes Funktionssymbol   und jedes   die Menge

 

leer ist oder ein eindeutig bestimmtes kleinstes Element hat.[13]:S. 6

Zulässige Signatur Bearbeiten

Eine reguläre Signatur heiß zulässig, wenn die folgenden Bedingungen erfüllt sind:[13]:S. 6 f

  • Wenn für   und   mit   gilt  , dann gilt auch  [13]:S. 6
  • Es kann keine unendliche Ketten   geben. Falls die Sorten- und Symbolmengen endlich sind (endliche Signatur), ist das stets gewährleistet.
  • Abwärtsvollständigkeit: Wenn zwei Sorten   gemeinsame Untersorten haben, dann gibt es eine größte gemeinsame Untersorte (ggU, engl.: greatest common subset), in Zeichen  .[41] Notfalls kann aber eine geeignete neue Sorte   zum Sortenalphabet   hinzugenommen werden, damit dann   erfüllt wird. Auf Objetebene besagt die Bedingung nichts anderes, als dass die Schnittmenge zweier Wertebereiche   und   (als größte gemeinsame Teilmenge) entweder leer ist, oder aber Wertebereich zu einer geeigneten Sorte   sein muss.
    Um ordnungssortierte Logik in einen satzbasierten automatischen Theorembeweiser zu integrieren, ist ein entsprechender ordnungssortierter Unifikation-Algorithmus notwendig. Dies erfordert, dass für zwei erklärte Sorten   mit Ausnahme der Disjunktheit deren ggU   ebenfalls erklärtes Mitglied der Sortenmenge   ist
  • Für alle   mit  [42] ist auch die Menge
     
entweder leer oder hat ein größtes Element. Die Kombination dieser Forderung mit der Abwärtsvollständigkeit heißt Abwärtseindeutigkeit.

Aus praktischen Gründen ist Überladung der Normalfall.[13]:S. 7 Alle Funktions- und Relationssymbole   müssten andernfalls für jeden Zahlenbereich   unterschiedlich sein und diesen z. B. als Index mitführen. Die Zahlenbereiche   mit den komplex-algebraischen Zahlen   und den Ketten   und   bilden auch ein Beispiel für (fehlende) Abwärtsvollständigkeit: Als Schnittmenge zweier Sorten-Wertebereiche sind die reell-algrbraischen Zahlen   eine Menge mit fehlenden Sortenzeichen, was der Vollständigkeit halber nachzutragen wäre.

Variablen in ordnungssortierter Logik Bearbeiten

Wie bei der vielsortigen Logik gibt es die Möglichkeit, die Variablen in Mengen mit fester Sorte zuzuordnen, oder die Sortenzughöigkeit nachträglich und lokal modifizierbar per Deklaration   festzulegen.

Termauswertung in ordnungssortierter Logik Bearbeiten

Die Termauswertung auf Basis der Variablendeklaration und des Typs der Funktionen (einschließlich der Konstanten) ordnet den Termen   abhängig von der Signatur und der Variablendeklaration rekursiv soweit möglich einen Sortemenge   (Überladungen!) und einen Wert   zu.

  • für Variablen  :   (Oberhalbmeng von  )
  • für Konstanten  :  
  • für Funktionen  :  [43]
Beispiel

Wenn   und   Variablen des Typs   bzw.   sind, dann hat die Gleichung   die Lösung  , wobei   gilt.

Erweiterungen Bearbeiten

Gert Smolka verallgemeinerte die ordnungssortierte Logik, um parametrischen Polymorphismus (engl. parametric polymorphism) zu erlauben.[44] In seiner Arbeit werden Untersortenbeziehungen zu komplexen Typ-Ausdrücken weiterentwickelt. In einem Programmierbeispiel kann eine parametrisierte Sorte   deklariert werden (wobei  > ein Typparameter ist wie in einem C++ Template). Aus der Untersortenbeziehung   kann die Relation   automatisch abgeleitet werden, was bedeutet, dass jede Liste von Ganzzahlen auch eine Liste von Gleitkommazahlen ( ) ist.

Schmidt-Schauß verallgemeinerte die ordnungssortierte Logik um Termdeklarationen zu erlauben.[45] Beispielsweise erlauben die Untersortenbeziehungen   und   und eine Termdeklaration wie   eine Eigenschaft der Ganzzahladdition zu erklären, wie sie mit gewöhnlicher Überladung nicht ausgedrückt werden kann.

Schließlich lässt sich die ordnungssortierte Logik noch in Richtung Feature-Logik erweitern. Die Argumente von Funktionen und Relationen werden mit Namen versehen (statt oder zusätzlich zur Positionsnummer).[46] Dies erlaubt es, neben oder anstatt der üblichen Stellungs- oder Positionsparameter Schlüsselwortparameter zu verwenden. Das Verfahren ist einerseits in der Informationstechnologie weit verbreitet, eröffnet andererseits aber theoretische Zusammenhänge mit Dependenzgrammatiken.[13]

Siehe auch Bearbeiten

Literatur Bearbeiten

  • Wolfgang Bibel, Steffen Hölldobler, Torsten Schaub: Wissensrepräsentation und Inferenz. Eine grundlegende Einführung. Springer-Verlag, 2013, ISBN 3-322-86814-1, S. 99–100 (books.google.de).
  • François Bry: Exkurs: Mehrsortige Prädikatenlogik erster Stufe. Band 2.9. LMU, Institut für Informatik, Lehr- und Forschungseinheit für Programmier- und Modellierungssprachen (pms), München 1999 (en.pms.ifi.lmu.de).
  • François Bry: Exkurs:Prädikatenlogik zweiter Stufe. Band 2.10. LMU, Institut für Informatik, Lehr- und Forschungseinheit für Programmier- und Modellierungssprachen (pms), München 1999 (en.pms.ifi.lmu.de).
  • P.C. Gilmore: An addition to “Logic of many-sorted theories”. In: Compositio Mathematica. 13. Jahrgang, 1958, S. 277–281 (numdam.org [PDF]).
  • Klaus Gloede: Skriptum zur Vorlesung Mengenlehre. SS 2004. Universitär Heidelberg, Mathematisches Institut, S. 181. PDF, Bei DOCZZ, Bei Yumpu
  • R. Hartwig: Syntax Semantik Spezifikation. Grundlagen de Informatik. WS 2009/2010. Universität Leipzig, Institut für Informatik, Leipzig, S. 219 (informatik.uni-leipzig.de [PDF]).
  • M. Huber, I. Varšek: Extended Prolog with Order-Sorted Resolution.4th IEEE Symposium of Logic Programming. San Francisco 1987, S. 34–45.
  • H. Kleine Büning,: Sorten und Terme. Wintersemester 2015. Mod. 05 Teil 1. Universität Paderborn, 2015, S. 15.
  • Reinhold Letz: Prädikatenlogik. WS 2004/2005. Technische Universität München, Fakultät für Informatik, Lehrstuhl Informatik IV, München, S. 47 (tcs.ifi.lmu.de [PDF]).
  • Carsten Lutz: Logik Teil 4: Prädikatenlogik zweiter Stufe. Universität Bremen, AG Theorie der künstlichen Intelligenz, 2010, S. 65 (informatik.uni-bremen.de [PDF] Vorlesung im Wintersemester 2010).
  • Arnold Oberschelp: Untersuchungen zur mehrsortigen Quantorenlogik, Nummer 4. In: Mathematische Annalen. 145. Jahrgang, 1962, ISSN 0025-5831; 1432-1807/e, S. 297–333, doi:10.1007/bf01396685 (eudml.org).
  • Arnold Oberschelp: Order Sorted Predicate Logic. Lecture Notes in Computer Science (LNCS). Hrsg.: Bläsius, Karl Hans; Hedtstück, Ulrich; Rollinger, Claus-Rainer. Band 418: Sorts and Types in Artificial Intelligence, Workshop, Eringerfeld, FRG, April 24–26, 1989 Proceedings. Springer-Verlag, Berlin / Heidelberg 1990, ISBN 978-3-540-52337-6, S. 307, doi:10.1007/3-540-52337-6.
  • F. Jeffry Pelletier: Sortal Quantification and Restricted Quantification. In: Philosophical Studies. 23. Jahrgang, 1972, S. 400–404, doi:10.1007/bf00355532 (sfu.ca [PDF]).
  • Esther Ramharter, Günther Eder: Prädikatenlogik zweiter Stufe. In: Memo Seki-85-11-KL. Universität Kaiserslautern, Fachbereich Informatik, 1985 (homepage.univie.ac.at [PDF]).
  • Manfred Schmidt-Schauß: A Many-Sorted Calculus with Polymorphic Functions Based on Resolution and Paramodulation. SE Modallogik und andere philosophisch relevante Logiken. WS 2015/2016. Universität Wien, S. 22.
  • Christoph Walther: A Mechanical Solution of Schubert’s Steamroller by Many-Sorted Resolution. In: Artif. Intell. 26 (2). Jahrgang, 1985, S. 217–224, doi:10.1016/0004-3702(85)90029-3 (tu-darmstadt.de [PDF]).
  • Christoph Walther: A Many-Sorted Calculus Based on Resolution and Paramodulation. In: Research Notes in Artificial Intelligence. Pitman, London 1987.
  • Hao Wang: Logic of many-sorted theories. In: Journal of Symbolic Logic. 17. Jahrgang, 1952, S. 105–116, doi:10.2307/2266241., Teil der Sammlung Computation, Logic, Philosophy. A Collection of Essays. Science Press, Beijing / Kluwer Academic, Dordrecht 1990.

Einzelnachweise und Anmerkungen Bearbeiten

  1. Näheres siehe A. Oberschelp (1962) S. 297f
  2. Beispielsweise können Fehler bei Datentyp-Zuweisungen schnell (zur Compilezeit) als Sytaxfehler erkannt werden.
  3.   wird gedeutet als ein Alphabet von Sortenbezeichnern, siehe Alphabet (Informatik) und Alphabet (Mathematik)
  4. Carlos Caleiro, Ricardo Gonçalves: Proc. 18th int. conf. on Recent trends in algebraic development techniques (WADT). Springer, 2006, ISBN 978-3-540-71997-7, On the algebraization of many-sorted logics, S. 21–36 (utl.pt [PDF]).
  5. Unter Sortierung versteht man in diesem Zusammenhang die Zuweisung zu Sorten, siehe Steimann (1991) S. 3
  6. mit dem Spezialfall des euklidischen Raumes
  7. Anmerkung: Kruse, Borgelt (2008) S. 3 und S. 9 bezeichnen
    • die Menge der Sorten   mit   und die Sorten selbst mit  ,
    • die Einschränkung   von   auf die Funktionssymbole mit   (eine Menge geordneter Paare),
    • die Einschränkung   von   auf die Relationssymbole mit  ,
    • die Variablendeklaration   mit   (genauer gesagt benutzen die Autoren eine Punktnotation, mit dem Punkt als zusätzlichem technischen Zeichen. Die Variablen werden nur in der Form   benutzt mit dem eigentlichen Variablennamen x und einer Sorte s. Als Variablen in dem im Artikel hier gebrauchten Sinn mit Mengenbezeichnung   werden dann die Kombinationen, d. h. Zeichenketten   mit einer impliziten Variablendeklaration   benutzt. Dadurch kann der rohe Name x für mehrere Sorten verwendet werden),
    • die Signatur mit  , was im obigen Text   entspricht,
    • die Abbildung   (kennzeichnend für die  -Struktur) mit  , und
    • die Variablenbelegung   mit  .
  8.  . Im Fall der Funktionssymbole, wo mindestens eine Sorte für den Wertebereich benötigt wird, liegen die Werte von   in der positiven Hülle  . Die Stelligkeit   ist die Wortlänge des Typs   (minus 1 bei Funktionssymbolen).
  9. mit dem leeren kartesischen Mengenprodukt bestehend aus dem leeren Wort (mengentheoretisch identisch mit der Leermenge):  
  10. a b c d e f g Brass, Stefan: Mathematische Logik mit Datenbank-Anwendungen. Martin-Luther-Universität Halle-Wittenberg, Institut für Informatik, Halle 2005, S. 176 (informatik.uni-halle.de [PDF]).
  11. Die beiden Familien definieren sich analog zum einsortigen Fall als die Urbildfasern der Einschränkungen von   auf die beiden Symbolmengen   und  :  
  12. Stefan Brass 2005 S. 16–19. Der Autor verwendet zur Kennzeichnung der Signatur Faserbündel und teilweise leicht abweichende Bezeichnungen, insbesondere wird das Sortenalphabet mit   statt   bezeichnet.
  13. a b c d e f g h Steimann, Friedrich: Ordnungssortierte Feature-Logik und Dependenzgrammatiken in der Computerlinguistik. Monographien. FernUni, Fakultät Mathematik und Informatik, LG Programmiersysteme, Hagen 31. Januar 2011, S. 104 (fernuni-hagen.de – Diplomarbeit)., bei: fernuni-hagen.de (PDF; 6,3 MB). Original bei: Universität Karlsruhe 1992, Institut für Logik, Komplexität und Deduktionssysteme. Der Autor beschreibt über das Thema hier hinausgehend eine ordnungssortierte Feature-Logik erster Stufe, d. h. Argumente haben Namen und können als Schlüsselwortparameter referenziert werden.
  14. siehe auch Korrespondenz
  15. A. Oberschelp (1989/1990) Seite 10
  16. das ist dann auch die Sorte der logischen Konstanten als nullstelligen Relationen.
  17. Relationen lassen sich also als spezielle Funktionen auffassen, umgekehrt sind Funktionen spezielle (linkstotal-rechtseindeutige) Relationen.
  18. Zur hier verwendeten Maplet-Schreibweise   (anstelle des von S. Brass verwendeten Schrägstrichs   oder  ) siehe Klaus Grue (1995) S. 11.
  19. A. Oberschelp (1989/1990) Seite 9ff
  20. F. Bry (1999/2.10) Def. 2.10.1
  21. C. Lutz (2010) S. 6 und 8
  22. Ramharter, Eder (2015/16) S. 17. Die Autoren kennzeichnen die Stelligkeit der Relationsvariablen mit einem Index.
  23. a b Grädel, Erich: Mathematische Logik. Mathematische Grundlagen der Informatik. SS 2009. RWTH, Aachen, S. 129 (cs.uni-dortmund.de [PDF]).
  24. a b Kruse, Stefan; Borgelt, C.: Grundbegriffe der Prädikatenlogik. Computational Intelligence. Otto-von-Guericke Universität, Magdeburg 2008, S. 14 (fuzzy.cs.ovgu.de [PDF]).
  25. Kleine Büning (2015), S. 5 ff
  26. Ausführliche Darstellung: Kleine Büning (2015), S. 8–15.
  27. D. h. im Skopus (Wirkungsbereich) des jeweiligen Quantors gilt eine lokal modifizierte Variablendeklaration (auch ( -)Variante genannt)   mit beliebigen   und
     
    Siehe Stefan Brass (2005) S. 56, sowie Ramharter, Eder (2015/16) S. 17. Für den Fall, dass   bereits außerhalb der Quantoren deklariert ist, d. h. wenn   bereits im ursprünglichen Definitionsbereich der Deklaration   enthalten ist, wird diese lokal überschrieben. Eine Variable im Skopus eines Quantors (wie hier  ) nennt man eine gebundene Variable.
  28. mit   (Familienschreibweise),  , wobei   (Wort- oder Tupellänge von  ).
  29. Siehe Stefan Brass (2005), S. 29; der Autor benutzt die Notation   statt  .   bezeichnet wie im einsortigen Fall die Stelligkeit von  , hier gegeben durch die (Wort-)länge des Typs  . Vereinfacht: ohne Überladung.
  30. Konstanten sind hier als nullstellige Funktionen aufgefasst. Ansonsten käme zum Wertebereich   von   noch ein weiterer Anteil   hinzu (dieser entspricht   im einsortigen Fall).
  31. Tatsächlich ist wegen der Disjunktheit von  ,   und   egal, ob man die einzelnen Abschnitte mit Komma oder   trennt. Ein Tupel von Familien mit disjunkten Indexmengen ist isomorph zu einer Familie mit der vereinigten Indexmange. In diesem Sinn ist die  -Struktur   bis auf Isomorphie identisch mit der Interpretationsfunktion (Familie)   oder mit  . Siehe auch Einschränkung, § Verträglichkeitsregeln.
  32. Werden die Variablen, die gemäß Deklaration   einer Sorte   zugeordnet sind, mit   bezeichnet (= Urbildfaser von   unter  ), dann ist die Einschränkung der Belegung   auf diese Variablen eine (ggf. partielle) Abbildung  
  33. alternative Bezeichnungen:  ,  
  34. A. Oberschelp (1989) Seite 11ff.
  35. Christoph Walter (1985)
  36. int steht für integer, Wertebereich ist  , für   einfach  . Siehe Folge, § Formale Definition: endliche Folgen.
  37. Umgekehrt wird in C bei der if-Abfrage jedes Argument ungleich 0 als wahr, und nur 0 als falsch gewertet.
  38. A. Oberschelp (1989/1990) Seite 11ff
  39. Steimann 1992, S. 5. Der Autor bezeichnet das Sortenalphabet als   mit Halbordnung  , die Symbolmenge mit   und die ordnungssortierte Signatur entsprechend mit  
  40. Gloede, Mengenlehre, 2004
  41. oder  ,  
  42. d. h. falls keine Überladung vorliegt ist  
  43. Oberschelp 1989/90 S. 14 f
  44. Smolka, Gert: Logic Programming over Polymorphically Order-Sorted Types. Universität Kaiserslautern, Mai 1989.
  45. Schmidt-Schauß, Manfred: Computational Aspects of an Order-Sorted Logic with Term Declarations (= LNAI. Band 395). Springer, April 1988.
  46. Siehe Parameter, § Unterschiedliche Parameter-Begriffe