新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论Semantic Web(语义Web,语义网或语义万维网, Web 3.0)及相关理论,如:Ontology(本体,本体论), OWL(Web Ontology Langauge,Web本体语言), Description Logic(DL, 描述逻辑),RDFa,Ontology Engineering等。
    [返回] 中文XML论坛 - 专业的XML技术讨论区W3CHINA.ORG讨论区 - Web新技术讨论『 Semantic Web(语义Web)/描述逻辑/本体 』 → 逻辑讲坛之二《数理逻辑中的一些基本概念:语法和语义》作者:wolfel,University of Texas at Austin 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 85643 个阅读者浏览上一篇主题  刷新本主题   平板显示贴子 浏览下一篇主题
     * 贴子主题: 逻辑讲坛之二《数理逻辑中的一些基本概念:语法和语义》作者:wolfel,University of Texas at Austin 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18406
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    兴趣:
    * XML相关技术
    * 资料收集
    * Ontology Engineering
    * Web架构
    * SW Implementation
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客楼主
    发贴心情 逻辑讲坛之二《数理逻辑中的一些基本概念:语法和语义》作者:wolfel,University of Texas at Austin


    应徐涵之邀,简单谈谈数理逻辑中的一些基本概念:语法和语义。

    本文尽量说的浅显易懂,针对的也是数理逻辑的初学者。如果是在逻辑方面已经有深刻理解的朋友,请直接略过。

    我们首先问这样一个问题:逻辑到底研究的是什么?

    很多初学者学了很久逻辑,看了无数定理定义证明,但是始终搞不清的问题是:这些定理定义证明到底是做什么用的?为什么要弄出这么一套复杂的理论?它跟我们的生活有什么联系?

    很多数学,物理学中的理论,看起来远离生活,其实和生活息息相关,比如学了几何学,可以用来丈量,学了微积分,可以用来解决物理学中的问题。但是逻辑学似乎总是远离生活,它和生活的关系至多只是一些简单的推理规则,比如德摩根律,比如反证法,is that all?

    其实远远不是:如果说数学,物理中的诸多理论影响了人们的生活,给人们提供了很多解决实际问题的方法,那么逻辑则会影响人们的思维,逻辑为人们的理性思维提供了工具。

    (一)

    我们先做一个假设:理性思维是能够被语言所正确表达的。现在我们假定这种语言就是“自然语言”,比如中文,英文。

    理性思维必须能被语言正确表达,所谓“词要达意”。你说出的话不能让别人误解,当成别的意思,比如

    (a)“I saw John with a telescope on a hill”

    这句话可以认为是你在称述一个事实,可惜的是你说的这句话很可能没有表达出你心里想表达的意思,因为它至少可以理解成下面三个句子之一表达的含义:

    (a1) “I stood on a hill, used a telescope and saw John.”
    (a2)“ I saw that John was standing on a hill and with a telescope. ”
    (a3)“ I used a telescope and saw John standing on a hill. ”

    类似这种句子,如果在日常生活中经常出现,倒也没有太大问题,因为生活中要处理的多半是简单直观的推理问题,并不会对你说的每句话都如此挑剔。但是如果你用这种类型的句子来表达严格的科学论证,比如证明数学定理,那就麻烦了,不仅别人可能看不明白你想要表达什么意思,也许你自己说着说着,也会陷入迷糊。

    所以在科学论证,尤其是数学论证绝对不能出现如此不严密的表达。很不幸的是,这种情况曾经在被认为最为精确的学科数学中,都广泛的存在:比如牛顿甚至不知道无穷小怎么定义,就发明了微积分。

    (a) 之所以会被理解成三种含义不同的句子,原因之一是 (a) 可以对应三种不同的语法树。这个和程序设计语言理论中的判断二义语法的道理是一致的:一个语法具有二义性,当且仅当存在一个满足该语法的句子,对应了两个语法树。

    因此我们需要使用一种精心设计的语言,这种语言所能表达出的句子,只会对应唯一的语法树。这种语言没有自然语言灵活,甚至表达起来拖沓累赘,表达能力也比较有限,但是它足够精确,没有二义。经典逻辑中的命题逻辑,一阶谓词逻辑都是这样的语言。

    翻开任何一本数理逻辑的教科书,首先学到的就是逻辑语言的“语法”,比如命题逻辑公式的语法:首先定义一个在语言中能出现的所有词汇的词汇表(signature),之后归纳定义这个语言中的合法的句子(公式):

    1. 对任意命题p,p是公式
    2. 如果F是公式,~F是公式
    3. 如果F, G是公式,F&G, F|G, F->G, F<->G也是公式

    通过规定逻辑连接词之间的优先级和适当的加入括号,任何一个逻辑公式都只对应唯一的语法树,因此,假如你用命题逻辑语言去说话,那么这句话肯定是无二义的。

    使用命题逻辑,如果要表达

    “如果明天天晴,我就去学校,或者去公园”

    就可以写成命题逻辑公式:

    ”明天天晴->(我去学校|我去公园)”

    可惜命题逻辑能表达的非常有限,比如句子(a)就表达不了。要表达句子(a),我们需要使用表达能力更强的逻辑,即逻辑语言运行我们谈论“对象”以及“对象间的关系”。假如我们希望 (a)表达的是(a1)的意思,那么(a1)中的对象有 “I”, “hill”, “telescope”, “John”, 对象之间的关系有 stand, use, see,于是我们可以把(a)表达为

    (a4) stand(I, hill) & use(I, telescope) & see(I, John)

    (a4) 准确的表达了(a1)的含义。所以,假如你在说(1)的时候,不要使用自然语言,而使用一阶逻辑语言,那么就不会被人误会成三种意思了。

    所以,逻辑的第一个作用是:为人们提供了一种能无二义的语言。

    (二)

    在上一节最后,谈到了逻辑能为人们提供准确表达含义的语言。在这里,我们说的“含义准确”,意思是只对应唯一的语法树。
    这一节我想谈谈“含义”的另一种“含义”。
    在日常生活中,或者在学习数学证明的过程中,我们经常会问这样一个问题:“这句话是什么意思?”比如我说:

    (b)“明天如果不下雨,我就去学校”。

    这句话有很多种意思。比如,假如我是个经常说谎的人,或者经常违背诺言的人,那么你估计根本不会相信这句话。

    假如我是个诚实的人,那么你对这句话的理解可能就不同了。你听了这句话后,就会确定,如果明天,比如2011年10月1号,真的不下雨,那么我就确实会去学校。没错,这是我告诉你的。所以我这句话的意思是:

    (b1) 当挂在墙上的日历翻到了2011年10月1号,并且没下雨,那么我就会去学校。

    这就是我这句话的“含义”。这里的“含义”和(一)中说的“含义”是不一样的:这里所说的含义跟语法树没有关系,而是跟现实生活中即将要发生的事情有关系。
    你可以认为人进行思考总是通过语言,表达自己的思想也是通过语言。语言,写下来是“语”,说出来是“言”,但是无论如何,都是一些抽象的符号,一个没有语病的句子仅仅是一些满足语法规范的字符串。那么人们到底是通过什么方法从 (b) 这样的一个字符串中得到了 (b1) 这样一个在现实生活中发生的事件呢?

    从(b)到(b1)实际上做的是一个映射:字符串“明天”被映射到了现实生活中一个切切实实的日子,2011年10月1日,字符串“不下雨”被映射到了天上没落雨点这样一个自然现象,字符串“我”被映射到现实生活中的说话的人,“去学校”被映射到了现实生活中去学校这样的一个动作。这样的一个映射被称为对词语的“解释”。要理解 (b) 的含义,首先做的事情就是对所有的词语做“解释”。解释的方法是把这个词语,根据其自然语言或者上下文的含义,把它与现实生活中的客观对象关联起来。

    到这里似乎还差了一点:“如果…就…”这个结构,到底是什么意思?假如一个初学中文的外国人不认识“如果…就…”这个结构,只能看懂 (b) 里的别的词,他还是看不懂这句话的意思。那么,作为一个有丰富中文知识的中国人,我会告诉他,这句话的意思是在客观世界中发生下面三种情况的任何一种:

    (b1.1)2011年10月1号没下雨,我去了学校
    (b1.2)2011年10月1号下雨了,我去了学校
    (b1.3)2011年10月1号下雨了,我没去学校

    虽然这个外国人没看懂 (b) 的意思,但是他的中文知识可以看懂 (b1.1), (b1.2), (b1.3),也就明白了你说 (b)这句话,事实上是说了你的客观行为就是 (b1.1), (b1.2), (b1.3)中的任何一种。
    可惜的是,并不是任何一个自然语言中的句子,都能通过找到这样的映射关系来理解它的含义。比如“我所说的话是谎话”,再比如“如果这个世界上有独角兽,那么太阳就会从西边出来”。
    而逻辑语言的好处是它有明确的语义。其中最重要的一种语义称为“模型论”语义。模型论语义也可以认为是和上面描述的人解释自然语言句子最为相似的一种语义。

    怎样去理解一个命题逻辑公式的含义呢?首先,我们从基本的命题符号开始解释。任何一个命题符号p,都被解释为true或者false,对照上面对自然语言的解释来理解,可以认为任何一个命题表达的含义,要么是客观世界中为真,要么在客观世界中为假。这种对每个命题符号进行解释(真值赋值)得到的这种映射,记做I。有了解释I之后,需要进一步定义 ~, &, |, ->, <->的含义(类似上面定义“如果…就”这个词组的意思):

    1. I(p)=true, then I(~p)=false
    2. I(F)=true and  I(G)=true, then I(F&G)=true
    3. I(F)=true or I(G)=true, then I(F | G)=true
    4. I(F)=true implies I(G)=true,  then I(F->G)=true
    5. I(F)=I(G), then I(F<->G)=true

    一个命题逻辑公式F,在给出了所有命题原子的解释I之后,就可以通过1—5 来算出整个公式的真值。如果在I解释下,F的真值为true,就称为I满足F(I|=F),I被称为F的“模型”,也就是说I这种解释,就是F这个命题公式的“含义”。对比在自然语言中的例子,(b)这句话的含义,就是(b1.1) (b1.2) (b1.3)。

    命题逻辑假设任何一个命题都只能表示客观世界中的true或者false,显然是一个太强的假设。在一阶逻辑中,它被扩展到表达客观世界中的“对象”以及对象之间的“关系“,于是命题逻辑的真值映射,在一阶逻辑中变成了定义在集合论上的代数结构。虽然这种解释就变得复杂多了,但是其基本动机和出发点是不变的。

    逻辑的语义都是被严格的数学化的定义的,因此,任何一个逻辑公式,都精确的对应了一个客观世界中。这是逻辑语言的第二个作用。

    综合(一),(二),如果你用“数理逻辑语言“说了一句话,那么,首先,这句话只有唯一的一种解析方式;其次,这句话精确的对应了客观世界中的某种(或若干种)状态。与自然语言相比,逻辑语言在语法和语义上的精确性,不会因为说话人或者听话人所处的时间,地点,态度,以及谈话的上下文的不同而发生变化。

    正是因为自然语言中的种种不尽人意的地方,以及它无时无刻不在影响人们的思维甚至科学研究,数学证明的推理过程,Gottlob Frege (1848-1926) 提出要使用一种严格的逻辑语言来规范数学证明,他称之为“概念演算”,事实上这是含等词的一阶逻辑。这种思想之后演化成了使用经典逻辑严格的重新定义所有的数学概念和分支,这就是二十世纪著名的希尔伯特计划,成就了二十世纪三四十年代数理逻辑的蓬勃发展,甚至成就了计算机科学的诞生。其中众多的划时代的理论成果,就不在本文中一一介绍了。

    推荐书籍:

    苏珊•哈克 《逻辑哲学》,商务印书馆
    侯世达:《GEB:集异璧之大成》,商务印书馆
    Stephen Kleene: 《元数学导论》

    [此贴子已经被作者于2012-5-10 17:01:47编辑过]

       收藏   分享  
    顶(0)
      




    ----------------------------------------------

    -----------------------------------------------

    第十二章第一节《用ROR创建面向资源的服务》
    第十二章第二节《用Restlet创建面向资源的服务》
    第三章《REST式服务有什么不同》
    InfoQ SOA首席编辑胡键评《RESTful Web Services中文版》
    [InfoQ文章]解答有关REST的十点疑惑

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2011/11/8 1:03:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 点击这里发送电邮给Google AdSense  访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/3/28 16:59:46

    本主题贴数13,分页: [1] [2]

     *树形目录 (最近20个回帖) 顶端 
    主题:  逻辑讲坛之二《数理逻辑中的一些基本概念:语法和语义》作者:wolfel,University&nb..(8172字) - admin,2011年11月8日
        回复:  写的太好了(10字) - sophicchen,2013年6月21日
        回复:  这篇文章写得不错,把逻辑联系到了实际生活中的应用。赞一个!(58字) - 海豚_128,2012年12月15日
        回复:  写的很好,希望能继续更新啊。希望能给介绍下逻辑讲坛一中提出的 命题逻辑,谓词逻辑,一阶逻辑,高阶逻..(123字) - 言午山魏,2012年6月7日
        回复:  这就是所谓的厚积薄发吧,复杂的概念用让人容易理解的简单方法表述本身就是一种艺术。楼主的介绍方法十分..(138字) - Humphrey,2012年4月16日
        回复:  确实很好(8字) - studyarmy,2012年4月5日
        回复:  学习一下了谢谢(16字) - hjx_221,2012年3月18日
        回复:  继续推荐(8字) - admin,2012年1月18日
        回复:  Wolfel写得很好! 赞一个!(25字) - Huang,2011年11月11日
        回复:  写的太好了,深入浅出,赞一个。(30字) - lsp_jlu,2011年11月8日
        回复:  这样的介绍连baby logic都算不上,这样的东西容易让没正儿八经受过逻辑训练的人感慨:逻辑,技..(96字) - ICT_RemyChan,2011年11月8日
            回复:  [quote][b]以下是引用[i]ICT_RemyChan在2011-11-8 5:50:00[..(355字) - wolfel,2011年11月10日
            回复:  [quote][b]以下是引用[i]ICT_RemyChan在2011-11-8 5:50:00[..(322字) - admin,2011年11月9日

    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    89.844ms