软件理论基础学习笔记——图灵机


图灵机(turing machine)

学过计算机的人总归会多或少得听说过图灵机这种东西,但是图灵机究竟是什么呢?图灵机其实也是自动机的一种,并且图灵机会在状态转换过程中操作一个无限的tape

tape的样子如下图所示,tape里面包含字符,其中后面那个两竖一横的符号是blank的意思,它是一个特殊的字符,用来填满无限的tape
在这里插入图片描述
tape head指向当前tape上的字符

tape上的操作

  • 可以对tape head指向的字符进行读/扫描操作
  • 可以对tape head指向的字符进行写/更新操作
  • 将tape head左移一格
  • 将tape head右移一格

操作规则:
1、
每一步操作都要执行一下操作

  • 读取当前的字符
  • 更新当前格子中的字符
  • 左移一格或者右移一格

如果当前tape指向最左边的格子,那么执行左移操作将不会发生移动

如果你不想更改当前格的字符,那么执行更新操作的时候只要让它更新为和当前字符一样即可

2、
操作行为类似于有限状态机

有初始状态

终止状态有两种:

  • accept state
  • reject state

计算结束后状态会变成下列三种中的一种:

  • 终止并且接受(accept)
  • 终止并且拒绝(reject)
  • 循环(loop,就是说没有终止)

下面是图灵机的正式定义,Turing Machine可以表示为一个七元组 ( S , Σ , Γ , δ , s 0 , b , F ) (S,Σ,Γ,δ,s_{0},b,F) (S,Σ,Γ,δ,s0,b,F)

  • S是一组状态的集合
  • Σ Σ Σ是输入字母表
  • Γ Γ Γ是tape的字母表
  • δ δ δ是转换函数
  • s 0 s_{0} s0是初始状态
  • b b b是空符号
  • F F F是终止状态的集合(包括accept或reject)

转换函数 δ δ δ定义为:
S × Σ → Γ × ( R / L ) × S S×Σ\rightarrow Γ×(R/L)×S S×ΣΓ×(R/L)×S

这里的(R/L)就是执行左移或者右移操作,R就是向右(right)移动,L就是向左(left)移动

以下面这张图为例,在图上 0 → 1 , R 0\rightarrow 1,R 01,R代表的含义是,在状态A时接收字符0,那么将会转变为状态B,并且在当前磁头位置写下1这个字符,然后磁头向右移动一格
在这里插入图片描述

例子

接下来我们通过构建一个图灵机,并且实际运算一下,看看图灵机究竟是如何进行计算的

我们要构建图灵机,用于计算n+1函数,下图的初始状态是q1,结束状态是qa

在这里插入图片描述
假设输入的数字为1011(二进制),初始时tape head指向第一个值

在这里插入图片描述

第一步读取一个1,自动机会通过 1 → 1 , R 1\rightarrow 1,R 11R这个转换,转换后仍然变成 q 1 q_{1} q1,在第一格写入1,并将tape head右移一格
在这里插入图片描述
接下来的步骤和上面一样分别读取0,1,1仍然转变为 q 1 q_{1} q1,并且写上和原来相同的数字
在这里插入图片描述
这时候的tape head指向了空字符,按照状态机的转换 q 1 q_{1} q1只能转变为 q 2 q_{2} q2,要注意的是,tape head会往左移动一格
在这里插入图片描述
我们看看 q 2 q_{2} q2这边的转换,碰到1就写入0,并且向左移动tape head,因为按照二进制加法的逻辑,最后一位如果是1,那么+1后变成0,并且会进一位,如果最后一位是0,那么就直接变成1就行了,故此有了图上 q 2 q_{2} q2的转换

在这里插入图片描述
再执行一次上面的操作
在这里插入图片描述
这次读取到了0,所以状态 q 2 q_{2} q2将会转变为 q 3 q_{3} q3,并且将0覆写为1,然后向右移动一格
在这里插入图片描述
来到了 q 3 q_{3} q3状态,在这个状态下,只要单纯向右移动即可,因为写入的数字是相同的

在这里插入图片描述
终于到了最后一步啦,看到读取空字符,然后 q 3 q_{3} q3状态就会转变为 q a q_{a} qa的接受状态,因为到达了终止状态,满足了图灵机的终止条件,所以图灵机运行完毕

我们来看看,我们输入的数字是1011,然后输出的数字是1100,所以我们实现的这个图灵机完成了n+1这个函数的操作步骤

格局(configuration)

configuration翻译成了格局,但这个东西其实就是一个图灵机在当前状态下的快照,由当前状态下tape中的字符,tape head指向的位置,以及当前自动机的状态这三个元素组成,可以简单的用如下图所示图灵机的格局

在这里插入图片描述

用字符串表示格局的话,是类似于下面这样的:

▹ \triangleright 1100 q 1 q_{1} q1 11001

▹ \triangleright 符号代表开始位置,里面的 q 1 q_{1} q1代表当前的状态,里面的字符代表的tape中的字符,tape head指向的是状态右边的第一个字符,所以在这个例子里面,tape head指向的是1

Turing’s Thesis

Turing’s Thesis
1、任何能被数字计算机执行的事情,Turing Machine同样也能够完成(从这里可以看出Turing Machine能力相当强大)
2、如果你能写出一个算法来解决某个问题,那么同样可以写出一个图灵机程序来解决相同的问题

  • 6
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值