`
lovnet
  • 浏览: 6878081 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
文章分类
社区版块
存档分类
最新评论

为什么2007年的图灵奖选择了模型检测技术

阅读更多

为什么2007年的图灵奖选择了模型检测技术
像树一样成长,刚听完俞敏洪的在赢在中国的演讲----------题记

2007年图灵奖授予了在模型检测技术领域的奠基性贡献的科学家:Edmund M. Clarke、E Allen Emerson和Joseph Sifakis三位科学家。

什么是模型检测技术呢? 看看wikipedia 上的定义吧:
Model checking is the process of checking whether a given structure is a model of a given logical formula. The concept is general and applies to all kinds of logics and suitable structures. A simple model-checking problem is testing whether a given formula in the propositional logic is satisfied by a given structure.

简单的说:是一套用于判断硬件和软件设计的理论模型是否满足规范的方法。这可真是个抽象的描述,看起来似乎离我们很遥远,遥远的只有像英特尔研究中心副总裁Andrew Chien才能对模型检测技术用一句话来评价:“英特尔和整个计算机工业都从他们的贡献中直接获益”。

那模型检测技术是不是离程序员也很遥远呢?图灵奖作为计算机界诺贝尔奖,如果把奖项颁给一个离程序员很遥远的技术,还真说不过去。

带着这个疑问,我浏览了wikipedia上长长的一窜模型检测技术的项目,还好不出所料,找到了下面几个项目:

1、Java Pathfinder :是一个用来认证java执行字节代码的系统。类似一个java虚拟机用来检测软件运行状态的验证系统。
2、Mono Model Checker :跑在mono 开源的.net平台上。用来自动侦查 CIL 字节码错误的程序。目前的版本支持CIL的死锁 deadlocks 和 断言冲突 assertion violation 。

3、对于c++ 感兴趣的人还可以看看这两个项目:
State Exploring Assembly Model CheckerBounded Model Checking for ANSI-C

举个例子吧,在开发中,利用测试库junit 和 dotunit 写测试代码已经逐渐普及开了,比如下面这段:
public void testToppingsOnNewPizza()
{
Pizza pizza = new Pizza();
List toppings = pizza.getToppings();
assert( (toppings.size()==0) );
}
注意上面加黑的这句: assert( (toppings.size()==0) );

这段代码我们用来检测:pizza.getToppings() 的大小是否为0。那么模型检测和上面的测试代码有什么不同呢?

不同点在于:现在的测试库用来判断结果 , 而模型检测用来判断过程(逻辑)是否符合要求。

我们常说,不但要关注结果,更要关注过程。模型检测就是对过程的关注。

无疑,现在写程序的时候,模型检测的过程,是由广大程序员完成的。如果这个过程可以由机器完成的话?那不是就是实现了自动编程吗?据说word的创始人开发者正在干这样的事儿... ,不知道这个老头有生之年能不能实现他的理想。

当然,我也相信在更高级的人工智能技术中,模型检测技术会大展拳脚。

又是个遥远的事情,洗洗睡吧。

分享到:
评论

相关推荐

    IT最高奖 图灵奖 图灵奖 图灵奖

    图灵奖 图灵奖 图灵奖 图灵奖 图灵奖 图灵奖图灵奖图灵奖图灵奖

    计算的美丽-图灵奖获得者

    通过从1966年开始的图灵奖,逐年介绍当年的图灵奖获得者。到目前为止,是图 灵奖的第一个 40年(1966–2005)。总共有 50位杰出的科学家获得了此荣誉。到现 在为止(2008年 2月 8日)近 2年过去了。新的 4位图灵奖获得...

    历届图灵奖获得者分类

    自 1966 年以来,共有 51 人获得了图灵奖。通过对历届图灵奖获得者的国籍、学历、年龄、研究方向等信息的分析,我们可以了解计算机科学领域的发展脉络和研究热点。 图灵奖获得者的国籍分布 根据图灵奖获得者的...

    1966-2016图灵奖获得者资料

    图灵奖,全称为艾伦·麦席森·图灵奖(ACM A.M. Turing Award),是由美国计算机协会(ACM)于1966年设立的奖项,被誉为“计算机界的诺贝尔奖”。该奖项每年颁发一次,以表彰对计算机科学做出重大贡献的个人。在给定...

    历届图灵奖得主及获奖词数据源

    图灵奖,全称为ACM艾伦·图灵奖,是由美国计算机协会(Association for Computing Machinery,简称ACM)于1966年设立的奖项,被誉为“计算机界的诺贝尔奖”。该奖项旨在表彰对计算机科学有深远影响的杰出贡献者。...

    1968年图灵奖获得者

    1968年,海明因其在“数值方法、自动编码系统、错误检测和纠错码”等方面的杰出贡献荣获图灵奖。 #### 海明码及其重要性 海明最著名的贡献之一是发明了“海明码”,这是一种能够检测并纠正单个错误的编码方式,...

    三位在数据库领域作出杰出贡献的图灵奖获得者

    石井义雄的贡献对日本的数据库技术产生了深远的影响,因此他在 2003 年获得了图灵奖。 三位在数据库领域作出杰出贡献的图灵奖获得者,对数据库技术的发展产生了深远的影响。他们的贡献不仅对数据库技术的发展产生了...

    图灵奖获得者获奖演讲稿.part2

    图灵奖是计算机界的最高奖项,由ACM发起,本资料收录了66-94年图灵奖获得者在ACM大会上的讲话。(共四个分卷)

    图灵奖获得者获奖演讲稿.part3

    图灵奖是计算机界的最高奖项,由ACM发起,本资料收录了66-94年图灵奖获得者在ACM大会上的讲话。(共四个分卷)

    2017年ACM发布2016年图灵奖

    INVENTOR OF WORLD WIDE WEB RECEIVES ACM A.M. TURING AWARD Sir Tim Berners-Lee Designed Integrated Architecture and Technologies that Underpin the Web

    图灵奖获得者获奖演讲稿.part1

    图灵奖是计算机界的最高奖项,由ACM发起,本资料收录了66-94年图灵奖获得者在ACM大会上的讲话。(共四个分卷)

    图灵奖获得者获奖演讲稿.part4

    图灵奖是计算机界的最高奖项,由ACM发起,本资料收录了66-94年图灵奖获得者在ACM大会上的讲话。(共四个分卷)

    图灵奖:计算机科学领域的诺贝尔奖.zip

    图灵奖,全称为艾伦·麦席森·图灵奖(ACM A.M. Turing Award),是由美国计算机协会(ACM)于1966年设立的一项国际性奖项,被誉为计算机科学领域的“诺贝尔奖”。这个奖项以英国数学家、逻辑学家、计算机科学之父...

    图灵奖大师讲座ppt

    【图灵奖大师讲座PPT】的讲解涵盖了计算机科学领域的重要进展和未来趋势,由康奈尔大学的John Hopcroft教授分享。Hopcroft教授在计算机科学领域的贡献显著,尤其在算法设计方面,使得该讲座对学习者具有极高的价值。...

    ACM图灵奖:1966-2006(第三版)计算机发展史的缩影

    《ACM图灵奖:1966-2006(第三版)计算机发展史的缩影》这本书详尽地记录了自1966年至2006年间四十年间,计算机科学领域的重大成就和发展历程。ACM图灵奖,被誉为计算机科学的诺贝尔奖,是对那些对计算机科学做出杰出...

    ACM图灵奖

    **ACM图灵奖**,全称为ACM A.M. Turing Award,是计算机科学领域最顶级的荣誉之一,由美国计算机协会(Association for Computing Machinery,简称ACM)于1966年设立,以计算机科学的先驱艾伦·麦席森·图灵的名字...

Global site tag (gtag.js) - Google Analytics