Differences between revisions 9 and 21 (spanning 12 versions)
Revision 9 as of 2011-03-24 16:49:44
Size: 2579
Editor: PaulBoddie
Comment: Added some links to CPython optimisation topics.
Revision 21 as of 2022-02-02 18:15:38
Size: 3363
Comment:
Deletions are marked like this. Additions are marked like this.
Line 2: Line 2:
Line 6: Line 5:
Line 12: Line 10:
 * [[http://www.raspberrypi.org/|Raspberry Pi]]
 * [[http://beagleboard.org/Products/BeagleBone%20Black|BeagleBone Black]]
Line 15: Line 15:
See also [[PythonForArmLinux]] and [[OpenEmbedded]]. See also PythonForArmLinux and OpenEmbedded.
Line 17: Line 17:
== Work to improve CPython for embedded applications ==
Line 21: Line 22:
 * File access overhead on startup: [[http://mail.python.org/pipermail/python-list/2008-October/564494.html|Improving interpreter startup speed]]  * General interpreter startup costs: SpeedUpInterpreterStartup
 * File access overhead on startup: [[http://mail.python.org/pipermail/python-list/2008-October/467718.html|Improving interpreter startup speed]], [[http://mail.python.org/pipermail/python-list/2005-May/339691.html|Tons of stats/opens to non-existing files increases Python's startup on loaded NFS servers]], [[http://mail.python.org/pipermail/python-dev/2003-May/035359.html|Startup time]]
 * Import-related costs: [[http://mail.python.org/pipermail/python-dev/2010-March/098042.html|__file__]]
 * Using a launcher process where "expensive" modules are required: [[http://blogs.gnome.org/johan/2007/01/18/introducing-python-launcher/|Introducing python-launcher]]
Line 24: Line 28:
Line 31: Line 34:
 * [[Zerynth]] formerly Viper
Line 32: Line 36:
On yet another hand, one can start with a full build, and simply
remove unneeded modules--Tkinter, ...--to realize
a reduced-size Python
with little effort.
On the other hand, one can start with a full build, and simply remove unneeded modules, ''e.g.'', Tkinter, etc., to realize a reduced-size Python with little effort.
Line 38: Line 39:
Line 41: Line 41:
Tools which support this kind of development include the following: Tools that support this kind of development include the following:
Line 43: Line 43:
 * [[http://myhdl.jandecaluwe.com/|MyHDL]]
 * [[http://www.sticlete.com/whatos/|WhatOS]]
 * [[https://myhdl.org/|MyHDL]]
 * [[https://sourceforge.net/projects/whatos/|WhatOS]]

Embedded Python

Python can be used in embedded, small or minimal hardware devices, depending on how limiting the devices actually are.

Devices capable of running CPython

Some modern embedded devices have enough memory and a fast enough CPU to run a typical Linux-based environment, for example, and running CPython on such devices is mostly a matter of compilation (or cross-compilation) and tuning.

Devices which could be considered as "embedded" by modern standards and which can run tuned versions of CPython include the following:

See also PythonForArmLinux and OpenEmbedded.

Work to improve CPython for embedded applications

Various efforts have been made to make CPython more usable for embedded applications:

Reduced or reworked Python implementations

Some devices may be more restrictive in that the typical memory footprint of CPython may exceed the amount of memory available on the device. In such cases, a re-engineered or adapted version of CPython, perhaps even to the point where it can be considered a new implementation of Python, might be appropriate.

Examples of such implementations include the following:

On the other hand, one can start with a full build, and simply remove unneeded modules, e.g., Tkinter, etc., to realize a reduced-size Python with little effort.

Python-based tools for developing embedded applications

Sometimes the embedded environment is just too restrictive to support a Python virtual machine. In such cases, various Python tools can be employed for prototyping, with the eventual application or system code being generated and deployed on the device.

Tools that support this kind of development include the following:

EmbeddedPython (last edited 2022-02-02 18:15:38 by SkipMontanaro)

Unable to edit the page? See the FrontPage for instructions.