生命是什么?我们可以创造生命吗?北京师范大学哲学系副教授李建会博士对此颇有研究,近年来在《二十一世纪》(香港)、《自然辩证法研究》等重要刊物上发表了一系列相关论文。不久前,记者在 清华大学举行的 “科学技术中的哲学问题研讨会”上与李博士相遇,请他介绍了国际学术界对于生命问题的最新见解。 人都会死去,有时很突然,马克思就是在打盹时去世的:一个充满智慧的头脑一下子变成了一具和土石一般无声无息的尸体。 躯体还是那个躯体,没任何明显的变化,但一刹那之间,阳忽然变成了阴,生忽然变成了死。生命是怎么离去,又是怎样产生的? 传统的生命观 古人把生命的奥秘归于神秘的生命之气,东西方都一样。不管是上帝造,还是女娲造,躯体塑成之后,吹进那口气,就成了鲜活的生命。那口气还被说成是灵魂:灵魂离去,生变化成死;魂兮归来,死回复为生。人们发现,不但人和动物是有生命的,甚至植物也有生命。于是,西方植物和人、动物一样,也有灵魂;东方不但人可成仙、动物可成魅,草木亦可为妖。实验科学产生之后,甚至还有人用天平来权衡灵魂的重量。 可毕竟没有确切的证据表明确有灵魂存在。于是有人提出:生命之所以和无生命的东西不同,是因为它们含有一类能带来生机的特殊物质——有机物。 但自维勒合成尿素以来,人们已由无机物合成了极多种类的有机物,而且发现,生命所含有的所有元素在无机界都能找到。所以普通的有机物肯定不是决定性的因素。 但这不能排除是某类特殊的有机物带来了生命。恩格斯就认为,“生命是蛋白体的存在方式”,是蛋白体这种特殊物质的固有属性。只要知道了蛋白体的结构,并把它合成出来,人就可以完成上帝的伟业,与此同时把生命创造出来。 自我国科学家1965年人工合成最小的蛋白质——胰岛素——以来,很多有机大分子我们今天都可以合成,但它们中的任何一个或者它们的混合物都没有表现出丝毫的生命迹象,还没有人能从无到有把无机物变成生命。 或者,更根本的是结构?仅有物质材料是不够的,它们只有在按特定的方式组织起来后才能表现出生命;结构解散,系统崩溃,生命即停止。 作为系统论思想先驱的恩格斯也意识到了这一点。他在强调蛋白体是生命的存在方式的同时,还强调新陈代谢:蛋白体并不是简单的蛋白质,它必须和周围的环境不断地进行交换,交换一旦停止,蛋白体就会分解,生命随即终结。 交换什么?当然离不开物质和能量。可一旦站到原子的尺度,会发现为什么要交换物质和能量是个难解的问题。著名物理学家薛定谔问道:既然氮、氧、硫等的任何一个原子和它同类的任何另一个原子都是一样的,任何一个卡路里跟任何另一个卡路里的价值是一样的,我们又为什么要吸进一些物质,又排出一些物质,摄取进一个卡路里的热量,又传递出一个卡路里的热量呢? 他的解答是:生命体吃进或同化进的不是简单的物质和能量,而是负熵,它们以此而抵御热力学第二定律所描述的孤立系统不可避免的熵增。生命是一种不断从外界环境吸纳负熵、建立并维持有序状态的热力学系统。一旦新陈代谢停止或失调,生命系统就会因为熵增而死亡。 薛定谔站在热力学角度得到的这种见解激励了许多物理学家投身生物学研究。后来,随着系统科学的发展,这种负熵说还于20世纪70年代进一步发展成了“自创生说”。 人工生命 薛定谔等人的见解是深刻的,但所涉及的仍只是地球上“如吾所识的生命”(life-as-we-know-it),80年代后期兴起的人工生命研究创造了几类全新的“如其可能的生命”(life-as-it-could-be ),给我们理解生命提供了一个截然不同的视角。 李建会告诉记者,当前构建人工生命的途径主要有三类。第一类是通过软件的形式,即用编程的方法建造人工生命。由于这类人工生命主要在计算机内活动,其行为主要通过计算机屏幕表现出来,所以它们被称为虚拟人工生命或数字人工生命。 大家熟悉的计算机病毒就是一种较为低等的数字人工生命。但美国生物学家托马斯·雷1990年编写的Tierra(西班牙语,意为地球)模型所创造的生命更具典型性。它们由一系列能够自我复制的程序组成,由于运行中有时会出错,所以它们能突变。刚开始时,Tierra模型中只有一个简单的祖先“生物”,经过526万条指令的计算后,Tierra模型中出现了366种大小不同的数字生物,仿佛寒武纪大爆发在区区几小时内发生了。经过25.6亿条指令后,演化出了1180种不同的数字生物,其中有一些在别的数字生物体内寄生,有一些对寄生生物具有免疫能力。Tierra中还演化出了间断平衡现象,甚至还出现了社会组织。总之,差不多自然演化过程中的所有特征,以及与地球生命相近的各类功能行为组织,全都出现在Tierra中。 第二类是通过硬件的形式,即通过电线、硅片、金属板、塑料等各种硬件的方法在现实环境中建造类似动物或人类的人工生命。它们被称为“现实的人工生命”或“机器人版本的人工生命”。 美国的赫德·利普森和乔丹﹖波拉克与2000年研制出来的进化的机器人是这类人工生命的代表。他们先在计算机上设计出由硬杆、传动装置、球状关节和电路组成的、非常简单、不会活动的机器人模型,然后为它设计“进化”程序,使得计算机每隔一段时间对设计模型进行一些修改。新模型中最灵活的被保留下来继续“进化”,不灵活的则被除掉。经过几百代的“进化”,计算机选择了最成功的几种模型,并控制自动生产机械制造出一些会爬或跳,能越过障碍物的机器人。 第三类是通过“湿件”的方式,即在试管中通过生物化学或遗传工程的方法合成或创造人工的生命。不过这种方法在目前并不能从头开始,即完全从无生命物质开始合成生命,而只能对现有的生命进行改造创造人工生命,比如克隆羊就是如此。因为这种工作基本运用的仍然是传统的生物学的方法,所以,作为一个新的研究领域的人工生命目前还属于计算机科学的一个分支,主要由一些计算机专家在进行研究。 走向生命的信息定义 上述人工生命能够遗传、变异、进化,拥有传统描述性定义所描画的生命的多种特征。虽然人参与了部分设计,但它们的行为并不是人工的,而是它们自己产生的。所以,人工生命奠基人兰顿和其他一些研究者认为,人工生命确实是真正的生命。 如果我们承认这一点,那么,一些传统观念就必须改变。生命当然得有物质基础,但它最核心的东西将不再是具体的物质,而是控制生命的逻辑。如果甲物质构成的生命的逻辑能在乙物质中完全体现出来,乙物质就是不同材料的另外一种生命。 李建会指出,在控制生命的逻辑中起关键作用的是自我繁殖信息系统。这类系统有两种作用:“一方面,它起到类似计算机程序的作用,在繁殖下一代的过程中它的表达产生出与自己基本相同的新个体,另一方面,它还起到被动数据的作用,在繁殖下一代的过程时可以基本不变地传递给下一代。” 学过生物学的人都知道,DNA所携带的遗传信息所起到的正是这两方面的作用。也就是说,生命的本质在于信息,它在以DNA(有时候是RNA)为主的物质系统中表达出来时,就形成了地球上“如吾所识的生命”;如果它物化在别的形式中,就形成别的“如其可能的生命”。
人工生命 v1.0 这是一个以“造人”为终极目标的项目,并不是一个实用的、可以马上在实际中使用的项目,目前还处于初始阶段,作者本人也处于探索中,希望有兴趣者能加入,早日在码云上创造出一个真正意义上的人工生命。 简介 | Introduce 目前人工智能的研究主要集中在算法上,下面这张图看了有什么感觉: 绝对是四个字: 一脸懵逼。(原贴位于[这里]) 对于普通程序员来说,是不可能学会上述知识树
一个基于“The Prestige Tree”的增量游戏引擎。它仍然需要编程知识,但它主要是非常简单的事情和复制/粘贴。
当在第四章讨论引用时,我们遗漏了一个重要的细节:Rust 中的每一个引用都有其 生命周期(lifetime),也就是引用保持有效的作用域。大部分时候生命周期是隐含并可以推断的,正如大部分时候类型也是可以推断的一样。类似于当因为有多种可能类型的时候必须注明类型,也会出现引用的生命周期以一些不同方式相关联的情况,所以 Rust 需要我们使用泛型生命周期参数来注明他们的关系,这样就能确保运行时实际使用的
本文向大家介绍Servlet生命周期与工作原理详解,包括了Servlet生命周期与工作原理详解的使用技巧和注意事项,需要的朋友参考一下 本文为大家分享了Servlet生命周期与工作原理,供大家参考,具体内容如下 Servlet生命周期分为三个阶段: 1、初始化阶段 调用init()方法 2、响应客户请求阶段 调用service()方法 3、终止阶段 调用destroy()方法 S
每一个编程语言都有高效的处理重复概念的工具;在 Rust 中其工具之一就是 泛型(generics)。泛型是具体类型或其他属性的抽象替代。我们可以表达泛型的属性,比如他们的行为或如何与其他泛型相关联,而不需要在编写和编译代码时知道他们在这里实际上代表什么。 同理为了编写一份可以用于多种具体值的代码,函数并不知道其参数为何值,这时就可以让函数获取泛型而不是像 或 String 这样的具体值。我们已经
1.调用全部引擎代码 2.游戏配置 3.UI处理 4.游戏事件以及生命周期 5.游戏呼起入口 调用代码 bricks引擎代码包含原生以及js层部分,旧版本开发者引用protocol.js来进行引擎js层接口的引用。新的开发者推荐使用qqPlayCore.js文件进行引用。单独引用protocol.js的方法也可以正常使用。 protocol.js为qqPlayCore.js的子集,除此外qqPla
注:本文档提供的生命周期指的是 Universal App 的生命周期,它依赖 rax-app 提供的 runApp方法。 App 级生命周期 launch 在 App 启动时触发 使用生命周期 你可以使用 rax-app 提供的 useAppLaunch 来注册 App 级别的生命周期。 示例: import { useAppLaunch } from 'rax-app'; useAppLa
我们大致为WebAPplication设计了4个生命周期: 请求初始化其实就是从URL中解析提取出{module}, {action}, {method}; 然后再根据{module}, {action}, {method}找到对应的Controller文件; 然后再调用对应的{method},完了之后再发送响应。当然响应的过程中肯定是要顺带着解析下模板标签啦。 恩,这就完了,貌似感觉很简单啊。