From 7f34d95b23a43d1cd5bfb849bc98bd7e545b202d Mon Sep 17 00:00:00 2001 From: Paul Sokolovsky Date: Fri, 15 May 2015 15:02:12 +0300 Subject: [PATCH] Full disclosure about performance --- FAQ.md | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 7fe869c..56c64c5 100644 --- a/FAQ.md +++ b/FAQ.md @@ -10,7 +10,14 @@ **How fast is micropython?** -> Check out the **[[Performance]]** wiki page for some samples. +> We try to make MicroPython have about same, or better, average performance as CPython, while offering considerably smaller memory footprint (both code ("ROM") and heap ("RAM") sizes). Optimizing for size is known to be opposite of optimizing for speed, so in some cases MicroPython may be slower (an example is diversified access to large dictionaries). However, on some operations (like integer arithmetics), MicroPython can be around 10 times faster than CPython (note that CPython itself is being optimized, so newer versions may be faster than older). + +> Additionally, on select architectures (which include the most popular ones like x86, x86_64, ARMv7), MicroPython offers an ahead-of-time compiler for large subset of Python language, which may increase performance 2 times on average. Beyond that, MicroPython offers "viper" native compiler for a smaller subset of Python language, which offers near-C speed for arithmetic/memory operations. As a final touch, MicroPython offers inline assembler support (currently only for ARMv7 (Thumb2)), for really performance-critical cod. + +> Summing up, MicroPython offers wide selection of performance options and optimizations, allowing you to get the performance you need - all available even on a microcontroller! + +> * Some informal performance samples: **[[Performance]]** +> * Continuous Integration performance testing: http://micropython.org/resources/code-dashboard/ (look for "pystones" curve). **How many platforms are supported by micropython**