- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Wikipedia Prolog article包括这个图灵机模拟器:
turing(Tape0, Tape) :-
perform(q0, [], Ls, Tape0, Rs),
reverse(Ls, Ls1),
append(Ls1, Rs, Tape).
perform(qf, Ls, Ls, Rs, Rs) :- !.
perform(Q0, Ls0, Ls, Rs0, Rs) :-
symbol(Rs0, Sym, RsRest),
once(rule(Q0, Sym, Q1, NewSym, Action)),
action(Action, Ls0, Ls1, [NewSym|RsRest], Rs1),
perform(Q1, Ls1, Ls, Rs1, Rs).
symbol([], b, []).
symbol([Sym|Rs], Sym, Rs).
action(left, Ls0, Ls, Rs0, Rs) :- left(Ls0, Ls, Rs0, Rs).
action(stay, Ls, Ls, Rs, Rs).
action(right, Ls0, [Sym|Ls0], [Sym|Rs], Rs).
left([], [], Rs0, [b|Rs0]).
left([L|Ls], Ls, Rs, [L|Rs]).
rule(q0, 1, q0, 1, right).
rule(q0, b, qf, 1, stay).
?- turing([1,1,1], Ts).
Ts = [1, 1, 1, 1] ;
turing(Tape0, Tape)
rule(Q0, Sym, Q1, NewSym, Action)
perform(Q0, Ls0, Ls, Rs0, Rs)
symbol([Sym|Rs], Sym, Rs)
action(left/stay/right, Ls0, Ls, Rs0, Rs)
left([L|Ls], Ls, Rs, [L|Rs])
最佳答案
在图灵机中,在任何给定状态下,写头都指向磁带上的特定位置。头部左侧有符号,头部右侧有符号。
查看第一个主要谓词:
turing(Tape0, Tape) :-
perform(q0, [], Ls, Tape0, Rs),
reverse(Ls, Ls1),
append(Ls1, Rs, Tape).
perform/5
来“运行机器”。 .
perform(Q0, Ls0, Ls, Rs0, Rs)
的参数代表:
Q0 - the current state (or initial state before the "perform")
Ls0 - the current set of symbols that are LEFT of the head
Ls - the FINAL set of symbols that WILL BE left of the head after perform
Rs0 - the current set of symbols that are RIGHT of the head
Rs - the FINAL set of symbols that WILL BE right of the head after perform
Tape0
最初包含头部右侧的所有符号。为了“运行机器”,主谓词调用:
perform(Q0, [], Ls, Tape0, Rs)
Q0
, 头部左侧没有以 (
[]
) 开头的符号,并且在
Tape0
中有符号右侧的头部开始。查询完成后,期望得到
Ls
用头部左侧的最后一组符号实例化,和
Rs
头部右侧的最后一组符号。
perform/5
.
symbol([Sym|Rs], Sym, Rs)
[Sym|Rs]
之间的关系,以及该列表中的第一个符号 (
Sym
) 和列表的其余部分 (
Rs
)。
perform/5
使用此谓词读取当前位于头部右侧的下一个符号。
perform/5
谓词维护
Rs0
变量使得它的顺序正确,其中列表的头部是右边的第一个符号,列表的第二个元素是右边的下一个符号,依此类推。请注意,左侧的符号列表并非如此。左侧列表以符号在磁带上出现的相反顺序维护。原因是可以按照它们离当前头部位置的距离的顺序来考虑它们。稍后会详细介绍这一点。
action(left/stay/right, Ls0, Ls, Rs0, Rs)
Ls0
和
Rs0
分别是执行 Action 之前头部左侧和右侧的符号列表。和
Ls
和
Rs
分别是 Action 完成后头部左侧和右侧的符号。
action(stay, Ls, Ls, Rs, Rs).
action(right, Ls0, [Sym|Ls0], [Sym|Rs], Rs).
Sym
,因为右侧的一组符号是
[Sym|Rs]
)立即变为左侧的符号。左边的一组符号最初是,
Ls0
并变成
[Sym|Ls0]
.右侧的符号列表最初是
[Sym|Rs]
并变成
Rs
.
left
action 比
stay
稍微复杂一点或
right
因为当左边没有更多符号并指示向左移动时,头部仍然向左移动,右边出现空白。所以
left
它被分解成一个单独的小谓词:
action(left, Ls0, Ls, Rs0, Rs) :- left(Ls0, Ls, Rs0, Rs).
left([], [], Rs0, [b|Rs0]).
[]
),那么向左移动意味着左边的符号仍然是空的(
[]
)并且一个新的空白(
b
)出现在头部的右侧,在原始右侧符号集(右侧列表从
Rs0
更改为
[b|Rs0]
)。
left([L|Ls], Ls, Rs, [L|Rs]).
[L|Ls]
(
L
是紧靠头部左侧的符号),头部右侧的初始符号集是
Rs
.当头部向左移动时,左边的第一个符号变成右边的第一个符号。所以更新后的左符号集是
Ls
,更新后的符号集为
[L|Rs]
.
action(left, ...)
可以在没有辅助谓词的情况下编写谓词,
left/4
, 这边走:
action(left, [], [], Rs0, [b|Rs0]).
action(left, [L|Ls], Ls, Rs, [L|Rs]).
turing/2
谓词:在
turing/2
之后电话
perform(q0, [], Ls, Tape0, Rs)
,它在右侧有最后一组符号 (
Rs
),它们的顺序正确,从左到右。但是,左侧的最后一组符号 (
Ls
) 是从右到左列出的(按照它们与当前头部位置的接近程度的顺序)。因此,为了以正确的顺序显示整个磁带,必须反转左侧的符号列表,然后添加到右侧的符号集。因此,调用:
reverse(Ls, Ls1),
append(Ls1, Rs, Tape).
perform/5
谓词:
perform(qf, Ls, Ls, Rs, Rs) :- !.
qf
,然后是左符号的最终列表,
Ls
, 成为我们当前的左符号集。对于正确的符号也是如此。
perform(Q0, Ls0, Ls, Rs0, Rs) :-
% Read the symbol to the right of the head (Sym)
%
symbol(Rs0, Sym, RsRest),
% Apply first found matching rule to the current state (Q0)
% and the current symbol on the right (Sym), resulting in
% a new symbol (NewSym) and an action (Action)
%
once(rule(Q0, Sym, Q1, NewSym, Action)),
% Perform the action using the current list of symbols on the left (Ls0)
% and the updates list of symbols on the right (old right symbol (Sym)
% replaced by the new right symbol (NewSym), which is [NewSym|RsRest]
% with the action resulting in new left Ls1 and new right Ls2
% sets of symbols
%
action(Action, Ls0, Ls1, [NewSym|RsRest], Rs1),
% Recursively perform the Turing engine on the new state, left,
% and right sets of symbols until we hit the final state (qf)
% with final result being left symbols, Ls, and right symbols, Rs
%
perform(Q1, Ls1, Ls, Rs1, Rs).
关于prolog - 请解释这个用 Prolog 编写的图灵机模拟器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29403291/
我使用 iOS 4.2 和 Xcode 3.2.5 创建了一个通用二进制文件。我正在尝试对应用程序进行一些自动化测试,由于 iPad 和 iPhone 版本之间的界面略有不同,因此我有单独的 UIAu
这是一个概念性的问题。如果有人能澄清背后的故事,那就太好了。 我了解模拟器和模拟器之间的区别。 模拟器:模仿设备环境(硬件、网络功能等)。与设备相比,我们更有可能得到非常接近的结果。 模拟器:使用正在
是否有任何现成的解决方案可以模拟或模拟 LDAP 服务器功能? 或者是否可以在 ubuntu 上安装 ldap 服务器(仅适用于 localhost)? 如果它不是来自 localhost 的 jsu
我正在将我的应用程序修复为通用二进制文件。模拟器上的测试似乎默认使用 iPad。对于诸如检查方向和小型 UI 更新之类的小修正,我能找到的获取 iPhone 版本的唯一方法是插入我的 iPhone 并
Emulator: emulator: WARNING: Could not connect to proxy at ::1:8080: Unknown error ! - Android 将 And
我的应用程序在 ios 4.3 模拟器中运行良好,但在 ios 5 模拟器中运行不佳。我的 iPhone 上有 ios 5,我的应用程序确实可以在 iPhone 上运行。 该应用在所有这三种环境中都可
我在 azure 上制作了移动应用程序,并将其快速启动为 xamarian.forms,并且(在未能发布下载的表 api 应用程序并决定在浏览器中编辑它之后)下载了他们提供的客户端应用程序。然后,当我
Emulator: emulator: ERROR: x86 emulation currently requires hardware acceleration! Emulator: Process
我试图在 iOS 10.3 模拟器上将任意文件从我的应用程序的沙箱保存到 iCloud Drive。 iCloud Drive 已启用并且我已登录。如果我在模拟器上打开 iCloud Drive 应用
有谁知道一个小型、快速、支持 DOM 层的 javascript 模拟器?在 C/C++ 中? 问题:我需要在爬虫应用程序中对 javascript 的基本支持,并且想知道除了以下选项之外是否还有其他
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我是 Xcode 开发新手。我在基于 Lion 的 Mac 上安装了 Xcode 4.3.1,并取消设置 ~/Library 上的隐藏标志。 我在这里读到了有关 iPhone/iPad 模拟器的信息
我已在 VisualStudio 2015 AZURE SDK 2.9、C# 中创建辅助角色 我在每个方法的开头添加了断点: public override void Run() {
全部。我已经安装了 Azure SDK 1.7。解决方案中的所有程序集都是使用“任何 CPU”设置进行编译的。但是当我在我的计算机上的 Azure 模拟器中启动解决方案时,其中之一失败了。该错误非常奇
有没有独立的 WAP 模拟器来模拟诺基亚 6600 和索尼爱立信 MIDP 手机的 waop 网站? 我正在创建一个 WAP 门户,我不想每次都将所有文件上传到网络上,然后将其加载到 Opera Mi
我已经安装了 Tizen 的 Visual Studio Code 扩展,并且(看起来)进展顺利。 但是,当我启动 Tizen 模拟器管理器时,我没有安装任何平台,并且当我尝试安装平台时,没有可用的平
我目前正在我的 jquery mobile/phonegap 应用程序中处理表单。在此表单中,我有两个选择列表。它们在我的桌面浏览器(firefox、safari、chrome)中都能正常工作。 奇怪
我尝试制作一个分辨率为 480x480 像素的模拟器。但是模拟器永远不会完成启动。它卡在 Android Logo 页面上。分辨率有限制吗? 最佳答案 模拟器 is not smart about s
我不知道如何在虚拟设备上启用快照功能。该选项是灰色的,创建或编辑虚拟设备时没有设置。我使用的是最新版本的 SDK 工具修订版 22.6.3 这是我的窗口的样子:Create new Android V
我正在尝试使用具有特定屏幕分辨率的模拟器,但是当我将屏幕参数设置为我需要的参数时,键盘消失了。这样我就没有后退按钮,主页按钮..任何想法如何解决这个问题?这是我在 AVD 管理器中设置的:屏幕分辨率:
我是一名优秀的程序员,十分优秀!