SECD machine简介

  secd machine是一种比较基础的虚拟机设计。一般是作为函数式语言的底层虚拟机。

secd machine的“secd”四个字母分别指的是这种虚拟机的核心Stack, Environment, Control, Dump,一般也称作寄存器。

secd machine 是一种stack-based虚拟机。

Stack一般是存放运算数据和结果

Environment保存的是环境变量,一般是函数调用里的参数以及局部变量

Control保存的是虚拟机指令

Dump保存的是函数调用时的调用帧数据。

secd machine常用的指令有如下一些。

  

  • nil 将一个nil push入stack
  • s e (NIL.c) d => (nil.s) e c d
  • ldc 将一个常量push入stack,如果区分类型也可以扩展成多个ld指令
  • s e (LDC x.c) d => (x.s) e c d
  • ld 从环境中加载一个变量push入stack,因为env是分层级的,所以一般是ld [1,2] 类似的形式。
  • s e (LD [y x].c) d => (locate([y x], e).s) e c d
  • sel 这个指令是为了实现条件选择,sel有两个参数,执行时会pop出stack的一个值,判断如果是真,则将Control寄存器设置为第一个参数,否则就设置为第二个参数。同时会将当前的C寄存器中的值push到Dump寄存器。
  • (x.s) e (SEL ct cf.c) d => s e c? (c.d)
    where c? is (if (not= x false) ct cf)
  • join 和sel共用的,是在sel一条选择语句执行完时,将sel指令push到D寄存器里的指令pop出来,然后设置C寄存器。
  •   
    s e (JOIN.c) (c‘.d) => s e c‘ d
  • ldf 将其参数当做一个函数加载到stack,创建函数时会加上当前的环境。
  • s e (LDF f.c) => ([f e].s) e c d
  • ap 从stack里pop出一个closure对象和一个函数参数对象,将SEC寄存器push到D寄存器,closure携带的的env会替换E寄存器,函数体替换C寄存器,并将参数列表push到env,
  • ([f e‘] v.s) e (AP.c) d => nil (v.e‘) f (s e c.d)
  • rtn  将返回值从stack之中pop出来,将d寄存器中保存的SEC值pop出来,赋值给SEC寄存器,然后将返回值push到stack里
  •    
    (x.z) e‘ (RTN.q) (s e c.d) => (x.s) e c d
  • dum push一个空环境到当前环境中
  • s e (DUM.c) d => s (nil.e) c d
  • rap 和ap不同之处,是会将参数替换dum的空环境,dum和rap联合能实现递归。
  • ([f (nil.e)] v.s) (nil.e) (RAP.c) d
    =>
    nil (rplaca((nil.e), v).e) f (s e c.d)

参考了wiki和pysecd和 这份代码

时间: 2024-12-31 06:08:13

SECD machine简介的相关文章

Docker Machine 简介

Docker Machine 是什么? Docker Machine 是 Docker 官方提供的一个工具,它可以帮助我们在远程的机器上安装 Docker,或者在虚拟机 host 上直接安装虚拟机并在虚拟机中安装 Docker.我们还可以通过 docker-machine 命令来管理这些虚拟机和 Docker.下面是来自 Docker Machine 官方文档的一张图,很形象哦! 本文将通过一系列 demo 来展示 Docker Machine 的主要使用场景. 安装 Docker Machin

Docker Machine 详解

笔者在<Docker Machine 简介>一文中简单介绍了 Docker Machine 及其基本用法,但是忽略的细节实在是太多了.比如 Docker 与 Docker Machine 的区别?又如当我们执行 docker-machine create 命令时,Docker Machine 都做了哪些重要的事情使得我们可以远程操作 Docker daemon?这样的远程操作安全吗?本文将试图解读这些问题.注:本文的演示环境为 Ubuntu16.04. Docker 与 Docker Mach

用 Docker Machine 创建 Azure 虚拟主机

搭建环境向来是一个重复造轮子的过程,Docker Machine 则把用户搭建 Docker 环境的各种方案汇集在了一起.笔者在<Docker Machine 简介>一文中演示了使用 Docker Machine 在本地的 vSphere 主机中安装 Docker 环境.但是在云计算大爆炸的今天,真正让我们头疼的可能是五花八门的 IaaS 平台!这才是 Docker Machine 真正发挥威力的地方.Docker Machine 把与平台相关的部分封装到了不同的驱动中.只要为某个 IaaS

上周热点回顾(6.19-6.25)

热点随笔: · 其实,我只想安静的写写代码...(飞不动)· 我眼中的项目经理(悦光阴)· 2017年前端框架.类库.工具大比拼(葡萄城控件技术团队)· .NET 开发环境搭建(Alan_beijing)· Docker Machine 简介(sparkdev)· 短信发送接口被恶意访问的网络攻击事件(二)肉搏战-阻止恶意请求(13韩)· 架构师之路--怎样聊技术天,限流技术和各类编程语言(静儿1986)· Docker Machine 详解(sparkdev)· 微服务架构:基于微服务和Doc

《Docker技术入门与实战第3版2018版》高清中文PDF下载

<Docker技术入门与实战第3版2018版>高清中文PDF下载资料简介:本书从Docker基本原理开始,深入浅出地讲解Docker的构建与操作,内容系统全面,可帮助开发人员.运维人员快速部署Docker应用.本书分为四大部分:基础入门.实战案例.进阶技能.开源项目,*部分(第1-8章)介绍Docker与虚拟化技术的基本概念,包括安装.镜像.容器.仓库.数据卷.端口映射等:第二部分(第9-16章)通过案例介绍Docker的应用方法,包括与各种操作系统平台.SSH服务的镜像.Web服务器与应用.

【Machine Learn】机器学习及其基础概念简介

机器学习及其基础概念简介 作者:白宁超 2016年12月23日21:24:51 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本系列文章是作者结合视频学习和书籍基础的笔记所得.本系列文章将采用理论结合实践方式编写.首先介绍机器学习和深度学习的范畴,然后介绍关于训练集.测试集等介绍.接着分别介绍机器学习常用算法,分别是监督学习之分类(决策树.临近取样.支持向量机.神经网络算法)监督学习之回归(线性回归.非线性回归)非监督学习(K-means聚

machine learning简介和背景

http://mp.weixin.qq.com/s?__biz=MjAzNzMzNTkyMQ==&mid=211346099&idx=1&sn=41d9c9761e729ed57a89ae2aaaa66bb1&scene=0#rd 关于机器学习的具体概念及介绍,有很多这方面的资料,有兴趣的话大家可以去查看,在这里我就不赘述.简而言之,机器学习方法就是计算机利用已有的数据(经验),得出某种模型,并利用模型来预测未来的一种方法,这种方法很类似于人类的思考方式(见图2).也就是说

【Machine Learning】wekaの特征选择简介

看过这篇博客的都应该明白,特征选择代码实现应该包括3个部分: 搜索算法: 评估函数: 数据: 因此,代码的一般形式为: AttributeSelection attsel = new AttributeSelection(); // create and initiate a new AttributeSelection instanceRanker search = new Ranker(); // choose a search methodPrincipalComponents eval

【docker】01、docker简介

一.docker简介 Docker 官网:http://www.docker.com Github Docker 源码:https://github.com/docker/docker 1.docker是什么 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间不会有任何接口(类似 i