标记系统
标记系统是 Emil Leon Post 在1943年创立的确定性计算模型,作为一种简单形式的字符串重写系统。
简介
标记系统也可以看作抽象机,叫做Post 标记机(不要混淆于Post-图灵机)——简单的说,其唯一的磁带是无限长度的FIFO队列的有限状态自动机,在每次状态转变中机器读在队列头部的符号,从头部删除固定数目的符号,并可以向尾部增加符号。
定义
标记系统是三元组 (m,A,P),这里的
• m是正数,叫做删除数。
• A是有限的符号字母表,其中一个是特殊的停机符号。在A上的有限的(可能空)字符串叫做字。
• P是产生规则的集合,指派一个字P(x)(叫做产品)到A中的每个符号x。指派给停机符号的产品(就是P(H))在下面会看到在计算中没有扮演任何角色,但是出于方便采用P(H)='H'。
术语m-标记系统经常用来强调删除数。定义在文献 有着不同,上面的定义(来自)可能最适合作为计算模型:
• 停机字是要么开始于停机符号要么长度小于m的字。
• 变换t定义在非停机字上,使得如果x指示一个字S的最左符号,则t(S) 是删除S的最左的m符号并添加字P(x)到右边。
• 标记系统做的计算是重复变换t所产生的字的有限序列,开始于初始给定的字并在产生停机字的时候停机。(计算不被认为要退出,除非在有限多重复中生成停机字。)
对于每个m\u003e 1,m-标记系统的集合是艾伦·麦席森·图灵完全的。特别是,Rogozhin 建立了 2-标记系统普遍性的类,使用字母表 {a, ...,a,H} 和相应的产品 {aaW, ...,aaW,aa,H},这里的W是非空字。
注意不像标记系统的某些可替代的定义那样,当前的定义中一个计算的“输出”可以编码在最终的字中。
例子
2-标记系统
字母表: {a,b,c,H}
产生规则: a --\u003e ccbaH b --\u003e cca c --\u003e cc
计算
初始字: baa
acca
caccbaH
ccbaHcc
baHcccc
Hcccccca (停机)。