Review of Julia programming language for scientific computing
2014-01-01·,,·
0 min read
Migran Nelsonovich Gevorkyan
Dmitry Sergeevich Kulyabov
Leonid Antonovich Sevastyanov
Abstract
Julia is new high-level programming language that supports multiple programming styles and primarily focuses on scientific computing [1]. Language has been developed at the Massachusetts Institute of Technology (MIT) in 2009 under the MIT license and is available through the public repository on GitHub [2]. Language is under active development and it’s latest version is 0.3. Language has built-in tools for parallel and distributed computing, and supports multithreading (coroutines). Developers have mentioned that Julia does not impose any particular style of parallelism on the user but provides a set of blocks that allows implementing parallelism as programmer likes. Julia is scientific oriented language and it influence on all aspects of language. There are built-in mathematical oriented data types in Julia, such as rational and complex numbers. Dynamic type conversion avoids a loss of accuracy, which is important in the scientific calculations. Also a large variety of built-in mathematical functions and a large number of libraries are present. One of the main goals of the language was to achiev high performance close to the C/Fortran, and clarity interpreted languages. Besides compiling source files into an executable program julia has the ability to execute language constructs interactively (like interpreted languages), as well as an interface to support iPython. Another key feature of the language is simple API for functions and subroutines of C/Fortran/Python. The standard library has lots of built-in wrappers for popular libraries (eg, BLAS and LAPACK). Also, there is a possibility to connect external libraries C / Fortran / Python. Julia supports multiple programming paradigms: procedural, object-oriented, functional programming. Language is under active development and is replenished with libraries for various fields of mathematics, physics and engineering sciences. 1. The Julia Language — http://julialang.org/ 2. The Julia Language˙GitHub — https://github.com/JuliaLang
Type
Publication
The 6th International Conference "Distributed Computing and Grid-technologies in Science and Education"