Reguläre Sprache

Aus testwiki
Zur Navigation springen Zur Suche springen

In der theoretischen Informatik ist eine reguläre Sprache oder reguläre Menge oder erkennbare Sprache eine formale Sprache, die einigen Einschränkungen unterliegt. Reguläre Sprachen können von endlichen Automaten erkannt werden und von regulären Ausdrücken beschrieben werden.

Eigenschaften

Die Klasse der regulären Sprachen hat in der Informatik eine große praktische Bedeutung. Sie bildet eine echte Teilmenge der kontextfreien Sprachen. Die Klasse der regulären Sprachen entspricht innerhalb der Chomsky-Hierarchie der am meisten eingeschränkten Sprachklasse vom Typ 3.

Definition

Eine Sprache L über einem Alphabet Σ, also eine Menge von Wörtern LΣ*, heißt dann regulär, wenn sie eine der folgenden äquivalenten Bedingungen erfüllt:

Nachweis der Regularität einer Sprache

Will man für eine gegebene Sprache nachweisen, dass sie regulär ist, so muss man sie demnach auf eine reguläre Grammatik, einen endlichen Automaten, einen regulären Ausdruck oder auf bereits bekannte reguläre Sprachen zurückführen. Für einen Nachweis, dass eine Sprache L nicht regulär ist, ist es meistens zweckmäßig, das Pumping-Lemma (= Pumplemma) für reguläre Sprachen zu benutzen oder in schwierigeren Fällen nachzuweisen, dass der Index von RL nicht endlich ist.

Beispiele

  • {aibji,j} ist regulär.
  • Alle endlichen Sprachen L über einem beliebigen Alphabet Σ, d. h. solche mit |L|, sind regulär.
    • Beispiel: {a,ab}
    • Auch die leere Menge ist eine reguläre Sprache.
  • Alle kontextfreien Sprachen über einem unären Alphabet, d. h. solche mit |Σ|=1, sind regulär.
  • Die Dyck-Sprachen sind nicht regulär.

Abschlusseigenschaften

Die Klasse der regulären Sprachen ist abgeschlossen unter den gewöhnlichen Mengenoperationen Vereinigung, Durchschnitt und Komplement. Darüber hinaus gilt die Abgeschlossenheit auch für die Konkatenation und den sogenannten Kleene-Stern sowie die Differenzmenge. Im Einzelnen gilt also:

  • Die Vereinigung L=L1L2 zweier regulärer Sprachen L1 und L2 ist regulär.
  • Der Schnitt L=L1L2 zweier regulärer Sprachen L1 und L2 ist regulär.
  • Das Komplement L=Σ*L einer regulären Sprache L ist regulär.
  • Die Konkatenation {uvuL1vL2} zweier regulärer Sprachen L1 und L2 ist regulär.
  • Der Kleene-Stern L* einer regulären Sprache L, d. h. die beliebig häufige Konkatenation von Wörtern aus der Sprache L vereinigt mit dem leeren Wort, ist regulär.
  • Die Differenz L=L1L2 zweier regulärer Sprachen L1 und L2 ist regulär.[1]

Typische Entscheidungsprobleme

Seien L, L1 und L2 gegebene reguläre Sprachen über dem Alphabet Σ. Dann ergeben sich folgende typische Problemstellungen:

Alle diese Probleme sind entscheidbar.

Literatur

  • Michael Sipser: Introduction to the Theory of Computation. PWS Publishing, Boston u. a. 1997, ISBN 0-534-94728-X, Chapter 1: Regular Languages.
  • Uwe Schöning: Theoretische Informatik – kurzgefasst. 4. Auflage. Spektrum, Heidelberg u. a. 2001, ISBN 3-8274-1099-1, (Spektrum-Hochschultaschenbuch), Kapitel 1.2: Reguläre Sprachen.
  • John E. Hopcroft, Rajeev Motwani, Jeffrey D. Ullman: Einführung in die Automatentheorie. Formale Sprachen und Komplexitätstheorie. 2. überarbeitete Auflage. Pearson Studium, München 2002, ISBN 3-8273-7020-5, (i – Informatik).
  • Vorlage:Literatur

Einzelnachweise und Anmerkungen

  1. Das ergibt sich schon aus den Abschlusseigenschaften von Schnitt und Komplement, da L1L2=L1L2 ist.