Alternation (formal language theory): Difference between revisions
ce |
typo |
||
(5 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
In [[formal language|formal language theory]] and [[pattern matching]], '''alternation''' is the [[union (set theory)|union]] of two sets of strings or |
In [[formal language|formal language theory]] and [[pattern matching]], '''alternation''' is the [[union (set theory)|union]] of two sets of strings, or equivalently the [[logical disjunction]] of two patterns describing sets of strings. |
||
[[Regular language]]s are [[Regular language#Closure properties|closed]] under alternation, meaning that the alternation of two regular languages is again regular.<ref>{{cite book|title=An Introduction to Formal Languages and Automata|first=Peter|last=Linz|publisher=Jones & Bartlett Learning|year=2006|isbn=9780763737986|contribution=Theorem 4.1|pages=100–101|contribution-url=https://books.google.com/books?id=KOo4NpfTEAIC&pg=PA100}}</ref> In [[regular expression]]s, alternation is often expressed with a vertical bar connecting the expressions for the two languages whose union is to be matched |
[[Regular language]]s are [[Regular language#Closure properties|closed]] under alternation, meaning that the alternation of two regular languages is again regular.<ref name=linz>{{cite book|title=An Introduction to Formal Languages and Automata|first=Peter|last=Linz|publisher=Jones & Bartlett Learning|year=2006|isbn=9780763737986|contribution=Theorem 4.1|pages=100–101|contribution-url=https://books.google.com/books?id=KOo4NpfTEAIC&pg=PA100}}</ref> In implementations of [[regular expression]]s, alternation is often expressed with a vertical bar connecting the expressions for the two languages whose union is to be matched,<ref>{{cite book|title=Introducing Regular Expressions: Unraveling Regular Expressions, Step-by-Step|first=Michael|last=Fitzgerald|publisher=O'Reilly Media|year=2012|isbn=9781449338893|contribution=Alternation|pages=43–45|contribution-url=https://books.google.com/books?id=mzNo2e_1WD8C&pg=PA43}}</ref><ref>{{cite web|url=https://www.regular-expressions.info/alternation.html|title=Alternation with The Vertical Bar|website=regular-expressions.info|accessdate=2021-11-11}}</ref> while in more theoretical studies the [[plus sign]] may instead be used for this purpose.<ref name=linz/> The ability to construct [[finite automaton|finite automata]] for unions of two regular languages that are themselves defined by finite automata is central to the equivalence between regular languages defined by automata and by regular expressions.<ref>{{cite book|title=Engineering a Compiler|first1=Keith|last1=Cooper|first2=Linda|last2=Torczon|edition=2nd|publisher=Elsevier|year=2011|isbn=9780080916613|page=41|url=https://books.google.com/books?id=_tgh4bgQ6PAC&pg=PA41}}</ref> |
||
Other classes of languages that are closed under alternation include [[context-free language]]s and [[recursive language]]s. |
|||
⚫ | |||
The vertical bar notation for alternation is used in the [[SNOBOL]] language and some other languages. |
|||
⚫ | |||
== References == |
== References == |
Latest revision as of 20:53, 11 November 2021
In formal language theory and pattern matching, alternation is the union of two sets of strings, or equivalently the logical disjunction of two patterns describing sets of strings.
Regular languages are closed under alternation, meaning that the alternation of two regular languages is again regular.[1] In implementations of regular expressions, alternation is often expressed with a vertical bar connecting the expressions for the two languages whose union is to be matched,[2][3] while in more theoretical studies the plus sign may instead be used for this purpose.[1] The ability to construct finite automata for unions of two regular languages that are themselves defined by finite automata is central to the equivalence between regular languages defined by automata and by regular expressions.[4]
Other classes of languages that are closed under alternation include context-free languages and recursive languages. The vertical bar notation for alternation is used in the SNOBOL language and some other languages. In formal language theory, alternation is commutative and associative. This is not in general true of the form of alternation used in pattern-matching languages, because of the side-effects of performing a match in those languages.
References
[edit]- ^ a b Linz, Peter (2006). "Theorem 4.1". An Introduction to Formal Languages and Automata. Jones & Bartlett Learning. pp. 100–101. ISBN 9780763737986.
- ^ Fitzgerald, Michael (2012). "Alternation". Introducing Regular Expressions: Unraveling Regular Expressions, Step-by-Step. O'Reilly Media. pp. 43–45. ISBN 9781449338893.
- ^ "Alternation with The Vertical Bar". regular-expressions.info. Retrieved 2021-11-11.
- ^ Cooper, Keith; Torczon, Linda (2011). Engineering a Compiler (2nd ed.). Elsevier. p. 41. ISBN 9780080916613.
Bibliography
[edit]- John E. Hopcroft and Jeffrey D. Ullman, Introduction to Automata Theory, Languages and Computation, Addison-Wesley Publishing, Reading Massachusetts, 1979. ISBN 0-201-02988-X.