search
HomeBackend DevelopmentPython TutorialDevelopers take part in person: Compared with Julia language and Python for machine learning, which one is better?

#Which programming language will you choose in 2022?

There has been a saying in the past few years that Julia will replace Python and become one of the new most popular programming languages. We are taking a wait-and-see attitude towards this statement for the time being, but as a powerful tool in scientific computing, Julia's advantages have already emerged, which means that programmers have another choice.

In the fields of data science, artificial intelligence, etc., if we carefully compare Julia and Python, we will find that: the same tasks that Python can achieve, Julia can do, and it is much more efficient and the syntax is concise. Elegant, but not as well-known as Python in terms of spread.

Recently, a hot post on reddit has attracted discussion among netizens. This post mentioned that recently, some developers of Julia language packages discussed the current status of ML in Julia and compared its status with The Python ML ecosystem is compared.

Original post address:

https://www.reddit.com/r/MachineLearning/comments/s1zj44/r_julia_developers_discuss_the_current_state_of /

Jordi Bolibar from Utrecht University believes that "Julia does have great potential for machine learning, but its current status is a bit mixed. More specifically, I insist on using Julia in SciML The main reason is that the DifferentialEquations.jl library works very well, but I haven't found anything similar in Python. However, the real pain for my research is the AD part. Since I started using Julia, I'm in Zygote I encountered two bugs that slowed down my work for a few months. But I still think Julia is the best choice for SciML, but these libraries (and their documentation) should be optimized to be more user-friendly."

Netizen @jgreener64 said: "ML in Julia is very powerful in certain fields. Everything is possible in Julia. The problem faced by Julia is: ML requires a lot of existing knowledge or a lot of time searching/trial and error. On a personal level, I'm currently developing novel differentiable algorithms in Julia."

In addition to the heated discussions among netizens, Julia software package developer Christopher Rackauckas answered the following 7 questions that netizens are more concerned about. Rackauckas is a mathematician and pharmacologist at MIT and the University of Maryland who primarily uses Julia for programming. Rackauckas has opened a dedicated blog for Julia, mathematics, and stochastic biology to introduce related content, and Rackauckas has developed some libraries in Julia, including (but not limited to) DifferentialEquations.jl and Pumas.

##Christopher Rackauckas

Questions include:

  1. Where is ML in Julia really shining today? In what ways will this ecosystem outperform other popular ML frameworks (e.g. PyTorch, Flax, etc.) in the near future and why?

  2. What are the functional or performance shortcomings of Julia’s current ML ecosystem? When will Julia become competitive in these areas?

  3. How do Julia's standard ML packages (e.g. deep learning) compare to popular alternatives in terms of performance (faster, slower, same order of magnitude)?

  4. Are there any important Julia experiments that benchmark popular ML alternatives?

  5. If a company or institution is considering creating a position to contribute to Julia’s ML ecosystem, are there any best practices? Why should they do this? Which contributions have been the most impactful?

  6. Why should independent developers working with other frameworks consider contributing to Julia's ML ecosystem?

  7. What packages do Julia developers tend to use for certain specific tasks? What do Julia developers hope to add that doesn't currently exist?

Below we have selected a few issues that everyone is more concerned about to report:

Question 3: How does Julia perform in "Standard ML"?

Julia's kernel speed is great: on CPU we do very well, on GPU everyone just calls the same cudnn etc; Julia's AD speed is also great. Zygote may have some overhead, but compared to Jax/PyTorch/TensorFlow, Zygote is fast in most cases. Specifically, PyTorch overhead is much higher and cannot even be measured in standard ML workflows. A large enough matrix multiplication will solve the allocation problem or other O(n) problem; Julia does not fuse kernels, so in most benchmarks if the user looks at it, it will see that it does not fuse conv or RNN cudnn calls.

Question 4: What important experiments and benchmarks should we track?

XLA’s distributed scheduler is very good. When we think about scaling, we should ignore PyTorch and think about DaggerFlux and TensorFlow/Jax. XLA has more flexibility to change operations so I think XLA is the winner and we need to use the e-graphs trick to match it. Another thing to note is the "missing middle part in automatic differentiation", which still needs to be solved.

Question 7: What are the recommended software packages?

I tend to use Flux when needed, but everyone should try to use DiffEqFlux. As far as existing kernels go, Flux is the most complete, but its style bores me. I'd like to have a Flux that doesn't use implicit parameters, but explicit parameters. I want these parameters to be represented by ComponentArrays.

The above is the detailed content of Developers take part in person: Compared with Julia language and Python for machine learning, which one is better?. For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:51CTO.COM. If there is any infringement, please contact admin@php.cn delete
Python and Time: Making the Most of Your Study TimePython and Time: Making the Most of Your Study TimeApr 14, 2025 am 12:02 AM

To maximize the efficiency of learning Python in a limited time, you can use Python's datetime, time, and schedule modules. 1. The datetime module is used to record and plan learning time. 2. The time module helps to set study and rest time. 3. The schedule module automatically arranges weekly learning tasks.

Python: Games, GUIs, and MorePython: Games, GUIs, and MoreApr 13, 2025 am 12:14 AM

Python excels in gaming and GUI development. 1) Game development uses Pygame, providing drawing, audio and other functions, which are suitable for creating 2D games. 2) GUI development can choose Tkinter or PyQt. Tkinter is simple and easy to use, PyQt has rich functions and is suitable for professional development.

Python vs. C  : Applications and Use Cases ComparedPython vs. C : Applications and Use Cases ComparedApr 12, 2025 am 12:01 AM

Python is suitable for data science, web development and automation tasks, while C is suitable for system programming, game development and embedded systems. Python is known for its simplicity and powerful ecosystem, while C is known for its high performance and underlying control capabilities.

The 2-Hour Python Plan: A Realistic ApproachThe 2-Hour Python Plan: A Realistic ApproachApr 11, 2025 am 12:04 AM

You can learn basic programming concepts and skills of Python within 2 hours. 1. Learn variables and data types, 2. Master control flow (conditional statements and loops), 3. Understand the definition and use of functions, 4. Quickly get started with Python programming through simple examples and code snippets.

Python: Exploring Its Primary ApplicationsPython: Exploring Its Primary ApplicationsApr 10, 2025 am 09:41 AM

Python is widely used in the fields of web development, data science, machine learning, automation and scripting. 1) In web development, Django and Flask frameworks simplify the development process. 2) In the fields of data science and machine learning, NumPy, Pandas, Scikit-learn and TensorFlow libraries provide strong support. 3) In terms of automation and scripting, Python is suitable for tasks such as automated testing and system management.

How Much Python Can You Learn in 2 Hours?How Much Python Can You Learn in 2 Hours?Apr 09, 2025 pm 04:33 PM

You can learn the basics of Python within two hours. 1. Learn variables and data types, 2. Master control structures such as if statements and loops, 3. Understand the definition and use of functions. These will help you start writing simple Python programs.

How to teach computer novice programming basics in project and problem-driven methods within 10 hours?How to teach computer novice programming basics in project and problem-driven methods within 10 hours?Apr 02, 2025 am 07:18 AM

How to teach computer novice programming basics within 10 hours? If you only have 10 hours to teach computer novice some programming knowledge, what would you choose to teach...

How to avoid being detected by the browser when using Fiddler Everywhere for man-in-the-middle reading?How to avoid being detected by the browser when using Fiddler Everywhere for man-in-the-middle reading?Apr 02, 2025 am 07:15 AM

How to avoid being detected when using FiddlerEverywhere for man-in-the-middle readings When you use FiddlerEverywhere...

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SecLists

SecLists

SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment