Pattern language (formal languages)
In theoretical computer science, a pattern language is a formal language that can be defined as the set of all particular instances of a string of constants and variables. Pattern Languages were introduced by Dana Angluin in the context of machine learning.[1]
Definition
Given a finite set Σ of constant symbols and a countable set X of variable symbols disjoint from Σ, a pattern is a finite non-empty string of symbols from Σ∪X. The length of a pattern p, denoted by |p|, is just the number of its symbols. The set of all patterns containing exactly n distinct variables (each of which may occur several times) is denoted by Pn, the set of all patterns at all by P*. A substitution is a mapping f: P* → P* such that[note 1]
- f is a homomorphism with respect to string concatenation (⋅), formally: ∀p,q∈P*. f(p⋅q) = f(p)⋅f(q);
- f is non-erasing, formally: ∀p∈P*. f(p) ≠ ε, where ε denotes the empty string; and
- f respects constants, formally: ∀s∈Σ. f(s) = s.
If p = f(q) for some patterns p, q ∈ P* and some substitution f, then p is said to be less general than q, written p≤q; in that case, necessarily |p| ≥ |q| holds. For a pattern p, its language is defined as the set of all less general patterns that are built from constants only, formally: L(p) = { s ∈ Σ+ : s ≤ p }, where Σ+ denotes the set of all finite non-empty strings of symbols from Σ.
For example, using the constants Σ = { 0, 1 } and the variables X = { x, y, z, ... }, the pattern 0x10xx1 ∈P1 and xxy ∈P2 has length 7 and 3, respectively. An instance of the former pattern is 00z100z0z1 and 01z101z1z1, it is obtained by the substitution that maps x to 0z and to 1z, respectively, and each other symbol to itself. Both 00z100z0z1 and 01z101z1z1 are also instances of xxy. In fact, L(0x10xx1) is a subset of L(xxy). The language of the pattern x0 and x1 is the set of all bit strings which denote an even and odd number, respectively. The language of xx is the set of all strings obtainable by concatenating a bit string with itself, e.g. 00, 11, 0101, 1010, 11101110 ∈ L(xx).
Properties
|
The problem of deciding whether s ∈ L(p) for an arbitrary string s ∈ Σ+ and pattern p is NP-complete (see picture), and so is hence the problem of deciding p ≤ q for arbitrary patterns p, q.[2]
The class of pattern languages is not closed under ...
- union: e.g. for Σ = {0,1} as above, L(01)∪L(10) is not a pattern language;
- complement: Σ+ \ L(0) is not a pattern language;
- intersection: L(x0y)∩L(x1y) is not a pattern language;
- Kleene plus: L(0)+ is not a pattern language;
- homomorphism: f(L(x)) = L(0)+ is not a pattern language, assuming f(0) = 0 = f(1);
- inverse homomorphism: f−1(111) = { 01, 10, 000 } is not a pattern language, assuming f(0) = 1 and f(1) = 11.
The class of pattern languages is closed under ...
- concatenation: L(p)⋅L(q) = L(p⋅q);
- reversal: L(p)rev = L(prev).[3]
If p, q ∈ P1 are patterns containing exactly one variable, then p ≤ q if and only if L(p) ⊆ L(q); the same equivalence holds for patterns of equal length.[4] For patterns of different length, the above example p = 0x10xx1 and q = xxy shows that L(p) ⊆ L(q) may hold without implying p ≤ q. However, any two patterns p and q, of arbitrary lengths, generate the same language if and only if they are equal up to consistent variable renaming.[5] Each pattern p is a common generalization of all strings in its generated language L(p), modulo associativity of (⋅).
Location in the Chomsky hierarchy
In a refined Chomsky hierarchy, the class of pattern languages is a proper superclass and subclass of the singleton[note 2] and the indexed languages, but incomparable to the language classes in between; due to the latter, the pattern language class is not explicitly shown in the table below.
The class of pattern languages is incomparable with the class of finite languages, with the class of regular languages, and with the class of context-free languages:
- the pattern language L(xx) is not context-free (hence neither regular nor finite) due to the pumping lemma;
- the finite language { 01, 10 } is not a pattern language.
Each singleton language is trivially a pattern language, generated by a pattern without variables.
Each pattern language can be produced by an indexed grammar: For example, using Σ = { a, b, c } and X = { x, y }, the pattern a x b y c x a y b is generated by a grammar with nonterminal symbols N = { Sx, Sy, S } ∪ X, terminal symbols T = Σ, index symbols F = { ax, bx, cx, ay, by, cy }, start symbol Sx, and the following production rules:
Sx[σ] | → Sx[ax σ] | | Sx[bx σ] | | Sx[cx σ] | | Sy[σ] |
Sy[σ] | → Sy[ay σ] | | Sy[by σ] | | Sy[cy σ] | | S[σ] |
S[σ] | → a x[σ] b y[σ] c x[σ] a y[σ] b |
x[ax σ] | → a | x[σ] | y[ax σ] | → | y[σ] |
x[bx σ] | → b | x[σ] | y[bx σ] | → | y[σ] |
x[cx σ] | → c | x[σ] | y[cx σ] | → | y[σ] |
x[ay σ] | → | x[σ] | y[ay σ] | → a | y[σ] |
x[by σ] | → | x[σ] | y[by σ] | → b | y[σ] |
x[cy σ] | → | x[σ] | y[cy σ] | → c | y[σ] |
x[] | → ε | y[] | → ε |
An example derivation is:
Sx[] ⇒ Sx[bx] ⇒ Sx[ax bx] ⇒ Sy[ax bx] ⇒ Sy[cy ax bx] ⇒ S[cy ax bx] ⇒ a x[cy ax bx] b y[cy ax bx] c x[cy ax bx] a y[cy ax bx] b ⇒ a x[ax bx] b y[cy ax bx] c x[cy ax bx] a y[cy ax bx] b ⇒ a a x[bx] b y[cy ax bx] c x[cy ax bx] a y[cy ax bx] b ⇒ a ab x[] b y[cy ax bx] c x[cy ax bx] a y[cy ax bx] b ⇒ a ab b y[cy ax bx] c x[cy ax bx] a y[cy ax bx] b ⇒ ... ⇒ a ab b c y[] c x[cy ax bx] a y[cy ax bx] b ⇒ a ab b c c x[cy ax bx] a y[cy ax bx] b ⇒ ... ⇒ a ab b c c ab x[] a y[cy ax bx] b ⇒ a ab b c c ab a y[cy ax bx] b ⇒ ... ⇒ a ab b c c ab a c y[] b ⇒ a ab b c c ab a c b
In a similar way, an index grammar can be constructed from any pattern.
Learning patterns
Given a sample set S of strings, a pattern p is called descriptive of S if S ⊆ L(p), but not S ⊆ L(q) ⊂ L(p) for any other pattern q.
Given any sample set S, a descriptive pattern for S can be computed by
- enumerating all patterns (up to variable renaming) not longer than the shortest string in S,
- selecting from them the patterns that generate a superset of S,
- selecting from them the patterns of maximal length, and
- selecting from them a pattern that is minimal with respect to ≤.[6]
Based on this algorithm, the class of pattern languages can be identified in the limit from positive examples.[7]
Notes
- ↑ Angluin's notion of substitution differs from the usual notion of string substitution.
- ↑ i.e. languages consisting of a single string; they correspond to straight-line grammars
References
- ↑ Dana Angluin (1980). "Finding Patterns Common to a Set of Strings" (PDF). Journal of Computer and System Sciences. 21: 46–62. doi:10.1016/0022-0000(80)90041-0.
- ↑ Theorem 3.6, p.50; Corollary 3.7, p.52
- ↑ Theorem 3.10, p.53
- ↑ Lemma 3.9, p.52; Corollary 3.4, p.50
- ↑ Theorem 3.5, p.50
- ↑ Theorem 4.1, p.53
- ↑ Dana Angluin (1980). "Inductive Inference of Formal Languages from Positive Data" (PDF). Information and Control. 45: 117–135. doi:10.1016/s0019-9958(80)90285-5.; here: Example 1, p.125