Flyable is a Python compiler that generates optimized native code to improve the performance of Python workloads.
Project description
A Python compiler for highly performant code.
Check the website for more information.
Introduction
Welcome to the official Flyable PyPI page! 😊🎉🥳
Flyable is a Python just-in-time compiler that generates optimized native code to decrease Python workloads.
Flyable works hand in hand with the interpreter in the sense that when Flyable can compile a function or method it does so and the interpreter executes that compiled function at runtime and otherwise Flyable lets the interpreter interpret this function or method.
Benchmarks
Detailed benchmarks to come soon! You can see previous benchmarks here.
Supported platforms
Flyable currently supports the following OS and architectures:
🪟 x86 instructions that run on Windows 64 bits.
🍎 ARM instructions that run on MacOS 64 bits.
🐧 x86 instructions that run on Linux 64 bits.
32 bits support isn’t planned in the near future.
Getting Started
All you will need is a working CPython installation (do not run Flyable inside a venv) and some Python code to compile. Simply install Flyable on your computer using the pip command pip install flyable and you will be ready to start using Flyable! Once this is done add these two lines in your python code:
import flyable
flyable.run(email="your.email@domain")
Now if you run your code, Flyable will compile it and execute it. Since we are still working on the beta version, we collect emails in order to ask for feedback. We will only use your email for this purpose and will not share it with anybody else.
How does it get faster ?
Flyable does multiple things to generate efficient code but most of the performance gains come from the following:
- Native execution of the code
- Static function dispatch (enabling direct call and efficient inlining)
- Type tracking (When possible)
- Function specialization depending on the signature but also on the usage
Roadmap
Our work is currently focused on integrating new optimizations and getting the compiler to support more syntactic features in order to increase the proportion of functions and methods that are compiled. 🛣️🚗
Contributions
If you want to participate and/or support the active development of Flyable:
- Let us know what is your use case for Flyable.
- Add a GitHub star to the project. ⭐
- Tweet about the project on your Twitter.
- Submit bugs and feature requests. 🐞
Keep in touch
- If you have any technical question, you can write a question on Stack Overflow.
- Follow us on Twitter or LinkedIn.
- Feel free to contact us on Discord or at contact@flyable.dev if you have any other concerns.
Licence
Flyable is licensed under the GNU Affero General Public License v3.0 .
Acknowledgments
🐉 LLVM is one of the powerful optimizing machines running under the hood.
🐍 CPython is ubiquitous in this project.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for flyable-0.0.1.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 54b92eda00ac3b76b6b4fee8ca2789c32321e02cd8df1ece0732040eea555487 |
|
MD5 | 2d90a3aa1502c5836aba343b94541357 |
|
BLAKE2b-256 | 710afb44d62448d729594baab73535f1a445adbbecbc3675956742a99df12f39 |