Why is LuaJIT so good?
LuaJitLuajitLua Problem Overview
EDIT: unfortunately LuaJIT was taken out of the comparison in the link below.
This http://shootout.alioth.debian.org/u64/which-programming-languages-are-fastest.php">comparison</a> of programming languages shows that LuaJIT has an over tenfold improvement over the normal Lua implementation. Why is the change so big? Is there something specific about Lua that makes it benefit a lot from JIT compilation? Python is dynamically typed and compiled to bytecode as well, so why doesn't PyPy (that has JIT now, I believe) show such a large jump in performance?
Lua Solutions
Solution 1 - Lua
Mike Pall has talked about this in a few places:
- http://article.gmane.org/gmane.comp.lang.lua.general/58908
- http://lambda-the-ultimate.org/node/3851
- http://www.reddit.com/user/mikemike
As with every performant system, the answer in the end comes down to two things: algorithms and engineering. LuaJIT uses advanced compilation techniques, and it also has a very finely engineered implementation. For example, when the fancy compilation techniques can't handle a piece of code, LuaJIT falls back to an very fast interpreter written in x86 assembly.
LuaJIT gets double points on the engineering aspect, because not only is LuaJIT itself well-engineered, but the Lua language itself has a simpler and more coherent design than Python and JavaScript. This makes it (marginally) easier for an implementation to provide consistently good performance.