为并行处理和云计算而生 Julia诞生记

导读:本文探讨了Julia语言的开发缘由以及它的新特性。笔者认为一门新语言的诞生势必会掀起一阵新的旋风,开发者在享受它带来乐趣的同时也在为它的存在价值而争论不休,究竟Julia能否给开发者带来新的福音呢?让我们来一同走进它:

为什么要创建Julia编程语言?

用一句话来说,因为我们求知若渴、不断追求。

我们拥有Matlab核心用户,有擅长Lisp方面的黑客,Pythonistas和Rubyists方面的专家也有不少;此外,还有一些是Perl方面的大牛,有一部分开发者在我们刚略懂皮毛前便使用了Mathematica。换句话说,他们懂的不仅仅是皮毛,比起其他人,开发R语言要多的多。而C语言对我们来说却是一块荒岛。

我们非常热爱这些语言,他们是如此的完美和强大。我们在科学计算、机器学、数据挖掘,大型线性代数和分布式并行计算做了大量的研究工作——可以说每个项目都有各自的优势,甚至给其他人产生畏惧。任何一个项目都会权衡考量。

我们贪婪,我们想要的更多。

我们需要有一门开源语言,这门语言在行业内是被公认许可的(基于许可证情况下)。我们希望这门语言能够有C语言一样的速度,Ruby一样得活力(dynamism)。我们需要像homoiconic一样的语言,它像Lisp一样有宏,但是也像Matlab一样有显而易见、熟悉的数学标记。

我们希望传统的编程语言像Python一样适用,像R语言一样适用于统计,像Perl一样适用于字符串处理,像线性代数Matlab一样强大,像DOS命令一样擅长粘合程序。这似乎看起来简单易学,但是想要让黑客乐意去迎合它却不是简单之事。我们希望它具有互动性且能够被编译。

像C语言一样运行速度之快?

希望提供的需求:Hadoop分布式核心,因为没有Java和XML千字节的样板文件,无法在数百台机器上通过千兆字节的日志文件进行筛选查找Bug。

拒绝复杂化的操作权限。我们想写一段简单的分等级的循环(代码),这段循环(代码)通过一个单核CPU上的寄存器利用严密的机器代码就可以编译。比如写一个A*B的代码,然后用一千台计算机进行1000次计算,这些计算机放在一起就是一个巨大的矩阵产品。

当我们不喜欢类型时,永远不会提起它。当需要动态函数时,需要利用泛型编程来编写算法并将其应用到类型中,寻求最佳方法从多重角度且有效的为所有函数挑选参数,通过数十种方法来定义不同类型间的共同特性,付出这么多的努力,我们无非是想语言变得更加简单、干净。

所有这些要求看起来并不过分,对吗?

大约两年半前,开始着手开发这门语言,那时还不是完整版,随着发布时间临期将至,最终1.0版酝酿而生——我们将其命名为Julia。

1.0版基本上90%达到了我们的“无理”要求。而现在需要您来提出“无理”要求并进一步改造它。因此,如果您也是一名积极进取、求知若渴的程序员,您不妨来试一试。

编程语言新宠——Julia诞生

Julia是一个新的高性能动态高级编程语言。语法和其他编程语言类似,易于其他语言用户学习。Julia拥有丰富的函数库,提供了数字精度、精致的增幅器(sophisticated amplifier)和分布式并行运行方式。核心函数库等大多数库是由Julia编写,但也用成熟的C和FORTRAN库来处理线性代数、随机数产生和字符串处理等问题。Julia语言可定义函数并且根据用户自定义的参数类型组合再进行重载。

JIT高性能编译器

Julia使用的JIT(Just-in-Time)实时编译器很有效地提高了它的运行效率,在某些地方甚至能比得上C和C++。

下面通过标准测试程序来测试下它的效率,你可以自己比较下各语言的运行效率。

注:运行环境是MacBook Pro,2.53GHz,Intel Core2 Duo CPU和8G 1066MHz,DDR3内存。

上表中只有C++运行时间是绝对时间,其它都是相对于C++的相对时间,数值越小代表用时越少。除少数几项测试Julia惜败于Matlab和JavaScript外,Julia完胜其他高级语言,甚至在pi summation上,成功以25%的优势击败C++。通过使用Intel核心数学库(MKL),MatLabs在矩阵乘法运算中稍占便宜,但是拥有MKL授权的Julia同样可以使用Intel MKL库,不过默认的开源BLAS库性能也不错。

这个测试表是通过编译器性能对一系列常用代码模式进行分析而得出的。比如:字符串解析、函数调用/回调、排序和数值循环、生成随机数和数组运算等。

Julia克服了高级语言一直难以逾越的难关:标量算数循环(在pi summation上就能体现出来。)。Matlab的浮点运算JIT和 V8 JS引擎对此也处理得很好。但JS不支持LAPACK等线性代数库导致了在矩阵运算中的低性能,而Julia有比较多的方法消除负载(overhead),使得它可以轻松支持任何函数库。

矩阵统计的Julia代码虽然性能上比不上C++但却要简洁得多。然而,规范和编制太过随意可能会在将来成为一个问题。

Julia代码示例:

为并行处理和云计算而生

Julia为分布式计算提供很多关键模块,使得它可以更加灵活地支持多种并行处理。

虽然还是早期版本,Julia已经支持了云计算。下面是基于交互性的Julia会话截图:

Julia将提供更加完整的性能支持云计算操作,比如分享和编辑,包括数据管理、数据挖掘和可视化操作等。它还允许用户操作大数据类型而不用关心数据操作行为。

免费、开源和Library Friendly

TJulia的核心代码遵循MIT协议,而其他库各自遵循GPL/LGPL/BSD等协议。用户还可以方便地将Julia作为核心功能共享库与C/FORTRAN代码联合使用。

(责任编辑:蒙遗善)

时间: 2024-08-02 23:52:17

为并行处理和云计算而生 Julia诞生记的相关文章

Chrome OS:为云计算而生的新型操作系统

技术迷们关注的Google与微软的争斗又出现了新的契机,随着Chrome OS的降临,让桌面操作系统更新换代的梦想恐怕即将成真.早在2006年时,就传闻Google即将要推出一款全新的桌面操作系统,结果到头来这个项目却只用在内部使用.之后又出现了Android,再次传闻Google可能将这款智能电话操作系统移植到传统的个人电脑上,这再次引起了市场的骚动――当然还是有许多人表示持怀疑态度.但如今Chrome OS的发布有望将之前任何萦绕在脑际的怀疑一举打消. 不过并非所有人都把这个搜索巨头的最新举

Chrome OS:为云计算而生的底层引擎

7月31日消息,据国外媒体报道,微软CEO史蒂夫·鲍尔默(Steve Ballmer)周四承认,微软的核心业务Windows正遭受谷歌和苹果等对手的挑战. 除了常见的盗版.新兴市场和上网本等问题,鲍尔默承认,Windows正面临竞争对手操作系统的挑战.他说:"我们的挑战来自许多不同的地方."其中,鲍尔默提到了Linux.苹果和谷歌Android及Chrome OS. 鲍尔默说:"尽管我还不知道Chrome OS是什么样,但我现在把它列在竞争对手的名单上."7月8日,

张小龙的微信帝国诞生记

2010年11月20日这一天,在广州,一个六七人的产品小组正式组建.2011年10月1日,这个产品小组的一款产品登上了中国移动互联网即时通讯工具软件第一的位置. 这款产品叫"微信",主导了这款产品的人是张小龙,时任腾讯广州研发部总经理. 短短三年时间,微信几乎已经成为中国每一款智能手机上必然会被安装的应用,微信能有此影响力,不惟有腾讯这棵"参天大树"的庇护和输送养料,亦有赖于微信产品团队对产品的打磨.把控.而一直以来,张小龙,这个主导了中国时下最火的社交应用的中年男

设计案例分析:QQ公益图标诞生记

永不熄灭的爱心图标--腾讯公益月捐计划 "QQ首席图标"诞生记 腾讯"月捐计划"倡导爱心人士,通过每月小额捐款的形式,长期关注和支持公益项目.并和亿万爱心网友一起,每人每月1份爱,点滴付出,汇成爱海,形成强大公益合力,随时帮助需要帮助的人! "QQ公益图标"正式亮相,让QQ用户轻松实现献爱心的公益愿望. "月捐计划"的icon设计是一次重大的挑战,因为赋予它的意义非凡,被点亮后,将排列在迷你资料卡上的第一位,是QQ用户的&qu

云上开发者全新体验——OpenAPI Explorer诞生记

摘要: 本文的整理自2017云栖大会-南京峰会上阿里巴巴资深开发工程师黄俊华的分享讲义,讲义主要对于云上的开发工具进行了详细的介绍,先后介绍了SDK.API文档.Cli调试工具以及OpenAPI的相关知识,并着重对于OpenAPI Explorer进行了介绍. 在2017云栖大会-南京峰会上,阿里巴巴资深开发工程师黄俊华做了题为<云上开发者全新体验--OpenAPI Explorer诞生记>的分享.他在分享中对于云上开发工具中的SDK.API文档.Cli调试工具以及OpenAPI的相关知识进行

为云计算而生 云计算服务器不完全收集

目前还无法给"http://www.aliyun.com/zixun/aggregation/14082.html">云计算服务器"做出确切定义,按照字面理解,它是一类"适合云计算"的服务器,而并非是一种特定的服务器类型,适合云计算应用的机架.刀片等服务器均可以称之为云计算服务器.云计算需要大规模部署,对每个节点的计算能力要求并不十分苛刻,但是要求服务器具有更高的部署密度.更加节能而易于管理.通用性服务器由于要适应多种应用,比如要兼顾性能.扩展性,而

5年间云计算将在全球诞生1400万工作机会

来自IDC的研究显示,http://www.aliyun.com/zixun/aggregation/13637.html">云计算产业在2011年到2015年的5年间,至少产生全球近1400万个就业岗位,通过云计算的IT业务创新,全球相关的收入有望达到1.1万亿美元. (责任编辑:吕光)

心情娃娃诞生记(恋爱娃娃)

六.恋爱娃娃 最后,让我们以一个浸沐在爱心中的娃娃来结束这篇文章. 1.打开最初的娃娃文件,另存为Loving.psd,将前景色设为RGB(255,134,197),用这种娇嫩的粉色填充图层Face的不透明区域. 2.将Eye L和Eye R拼合,复制,把副本向下移动,同时降低Eye L层的不透明度,在Eye L层中载入副本选区,删除,取消选择后删除副本层,恢复Eye L的图层不透明度.(图24) 图24 3.删除mouth层,复制Face层两次,将两个副本层填充不同的颜色以作区别,再分别做不同

UC8.0诞生记 应用中心图标设计教程

应用的时代到来?毋庸置疑的回答是"Yes!".无论是PC.Web还是移动终端,都迎来自己"应用化"的春天.当然,随着UC8.0各线浏览器产品的发布,UC浏览器的粉丝们不难发现,"应用化"的道路上出现了大家挚爱的UC嘞,可喜可贺呀! 找好自己的风格!这是我们开始图标设计之前需要想好的.平面的?立体的?写实的?卡通的?等等.这个过程也许很长,也许会很短.灵感这东西很难琢磨.当我们想好大体的形状,我们就可以先动手画几个"模拟"图标,