MicroPython

MicroPython

Postby keithsloan52 » Wed Oct 12, 2016 4:31 pm

Would micropython https://micropython.org be a good fit for parallela?
keithsloan52
 
Posts: 17
Joined: Fri Mar 07, 2014 9:22 am

Re: MicroPython

Postby jar » Thu Oct 13, 2016 4:14 pm

It probably makes more sense to run that on the ARM host, not the Epiphany cores. I'm not sure it could even be ported to an Epiphany core without substantial effort. So why not use regular Python on ARM if that's what you want?
User avatar
jar
 
Posts: 295
Joined: Mon Dec 17, 2012 3:27 am

Re: MicroPython

Postby polas » Fri Oct 14, 2016 11:09 am

This certainly looks like an interesting project, but as Jar says in its current form it is more applicable for the host rather than the Epiphany. I see the interpreter needs 256KB with a minimum 16K RAM needed, each Epiphany core has 32KB memory so currently this implementation goes quite a way beyond the on-core limits... You could pop the interpreter in shared memory and just use the on-core RAM for heap/stack but that will likely have a significant performance penalty. The Epiphany is far more accelerator than CPU in terms of it doesn't have any direct IO etc so again that is something that would need to be addressed on the host side. These could be done, but it moves quite a way away from where that implementation currently is which is of no surprise as it is currently targeted more at embedded rather than many-core. With ePython we do all the lexing/parsing/byte code building etc on the host and have the minimum amount running on the Epiphany (the interpreter & runtime takes up 24KB of on-core memory, with the rest reserved for byte code, heap, stack etc but this can all transparently wrap over onto shared memory.)

Where these things become more interesting is running in hybrid mode, where someone can run full Python code in an existing interpreter (maybe CPython) on the host and off load certain Python kernels to the Epiphany cores. ePython currently supports this, with ePython taking care of the Epiphany side and a Python module imported in the host code to allow for the two to communicate. Currently it is designed for eduction/prototyping and certainly it won't be as fast as C but I think additional optimisations on the ePython side (such as JIT compiling) could make it more compelling for application usage too.

Nick
polas
 
Posts: 46
Joined: Thu Mar 05, 2015 9:41 pm


Return to Python

Who is online

Users browsing this forum: No registered users and 2 guests