形式语言自动机——图灵机(一).ppt
《形式语言自动机——图灵机(一).ppt》由会员分享,可在线阅读,更多相关《形式语言自动机——图灵机(一).ppt(31页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1School of Computer Science&Technology,BUPT第五章第五章 图灵机图灵机A.Turing在1936年 介绍了这样一个通用的计算模型,该模型具有以下两个性质n该模型的每个过程都是有穷可描述的;n过程必须是由离散的、可以机械执行的步骤组成。图灵机是计算机的一种简单数字模型,尽管简单,但它具有模拟通用计算机的计算能力。n通过研究TM来研究递归可枚举集和部分递归函数n为算法和可计算性研究提供了形式化描述工具。2School of Computer Science&Technology,BUPT主要内容主要内容nTM的基本定义nTM的格局nTM接受的语言nTM的构
2、造技术nTM的变形;n重点:TM的定义、TM的构造。n难点:TM的构造。3School of Computer Science&Technology,BUPTFinitecontrolX1BB.X2XnXi带(带(tape)单元格(单元格(cell)带符(带符(tape symbol)n 读写头在每一时刻扫描带上的一个单元读写头在每一时刻扫描带上的一个单元n 带有一个最左单元,向右则是无限的。带有一个最左单元,向右则是无限的。n 带的每个单元可容纳一个带符号带的每个单元可容纳一个带符号开始时,最左边开始时,最左边n个单元装着输入(个单元装着输入(n0,n为有限数),它是为有限数),它是一个字符
3、串,符号都选自一个字符串,符号都选自“带符号带符号”的一个子集,即所谓的的一个子集,即所谓的“输输入符号集合入符号集合”。余下的有穷个单元都存放空白符,它是一个特殊。余下的有穷个单元都存放空白符,它是一个特殊的带符号,但的带符号,但不是不是输入符号。输入符号。图灵机的基本模型4School of Computer Science&Technology,BUPT在在一一个个图灵灵机机的的动作作中中,图灵灵机机根根据据带头(读写写头)所)所扫描的符号和有限控制器的状描的符号和有限控制器的状态可能作可能作n改变状态n在被扫描的带单元上重新写一个符号,以代替原来写在该单元上的符号.n将带头向左或者右移
4、一个单元。*图灵灵机机和和双双向向有有限限自自动机机的的区区别:图灵灵机机能能改改变它它带上的符号。上的符号。图灵机的工作机制5School of Computer Science&Technology,BUPT图灵机的形式化描述图灵机的形式化描述 有限状态集 有限输入符号集 有限带符号集 转移函数 开始状态 特殊带符:空白符 终态集合q0 Q T B T F Q转移函数转移函数 :Q Q L,R 形式定义形式定义 一个图灵机一个图灵机 TM(Turing machine)是一个七元组是一个七元组 M=(Q,T,q0,B,F).6School of Computer Science&Techn
5、ology,BUPTn函数示例:函数示例:Q Q Q QL,RL,R(q,a(q,ai i)=(p,B,L)q,p Q)=(p,B,L)q,p Q (q,a (q,ai i)=(p,b,R)a)=(p,b,R)ai i b b n格局格局用w1q w2描述图灵机的瞬间工作状态q为M的当前状态,w1w2*w1w2是当前时刻从开始端(因为可写)到右边空白符号为止的内容当读写头已达到带的右端,则w1w2为读写头以左的内容。约定:定:w w1 1q wq w2 2表示表示读写写头正正扫描描w w2 2的最左字符的最左字符w w2 2 则则表示表示读读写写头头正正扫扫描一个空白字符。描一个空白字符。图灵
6、机的函数与格局7School of Computer Science&Technology,BUPT图灵机的格局图灵机的格局 给定图灵机给定图灵机 M=(Q,T,q0,B,F),定义格局之间定义格局之间的推导关系的推导关系M 如下:如下:1.设设 (q,Xi)=(p,Y,L),则有则有 X1X2Xi-1qXiXi+1Xn M X1X2Xi-2pXi-1YXn,但有如下两个例外但有如下两个例外:(1)i=1时,时,qX1X2Xn M qYX2Xn,和和 (2)i=n及及 Y=B 时,时,X1X2Xn-1qXn M X1X2Xn-2pXn-1 B.2.设设 (q,Xi)=(p,Y,R),则有则有
7、X1X2Xi-1 q XiXi+1Xn M X1X2Xi-1Y p Xi+1Xn,但有如下两个例外但有如下两个例外:(1)i=n时,时,X1X2Xn-1q Xn M X1X2Xn-1Y p B,和和 (2)i=1及及 Y=B 时,时,q X1X2XnM B p X2Xn-1Xn.8School of Computer Science&Technology,BUPT图灵机接受的语言图灵机接受的语言L(M)=TT*且且q q0 0*1 1 p p 2 2 ,pF,pF,1 12 2*图灵机接受的语言是输入字母表中这样一些字符串的集合,初始时,这些字符串放在M的带上,M处于状态q0,且M的带头处在最
8、左单元上,这些字符串将使M进入某个终止状态。假定:假定:当输入被接受时,图灵机将停止,没有下一个动作。9School of Computer Science&Technology,BUPT 任给图灵机任给图灵机 M=(Q,T,q0,B,F),以及输入字符串以及输入字符串w T*.试问:对于试问:对于w,M 是否停机是否停机?停机是指图灵机不存在停机是指图灵机不存在下一个移动步(下一个移动步(move).结论结论 图灵机的停机问题是不可解的(即不可判定的)图灵机的停机问题是不可解的(即不可判定的).结论结论 任给图灵机任给图灵机 M,很容易构造一个图灵机很容易构造一个图灵机 M,使得使得L(M)
9、=L(M ),并满足:如果并满足:如果w L(M),则对于则对于 w,M 接接受受w并一定停机并一定停机.如果没有特别指出,总是假定图灵机到达终态(接受态)如果没有特别指出,总是假定图灵机到达终态(接受态)后一定停机后一定停机.但是但是,对不能接受的字符串,图灵机可能永不停止对不能接受的字符串,图灵机可能永不停止.(只(只要要M还在某个输入上运行,我们无法知道是因为运行的时间不还在某个输入上运行,我们无法知道是因为运行的时间不够长而没有被接受,还是根本就不会停机)够长而没有被接受,还是根本就不会停机)图灵机的停机问题图灵机的停机问题 10School of Computer Science&T
10、echnology,BUPT图灵机举例图灵机举例例例1 1:设语言:设语言 L=aL=an n b bn nn=1n=1,设计图灵机接受设计图灵机接受L L。思路:最初带上为思路:最初带上为 a aa a a b ba b b b B B B b B B B n n个个a na n个个b b首先用首先用x x替换替换M M最左边的最左边的a a,再右移至最左边的再右移至最左边的b b用用y y替换之,左移替换之,左移寻找最右的寻找最右的x x,然后右移一单元到最左的然后右移一单元到最左的a a,重复循环。重复循环。如果如果(1 1)当在搜寻)当在搜寻b b时,时,M M找到了空白符找到了空白符
11、B B,则则M M停止,不接受该串。停止,不接受该串。(此时,(此时,a a的个数大于的个数大于b b的个数)的个数)(2 2)当将当将b b改为改为y y后,左边再也找不到后,左边再也找不到a a,此时此时,若右边再无若右边再无b b,接受;若仍有接受;若仍有b b,则则b b的个数大于的个数大于a a的个数,不接受。的个数,不接受。11School of Computer Science&Technology,BUPT例例1 L=an bnn=1(q0,a)=(q1,x,R)(q0,y)=(q3,y,R)(q1,a)=(q1,a,R)(q1,y)=(q1,y,R)(q1,b)=(q2,y,
12、L)(q2,a)=(q2,a,L)(q2,y)=(q2,y,L)(q2,x)=(q0,x,R)(q3,y)=(q3,y,R)(q3,B)=(q4,B,R)例:例:aabbaabb的接收格局序列的接收格局序列q q0 0aabb xqaabb xq1 1abb xaqabb xaq1 1bb xqbb xq2 2ayb qayb q2 2xaybxqxaybxq0 0aybxxqaybxxq1 1ybyb xxyq xxyq1 1bxxqbxxq2 2yyxqyyxq2 2xyyxxqxyyxxq0 0yyxxyqyyxxyq3 3yxxyyqyxxyyq3 3BxxyyqBxxyyq4 4 1
13、2School of Computer Science&Technology,BUPT对于输入字符串对于输入字符串001122,该图灵机可以有如下推导该图灵机可以有如下推导步:步:q0001122MXq101122 MX0q11122MX0Yq2122MX0Y1q222MX0Yq31Z2*Mq3X0Y1Z2MXq00Y1Z2*MXXYYZq22MXXYYq3ZZ*MXq3XYYZZMXXq0YYZZ*MXXYYq4ZZMXXYYZq5ZMXXYYZZq5BMXXYYZZBq6B例例2 L=0n1n2n n 1.13School of Computer Science&Technology,BU
14、PT 转移图与转移表转移图与转移表14School of Computer Science&Technology,BUPT 作为整数函数计算机的图灵机作为整数函数计算机的图灵机n预备知知识:图灵机除了作为语言接受器外,还可看作整数到整数的函数计算机。n传统方法把整数表示成一方法把整数表示成一进制制整数 i 0 用字符串 0i 表示n如果一个函数有k个自变量,i1,i2,ik,那么这些整数开始时被放在带上,并用1把他们分隔开。形如 0i1 1 0i2 1 0i3 1 0ikn如果图灵机停止(不论是否在一个接受状态上)且带上为 0m,则 f(i1,i2,ik)=m f是被图灵机计算的k元函数n如果
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 形式语言 自动机 图灵机
限制150内