原文地址:

https://blog.csdn.net/seekiu/article/details/47397067

随着  Julia 1.0版本的推出,人工智能圈子比较炸锅, 好像这门小众语言要赶超Python了, 作为现在编程领域的大佬,Python最被人诟病的就是运算性能,恰巧 Julia 是已高性能并行计算为主打,并且兼顾了语法简洁和动态性,好奇之下找了找网上的相关资料,发现确实是太小众了,最后发现了下面这篇文章,觉得有些用处。

以下为原文内容:

上一篇博文中推荐了 Python 的 JIT 编译器 numba,这两天又用空余的时间尝试了一下最近的一个新兴语言 Julia。Julia 的目标设定得很高,未来是要成为一个速度上接近甚至超过 Fortran/C 这样的传统语言的通用编程语言。然而就我这两天很初步的尝试结果看来,它也许有这个能力,但至少目前,对工程计算的人来说,还没有达到 production-ready 的程度。(当然,这只是基于我个人的编程经验和需求的结论,很可能不适用于其他人。而且Julia本身是一门相对年轻的语言,很值得持续关注。)

之所以这样说,有三个方面的理由:

  1. 作为一个动态语言,它的 JIT 编译器(在很多情况下)还没有智能到,让我可以同时享受动态语言的便利和它的速度优势。例如最近我在试用 Julia 时最先尝试的就是把原来用 Numba 写的函数重写一遍,然而发现结果非常不好。Julia 版本的函数执行速度相当于纯 Python 的速度,与 Numba 版本相差三个数量级,占用的内存也异常地大。后来发现,最主要的原因是三层嵌套循环中,循环长度我按 Python 的习惯定义为变量,而在 Julia 中不变的全局量最好声明为常量。仅仅这个修改,让速度提升了两个数量级,但还不及 numba 的速度。进一步的测试还可以通过一些细小的地方来进一步提升速度,如这篇文章做的那样,最终高度优化之后速度也许可以达到接近 Fortran。但是,如果要这样做,为什么不干脆用 Fortran 呢?相比之下,numba 的可用性就要高太多了。不过毕竟它现在的稳定版本还是0.3.10,还需要再给它一点时间发展成熟。

  2. 作为一个新兴、小众的语言,相关的工具链还太弱了。没有合格的 IDE,Juno 在我看来现在连半成品都还算不上。包管理似乎是用的 Git,有时会出一些奇怪的问题,这时候用 Pkg 倒还不如手动去管理。调试程序也比较痛苦,一方面是很多错误信息跟没给差不多,像我这种不熟悉的人基本只能用 print 一半一半地查,另一方面是相关的调试工具也还不够好用。

  3. 文档、相关信息还太少。已经有不少人开始使用 Julia,但网上公开的信息中,官方的文档还比较简陋,其他用户贴出的博客也很少。这导致在遇到问题的时候,很难快速地难过 Google 直接得到问题的答案,而往往需要在社区中等待圈内人士的解答。

另外一个对 Julia 印象不太好的是,官网给出的 benchmark 没有多少参考价值,至少其结果中 Python 和 Matlab 都很有问题,多半是单纯地逐行翻译出来的程序。这就跟我把 numba 的程序直接翻译成 Julia,然后得出结论它很慢一样,是不公平的比较。

不管怎么样,Julia 目前看来还是值得持续关注的,但是目前,我还不会考虑把它作为主要的计算语言。

初试 Julia 语言 (转)的更多相关文章

  1. Julia语言:让高性能科学计算人人可用

    Julia语言:让高性能科学计算人人可用要:一群科学家对现有计算工具感到不满:他们想要一套开源系统,有C的快速,Ruby的动态,Python的通用,R般在统计分析上得心应手,Perl的处理字符串处理, ...

  2. Julia语言程序基础

    Julia-lang 新兴的Julia语言,Julia 一开始就是为高性能而设计的. Julia 程序通过 LLVM 编译成高效的多平台机器码. Julia中文社区: https://cn.julia ...

  3. Julia语言介绍

    官网:https://julialang.org/ 中文社区:https://cn.julialang.org/ Julia 是一个面向科学计算的高性能动态高级程序设计语言. 首先定位是通用编程语言, ...

  4. Julia 语言的一些尝试

    前些天发现了Julia 这门编程语言后便决定对其进行一些尝试,便写了下面的小程序,也算是看看这门语言所谓的速度快到底是怎么快法. 整数累加: x= function fff() : global x ...

  5. 小题精炼-----初试C语言

    毫无疑问, 这个又是给新入门学C语言的小鲜肉准备的! 题解: 1. 直接两个循环就ok啦! 当初讲课的时候几乎讲过原题啦. 2. 直接 100的三次方就是1000000啦, 所以直接对某数的三次方开方 ...

  6. Julia 语言

    同时安装多个库 Pkg.add.(["IJulia", "Combinatorics", "Plots", "TaylorSeri ...

  7. 《C Primer Plus》- 第一章 初试C语言

    本笔记写于2020年1月25日. 从今天开始,我要全面的.彻底的将未来计划中所有的知识重新规划学习一遍,并整理成一套全面的笔记体系.为我将来的职业打下坚实的基础.而所有的一切从C语言开始. 本系列文章 ...

  8. 在天河二号上对比Julia,Python和R语言

    Julia是一款高级高效为技术计算(technical computing)而设计的编程语言,其语法与其他计算环境类似.其为分布式计算和并行所设计,最知名的地方在于其接近C语言的高效率. 按开发者的话 ...

  9. AdaBoost对实际数据分类的Julia实现

    写在前面 AdaBoost是机器学习领域一个很重要很流行的算法,而Julia是一门新兴的发展迅速的科学计算语言.本文将从一个实际例子出发,展示如何用Julia语言实现AdaBoost算法. 什么是Ad ...

随机推荐

  1. 模块讲解----XML模块

    XML实现不同语言或者程序之间进行数据交换的协议XML文件格式如下: 1.浏览器返回的字符串格式类型有: a.HTML b.Json c.XML 2.XML格式如下: <data> #表示 ...

  2. The same month as the adidas NMD Singapore is releasing

    Earlier this December 2017, the inaugural adidas NMD Singapore silhouette released in the first colo ...

  3. 【cocos2d-x 3.5】Lua动画API

    1.加载动画 local node = cc.CSLoader:createNode("ActionTimeline/DemoPlayer_skeleton.csb") local ...

  4. 查准率与查全率(precision and recall) 的个人理解

    假设要识别照片中的狗的,在一些照片中,包含12只狗的照片和一些猫的照片.算法识别出有8只狗.在确定的8只狗中,5只实际上是狗(真阳性TP),而其余的是猫(假阳性FP).该程序的精度为5/8,而其召回率 ...

  5. Python3.6(windows系统)解决编码问题

    Python3.6(windows系统)解决编码问题 1,py文件代码: import urllib.request url = "http://www.douban.com/" ...

  6. 20145319 return-to-libc攻击实验

    20145319 Return-to-libc攻击实验 一 实验内容 return-to-libc实验是一个基于缓冲区溢出攻击实验的基础上的一种攻击实验 缓冲区溢出攻击相关知识: 原理:通过一段包含s ...

  7. 20145326 《Java程序设计》第5周学习总结

    20145326 <Java程序设计>第5周学习总结 教材学习内容总结 第八章 一.语法与继承结构 1.使用try .catch 我们编写程序时总有些由意想不到的状况而引发的错误,java ...

  8. 2017-2018-1 Java小组-1623 第一周作业

    2017-2018-1 Java小组-1623 第一周作业 <构建之法>学习笔记及团队成员介绍 1. 学习内容 概论 个人技术和流程 软件工程师的成长 两人合作 团队和流程 敏捷流程 实战 ...

  9. Linux内核源码目录说明

    Linux内核源代码位于/usr/src/linux目录下,其结构分布如图1.3所示,每一个目录或子目录可以看作一个模块,其目录之间的连线表示“子目录或子模块”的关系.下面是对每一个目录的简单描述. ...

  10. [数据库] - org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection

    MySQL的驱动改名了,如果使用原来的com.mysql.jdbc.Driver 那么会提醒驱动不正常了,那么新的MySQL驱动名为:com.mysql.cj.jdbc.Driver 之后还报错,如题 ...