Categories
  Encyclosphere.org ENCYCLOREADER
  supported by EncyclosphereKSF

Cyclic language

From HandWiki - Reading time: 2 min

In computer science, more particularly in formal language theory, a cyclic language is a set of strings that is closed with respect to repetition, root, and cyclic shift.

Definition

If A is a set of symbols, and A* is the set of all strings built from symbols in A, then a string set LA* is called a formal language over the alphabet A. The language L is called cyclic if

  1. wA*. ∀n>0. wLwnL, and
  2. v,wA*. vwLwvL,

where wn denotes the n-fold repetition of the string w, and vw denotes the concatenation of the strings v and w.[1]:Def.1

Examples

For example, using the alphabet A = {a, b }, the language

L = { apbn1 an2bn2 ... ankbnk aq : ni ≥ 0 and p+q = n1 }
{ bp an1bn1 an2bn2 ... ank bq : ni ≥ 0 and p+q = nk }

is cyclic, but not regular.[1]:Exm.2 However, L is context-free, since M = { an1bn1 an2bn2 ... ank bnk : ni ≥ 0 } is, and context-free languages are closed under circular shift; L is obtained as circular shift of M.

References

  1. 1.0 1.1 Marie-Pierre Béal and Olivier Carton and Christophe Reutenauer (1996). "Cyclic Languages and Strongly Cyclic Languages". Proc. Symposium on Theoretical Aspects of Computer Science. Lecture Notes in Computer Science. 1046. Springer. pp. 49–59. http://www.lacim.uqam.ca/~christo/Publi%C3%A9s/1996/Strongly%20cyclic%20languages.pdf. 




Licensed under CC BY-SA 3.0 | Source: https://handwiki.org/wiki/Cyclic_language
5 views | Status: cached on September 20 2024 09:43:13
↧ Download this article as ZWI file
Encyclosphere.org EncycloReader is supported by the EncyclosphereKSF