Misplaced Pages

Omega language

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Theoretical computer science concept
This article includes a list of general references, but it lacks sufficient corresponding inline citations. Please help to improve this article by introducing more precise citations. (October 2015) (Learn how and when to remove this message)

In formal language theory within theoretical computer science, an infinite word is an infinite-length sequence (specifically, an ω-length sequence) of symbols, and an ω-language is a set of infinite words. Here, ω refers to the first infinite ordinal number, modeling a set of natural numbers.

Formal definition

Let Σ be a set of symbols (not necessarily finite). Following the standard definition from formal language theory, Σ is the set of all finite words over Σ. Every finite word has a length, which is a natural number. Given a word w of length n, w can be viewed as a function from the set {0,1,...,n−1} → Σ, with the value at i giving the symbol at position i. The infinite words, or ω-words, can likewise be viewed as functions from N {\displaystyle \mathbb {N} } to Σ. The set of all infinite words over Σ is denoted Σ. The set of all finite and infinite words over Σ is sometimes written Σ or Σ.

Thus an ω-language L over Σ is a subset of Σ.

Operations

Some common operations defined on ω-languages are:

Intersection and union
Given ω-languages L and M, both LM and LM are ω-languages.
Left concatenation
Let L be an ω-language, and K be a language of finite words only. Then K can be concatenated on the left, and only on the left, to L to yield the new ω-language KL.
Omega (infinite iteration)
As the notation hints, the operation ( ) ω {\displaystyle (\cdot )^{\omega }} is the infinite version of the Kleene star operator on finite-length languages. Given a formal language L, L is the ω-language of all infinite sequences of words from L; in the functional view, of all functions N L {\displaystyle \mathbb {N} \to L} .
Prefixes
Let w be an ω-word. Then the formal language Pref(w) contains every finite prefix of w.
Limit
Given a finite-length language L, an ω-word w is in the limit of L if and only if Pref(w) ∩ L is an infinite set. In other words, for an arbitrarily large natural number n, it is always possible to choose some word in L, whose length is greater than n, and which is a prefix of w. The limit operation on L can be written L or L {\displaystyle {\vec {L}}} .

Distance between ω-words

The set Σ can be made into a metric space by definition of the metric d : Σ ω × Σ ω R {\displaystyle d:\Sigma ^{\omega }\times \Sigma ^{\omega }\rightarrow \mathbb {R} } as:

d ( w , v ) = inf { 2 | x | x Σ   and   x Pref ( w ) Pref ( v ) } {\displaystyle d(w,v)=\inf\{2^{-|x|}\mid x\in \Sigma ^{*}\ {\text{and}}\ x\in {\text{Pref}}(w)\cap {\text{Pref}}(v)\}}

where |x| is interpreted as "the length of x" (number of symbols in x), and inf is the infimum over sets of real numbers. If w = v {\displaystyle w=v} then there is no longest prefix x and so d ( w , v ) = 0 {\displaystyle d(w,v)=0} . Symmetry is clear. Transitivity follows from the fact that if w and v have a maximal shared prefix of length m and v and u have a maximal shared prefix of length n then the first min { m , n } {\displaystyle \min\{m,n\}} characters of w and u must be the same so d ( w , u ) 2 min { m , n } 2 m + 2 n = d ( w , v ) + d ( v , u ) {\displaystyle d(w,u)\leq 2^{-\min\{m,n\}}\leq 2^{-m}+2^{-n}=d(w,v)+d(v,u)} . Hence d is a metric.

Important subclasses

The most widely used subclass of the ω-languages is the set of ω-regular languages, which enjoy the useful property of being recognizable by Büchi automata. Thus the decision problem of ω-regular language membership is decidable using a Büchi automaton, and fairly straightforward to compute.

If the language Σ is the power set of a set (called the "atomic propositions") then the ω-language is a linear time property, which are studied in model checking.

Bibliography

Categories: