Denotationelle Semantik - LinkFang.de





Denotationelle Semantik


Die denotationelle Semantik (Funktionensemantik) ist in der Theoretischen Informatik eine von mehreren Möglichkeiten, eine formale Semantik für eine formale Sprache zu definieren. Die formale Sprache dient hierbei als mathematisches Modell für eine echte Programmiersprache. Somit kann die Wirkungsweise eines Computerprogramms formal beschrieben werden.

Konkret kann man etwa bei einer gegebenen Belegung für Eingabevariablen das Endergebnis für eine Menge von Ausgabevariablen mit der denotationellen Semantik berechnen. Es sind auch allgemeinere Korrektheitsbeweise möglich.

Bei der denotationellen Semantik werden partielle Funktionen verwendet, die Zustandsräume aufeinander abbilden. Ein Zustand ist hier eine Belegung von Variablen mit konkreten Werten. Die denotationelle Semantik wird induktiv über die syntaktischen Anweisungskonstrukte der formalen Sprache definiert. Abhängig von der gewünschten Programmsemantik werden die partiellen Funktionen gewählt.

Neben der denotationellen Semantik gibt es auch die operationelle Semantik und die axiomatische Semantik, um die Semantik von formalen Sprachen zu beschreiben.

Definition der semantischen Funktion f

Sei [math]\mathcal{Z}[/math] die Menge aller möglichen Zustände. Die Wirkung, die eine Anweisung [math]\ A[/math] auf einen Zustand hat, ist formal gesprochen eine Abbildung

[math]f[A]\colon\mathcal{Z}\rightarrow\mathcal{Z}[/math],

die einem Zustand [math]z\in\mathcal{Z}[/math] einen Folgezustand [math]z'\in\mathcal{Z}[/math] zuordnet.

[math]\ f[/math] bezeichnet die semantische Funktion und ordnet jedem Anweisungskonstrukt eine Bedeutung zu, indem sie eine Zustandsänderung des Programms bewirkt.

Nachfolgend wird die Wirkung der wichtigsten Kontrollstrukturen einer Programmiersprache auf einen Zustand untersucht.

  • Die Bedeutung der leeren Anweisung [math]\ null[/math]:
[math]f[null](z)\ =\ z[/math].
Die leere Anweisung, angewendet auf einen Zustand [math]\ z[/math], verändert den Zustand nicht.
  • Die Semantik einer Anweisungsfolge kann folgendermaßen beschrieben werden:
[math]f[A_1,A_2](z)\ =\ f[A_2](f[A_1](z))[/math].
Die Bedeutung dieser Befehlssequenz ist die Wirkung von [math]\ A_2[/math] angewendet auf den Zustand, der sich ergibt, nachdem [math]\ A_1[/math] auf [math]\ z[/math] ausgeführt wurde.
  • Für die Wirkung einer Zuweisung auf einen Zustand gilt:
[math]f[x:=E](z)\ =\ \begin{cases} \bot, &\mathrm{wenn}\ [E](z)=\bot \\ z', &\mathrm{sonst} \end{cases} [/math]
Das Programm terminiert nicht ([math]\ \bot[/math]), wenn die Anweisung (oder der Ausdruck) [math]\ [E][/math] angewendet auf Zustand [math]\ z[/math] nicht terminiert. In allen anderen Fällen geht das Programm in einen Zustand [math]\ z'[/math] über.
  • Für die zwei-seitige Alternative gilt:
[math]f[if\ B\ then\ C_1\ else\ C_2](z)= \begin{cases} f[C_1](z), & \mathrm{wenn}\ B[z] = true \\ f[C_2](z), & \mathrm{wenn}\ B[z]=false \\ \bot, &\mathrm{sonst} \end{cases}[/math].
Der Folgezustand entspricht [math]\ [C_1][/math] angewendet auf [math]\ z[/math], wenn [math]\ B[z]=true[/math]. Wenn [math]\ B[z]=false[/math], so wird der nachfolgende Zustand durch [math]\ [C_2][/math] angewendet auf [math]\ z[/math] bestimmt. In allen anderen Fällen terminiert das Programm nicht.
  • Die Bedeutung der Wiederholung definiert sich rekursiv zu:
[math]f[while\ B\ do\ L](z)=\begin{cases} z, &\mathrm{wenn}\ [B](z)=false \\ \bot, &\mathrm{wenn}\ [B](z)=\bot\ \or\ [L](z)=\bot \\ f[while\ B\ do\ L]([L](z)), &\mathrm{sonst}\end{cases}[/math].
Falls [math]\ [B](z)=false[/math], so bewirkt die While-Anweisung keine Zustandsänderung.
Wenn [math]\ [B](z)=\bot[/math] oder [math]\ [L](z)=\bot[/math], so terminiert das gesamte Programm nicht.
In allen anderen Fällen wird erneut die Wiederholungsanweisung [math]\ [while\ B\ do\ L][/math] auf den Zustand angewendet, der sich nach Ausführung von [math]\ [L](z)[/math] ergibt.
Durch diese rekursive Definition kann man nicht auf die Wirkung dieser Anweisung schließen. Man ist daher am Fixpunkt der Funktion interessiert, der die Semantik der While-Schleife beschreibt.

Fixpunkt der While-Semantik

Der Fixpunkt der Funktion, die die Semantik der While-Schleife beschreibt, wird nachfolgend anhand eines einfachen Beispiels erläutert.

[math]\ while\ x\not=y\ do\ y:=y+1[/math]
Solange [math]x[/math] ungleich [math]y[/math], wird der Wert der Variablen [math]y[/math] um 1 erhöht.

Um den Fixpunkt dieser Gleichung zu bestimmen, bedient man sich des Tarskischen Fixpunktsatzes. Dieser Satz besagt, dass für eine geordnete Menge [math]\ \mathcal{M}[/math], welche ein kleinstes Element besitzt, und eine streng monotone Funktion, welche [math]\ \mathcal{M}[/math] auf sich selbst abbildet, ein kleinster Fixpunkt existiert.

Damit der Satz angewendet werden kann, muss zuerst eine geordnete Menge für das Beispiel definiert werden.

Sei [math]w\colon(\mathbb{Z}\times\mathbb{Z})\rightarrow(\mathbb{Z}\times\mathbb{Z})[/math] die partielle Funktion der While-Schleife aus dem Beispiel. Diese bildet einen Zustand, bestehend aus der Belegung [math](x,y)[/math] für die gleichnamigen Variablen, in einen anderen Zustand mit der Variablenbelegung [math](x',y')[/math] ab. Die Variablen [math]x[/math] und [math]y[/math] sind dabei ganzzahlig.

Sei nun [math]\mathcal{P}_{(\mathbb{Z}\times\mathbb{Z})}[/math] die Menge aller partiellen Funktionen [math]\ w[/math].

Die partielle Ordnung [math]\sqsubseteq [/math] für zwei partielle Funktionen [math]\ w[/math], [math]\ w' \in \mathcal{P}_{(\mathbb{Z}\times\mathbb{Z})}[/math] sei wie folgt definiert:

[math]\ w \sqsubseteq w' \Leftrightarrow \operatorname{dom}(w) \subseteq \operatorname{dom}(w') \wedge (w(x,y)=(x',y') \Rightarrow w'(x,y)=(x',y'))[/math].

Die partielle Abbildung [math]\ w[/math] ist kleiner/gleich [math]\ w'[/math] genau dann, wenn der Definitionsbereich von [math]\ w[/math] eine Teilmenge des Definitionsbereichs von [math]\ w'[/math] ist. Zudem muss gelten, dass wenn [math]\ w(x,y)[/math] eine Zustandsänderung nach [math]\ (x',y')[/math] bewirkt, auch Funktion [math]\ w'(x,y)[/math] nach [math]\ (x',y')[/math] abbildet.

Das kleinste Element der Menge [math]\mathcal{P}_{(\mathbb{Z}\times\mathbb{Z})}[/math] ist die nirgends definierte Funktion [math]\bot[/math].

Um den Satz von Tarski verwenden zu können, fehlt nun noch eine streng monotone Funktion, die [math]\mathcal{P}_{(\mathbb{Z}\times\mathbb{Z})}[/math] auf sich selbst abbildet. Dazu wird eine Funktion [math]\ f[/math] definiert:

[math]\ f\colon\mathcal{P}_{(\mathbb{Z}\times\mathbb{Z})}\rightarrow \mathcal{P}_{(\mathbb{Z}\times\mathbb{Z})}[/math].

Laut obigen Beispiel gilt für [math]\ f[/math]:

[math]\ f(w)(x,y)=\begin{cases}(x,y), &\mathrm{wenn}\ x=y \\ w(x,y+1), &\mathrm{sonst} \end{cases}[/math].

Weiterhin sei:

[math]\ w_{n+1}=f(w_n)\ \forall n\isin\mathbb{N}[/math].

Nun sind alle Voraussetzungen des Fixpunktsatzes erfüllt, es existiert ein Fixpunkt.

Den Fixpunkt berechnet man durch Grenzwertbildung der Funktion [math]\ f[/math].

Um auf den Grenzwert schließen zu können, beginnt man mit dem Ausrechnen einzelner Funktionswerte.

  • [math]\ w_0(x,y)= \bot[/math], da [math]\ w_0[/math] das kleinste Element der Menge [math]\mathcal{P}_{(\mathbb{Z}\times\mathbb{Z})}[/math] ist.
  • [math]\ w_1(x,y)[/math] ist laut Definition der Funktion [math]\ f[/math]:
[math]\ w_1(x,y)=f(w_0)(x,y)=\begin{cases}(x,y),&\mathrm{wenn}\ x=y \\ w_0(x,y+1)=\bot,&\mathrm{sonst}\end{cases}[/math].
  • [math]\ w_2(x,y)[/math] ergibt sich zu:
[math]\ w_2(x,y)=f(w_1)(x,y)=\begin{cases}(x,y),&\mathrm{wenn}\ x=y \\ w_1(x,y+1)=\begin{cases}(x,y+1),&\mathrm{wenn}\ x=y+1 \\ \bot,&\mathrm{sonst} \end{cases}\end{cases}[/math].
  • Für [math]\ w_n[/math] kann formuliert werden:
[math]\ w_n(x,y)=f(w_{n-1})(x,y)=\begin{cases}(x,x),&\mathrm{wenn}\ x-(n-1) \le y \le x \\ \bot,& \mathrm{sonst}\end{cases}[/math].

Der Grenzwert [math]\ w_{\infty} = w_n \ \forall \ n \isin \mathbb{N}[/math] sei nun:

[math]w_{\infty}(x,y)=\begin{cases}(x,x),&\mathrm{wenn}\ -\infty \le y \le x \\ \bot,& \mathrm{sonst}\end{cases}[/math].

Für den Fixpunkt muss nun gelten, dass [math]\ f(w_{\infty})(x,y)=w_{\infty}(x,y)[/math].

[math]\ f(w_{\infty})(x,y)=\begin{cases}(x,y),&\mathrm{wenn} \ x=y \\ w_{\infty}(x,y+1)= \begin{cases}(x,x), &\mathrm{wenn}\ -\infty \le y \lt x \\ \bot,&\mathrm{sonst}\end{cases}\end{cases}[/math].

Dies kann umgeformt werden zu:

[math]\ f(w_{\infty})(x,y)=\begin{cases}(x,x), &\mathrm{wenn}\ -\infty \le y \le x \\ \bot,&\mathrm{sonst}\end{cases}[/math].

Somit gilt [math]\ f(w_{\infty})(x,y)=w_{\infty}(x,y)[/math]. Der Fixpunkt ist gefunden. Die Bedeutung der While-Schleife aus dem Beispiel ergibt sich aus dem Fixpunkt. Die Schleife terminiert, wenn [math]\ y \le x[/math], und liefert das Tupel [math]\ (x,x)[/math]. Falls [math]\ y \gt x[/math], so terminiert die Schleife nicht.es:Semántica denotacional


Kategorien: Theoretische Informatik

Quelle: Wikipedia - http://de.wikipedia.org/wiki/Denotationelle Semantik (Vollständige Liste der Autoren des Textes [Versionsgeschichte])    Lizenz: CC-by-sa-3.0

Änderungen: Alle Bilder mit den meisten Bildunterschriften wurden entfernt. Ebenso alle zu nicht-existierenden Artikeln/Kategorien gehenden internen Wikipedia-Links (Bsp. Portal-Links, Redlinks, Bearbeiten-Links). Entfernung von Navigationsframes, Geo & Normdaten, Mediadateien, gesprochene Versionen, z.T. ID&Class-Namen, Style von Div-Containern, Metadaten, Vorlagen, wie lesenwerte Artikel. Ansonsten sind keine Inhaltsänderungen vorgenommen worden. Weiterhin kann es durch die maschinelle Bearbeitung des Inhalts zu Fehlern gerade in der Darstellung kommen. Darum würden wir jeden Besucher unserer Seite darum bitten uns diese Fehler über den Support mittels einer Nachricht mit Link zu melden. Vielen Dank!

Stand der Informationen: August 201& - Wichtiger Hinweis: Da die Inhalte maschinell von Wikipedia übernommen wurden, ist eine manuelle Überprüfung nicht möglich. Somit garantiert LinkFang.de nicht die Richtigkeit und Aktualität der übernommenen Inhalte. Sollten die Informationen mittlerweile fehlerhaft sein, bitten wir Sie darum uns per Support oder E-Mail zu kontaktieren. Wir werden uns dann innerhalb von spätestens 10 Tagen um Ihr Anliegen kümmern. Auch ohne Anliegen erfolgt mindestens alle drei Monate ein Update der gesamten Inhalte.