This is how Python currently runs programs.
data:image/s3,"s3://crabby-images/9f936/9f936310cb3ebccfd874d83c30d64f4e53c841a1" alt=""
Suppose the interpreter is in Python instead of C. Ignoring performance, this would be a great setup since we could work in Python rather than C. But we cant ignore performance! This setup would be slow.
data:image/s3,"s3://crabby-images/842d4/842d41692284a622513a4d4bd3469bbe50b6afb1" alt=""
So if we have to get back to the speed levels of the existing CPython setup, we would have run an interpreter based in C rather than in Python. How about we keep the source file of the interpreter in Python but use a translator to convert the code to C? Then we can still write the interpreter in Python and also get a functioning interpreter that’s fast as C.
data:image/s3,"s3://crabby-images/bf794/bf79421afae3d6182c0046e0bf1ef4fb3e5f2287" alt=""
But are we sure that a translated interpreter will always be as fast as or faster than the original C interpreter? Are there other ways we can increase the speed of this setup? Yes! Instead of just a translator, use the JIT (just-in-time) compiler-generator to generate a JIT compiler out of the Python interpreter.
data:image/s3,"s3://crabby-images/52e56/52e5694289078e05c718c1f6d06cf36465629040" alt=""
Points to note:
- The interpreter written in Python in PyPy is actually written in RPython, a restricted version of Python that is statically-typed. This is to enable generation of a more-efficient program for the target platform.
- The JIT Compiler generated uses a different approach than the JIT compiler that can be generated for the CPython version (Psyco) and according to the PyPy site has demonstrated superior performance, even though its still a work in progress.