2021-12-01 18:45:41 +08:00
< p align = "center" >
2022-02-20 07:44:38 +08:00
< img alt = "logo" src = "document/image/144221063-a85b2cb0-0416-493f-9afb-56cff31e977d.jpg" width = "300" >
2021-12-01 18:45:41 +08:00
< / p >
2023-01-07 16:18:02 +08:00
< h1 align = "center" style = "margin: 30px 0 30px; font-weight: bold;" > PikaPython< / h1 >
2021-12-01 18:45:41 +08:00
< h4 align = "center" > Cross platform ultra lightweight embedded Python engine< / h4 >
< p align = "center" >
2023-01-07 16:16:28 +08:00
< a href = "https://gitee.com/lyon1998/pikapython/stargazers" > < img src = "https://gitee.com/lyon1998/pikapython/badge/star.svg?theme=gvp" > < / a >
< a href = "https://gitee.com/lyon1998/pikapython/members" > < img src = "https://gitee.com/lyon1998/pikapython/badge/fork.svg?theme=gvp" > < / a >
< a href = "https://github.com/pikastech/pikapython/stargazers" > < img src = "https://img.shields.io/github/stars/pikastech/pikapython?style=flat-square&logo=GitHub" > < / a >
< a href = "https://github.com/pikastech/pikapython/network/members" > < img src = "https://img.shields.io/github/forks/pikastech/pikapython?style=flat-square&logo=GitHub" > < / a >
< a href = "https://github.com/pikastech/pikapython/watchers" > < img src = "https://img.shields.io/github/watchers/pikastech/pikapython?style=flat-square&logo=GitHub" > < / a >
< a href = "https://github.com/pikastech/pikapython/issues" > < img src = "https://img.shields.io/github/issues/pikastech/pikapython.svg?style=flat-square&logo=GitHub" > < / a >
< a href = "https://github.com/pikastech/pikapython/blob/master/LICENSE" > < img src = "https://img.shields.io/github/license/pikastech/pikapython.svg?style=flat-square" > < / a >
2023-04-13 15:59:58 +08:00
< a href = "https://github.com/pikasTech/pikapython/actions/workflows/CI.yml" > < img src = "https://github.com/pikasTech/pikapython/actions/workflows/CI.yml/badge.svg" > < / a >
< a href = "https://app.codecov.io/gh/pikasTech/PikaPython" > < img src = "https://codecov.io/gh/pikasTech/PikaPython/branch/master/graph/badge.svg" > < / a >
2021-12-01 18:45:41 +08:00
< / p >
2021-11-17 17:32:48 +08:00
2021-12-01 18:45:41 +08:00
< p align = "center" >
2021-12-03 09:01:25 +08:00
< a href = "README_zh.md" > 中文页< / a > |
< a href = "https://whycan.com/f_55.html" > Forum< / a > |
2022-04-09 13:56:09 +08:00
< a href = "https://pikadoc.readthedocs.io/en/latest/index.html" > Documents< / a > |
2021-12-03 09:10:21 +08:00
< a href = "https://space.bilibili.com/5365336/channel/detail?cid=202329" > Videos< / a > |
2021-12-14 04:24:41 +00:00
< a href = "../../tree/master/bsp #platform -support" > BSP</ a > |
2022-04-09 13:56:09 +08:00
< a href = "https://pikadoc.readthedocs.io/en/latest/%E5%8C%85%E7%AE%A1%E7%90%86%E5%99%A8%E4%B8%8E%E6%A8%A1%E5%9D%97%E7%AE%A1%E7%90%86.html" > Package Manager< / a > |
< a href = "https://pikadoc.readthedocs.io/en/latest/%E5%A6%82%E4%BD%95%E5%8F%82%E4%B8%8E%E7%A4%BE%E5%8C%BA%E8%B4%A1%E7%8C%AE.html" > Contribute< / a > |
< a href = "https://pikadoc.readthedocs.io/en/latest/%E5%95%86%E4%B8%9A%E5%90%88%E4%BD%9C%E6%96%B9%E5%BC%8F.html" > Business< / a >
2021-12-01 18:45:41 +08:00
< / p >
2021-10-21 07:33:12 +08:00
2023-03-08 10:14:56 +08:00
[![image ](document/image/147997370-ff37b6e7-25b2-4174-aa64-c1fb92cede04.png )](https://pikastech.github.io/PikaPython/dev/bench/)
2022-01-04 09:22:21 +08:00
2021-10-20 10:29:40 +08:00
# 1. Abstract
2023-03-16 09:34:10 +08:00
PikaPython is an ultra-lightweight Python interpreter that runs with only 4KB of RAM, zero dependencies. It is ready to use out of the box without any configuration required and easy to extend with C.
2023-01-10 14:40:33 +08:00
PikaPython also known as PikaScript and PikaPy.
2021-10-20 10:33:13 +08:00
2021-12-31 10:33:48 +08:00
< img src = "https://user-images.githubusercontent.com/88232613/147799704-d79345da-a2b9-4593-b1eb-ff9de127429a.png" width = "500" / >
2021-10-20 10:29:40 +08:00
2022-05-23 10:03:49 +08:00
It's very easy to bind C function to python module with the help of Pika Pre-compiler.Only write the API of python in `.pyi` and the bindings are autoly generated by Pre-compiler.
2023-01-07 16:16:28 +08:00
The Pre-compiler is fully open-source, and the source code is in the [tools ](https://github.com/pikasTech/pikapython/tree/master/tools ) folder.
2021-10-20 11:19:54 +08:00
2022-05-20 23:38:40 +08:00
![image-20220520233540245 ](document/image/image-20220520233540245.png )
2021-10-20 11:04:30 +08:00
2023-01-07 16:16:28 +08:00
# Get pikapython:
2021-10-19 19:50:14 +08:00
2022-02-05 15:20:50 +08:00
## Use Online Project Generator
Generator url:
http://pikascript.com
2022-05-22 23:57:36 +08:00
Note: You need the [Community Edition license (Now Free) ](https://www.keil.com/pr/article/1299.htm ) to build Keil projects, and the version of Keil should be newer than v5.36.
2022-07-02 10:42:23 +08:00
[![ ](assets/1644129110261-049ad5bb-21af-40e2-9533-a1c8c86790f1.jpg )](http://pikascript.com)
2022-02-05 15:20:50 +08:00
2022-05-21 18:37:12 +08:00
## Use Pika package manager [PikaPackage.exe](https://pikadoc.readthedocs.io/en/latest/%E5%8C%85%E7%AE%A1%E7%90%86%E5%99%A8%E4%B8%8E%E6%A8%A1%E5%9D%97%E7%AE%A1%E7%90%86.html)
2021-10-19 19:50:14 +08:00
2023-01-07 16:20:52 +08:00
1. Run the [PikaPackage.exe ](https://pikadoc.readthedocs.io/en/latest/%E5%8C%85%E7%AE%A1%E7%90%86%E5%99%A8%E4%B8%8E%E6%A8%A1%E5%9D%97%E7%AE%A1%E7%90%86.html ) directly, then the pikapython repo would be downloaded auto in the /tmp/pikascript folder of your current disc partition.
2021-10-19 20:40:51 +08:00
2023-01-07 16:20:52 +08:00
2. Add [requestment.txt ](/bsp/stm32g070cb/pikascript/requestment.txt ) to the same folder of PikaPackage.exe then run [PikaPackage.exe ](https://pikadoc.readthedocs.io/en/latest/%E5%8C%85%E7%AE%A1%E7%90%86%E5%99%A8%E4%B8%8E%E6%A8%A1%E5%9D%97%E7%AE%A1%E7%90%86.html ). The [run-time core ](../../tree/master/src ), [pre-compiler ](../../tree/master/tools/pikaCompiler ) and [moudles ](../../tree/master/package ) would be installed in the current folder.
2021-10-19 20:40:51 +08:00
2021-10-21 07:57:07 +08:00
3. Released modules: [packages.toml ](packages.toml )
2021-10-19 20:40:51 +08:00
2021-11-11 15:10:11 +08:00
# Quick Start
2022-04-12 22:50:31 +08:00
You can use [simulation project ](https://pikadoc.readthedocs.io/en/latest/Keil%20%E4%BB%BF%E7%9C%9F%E5%B7%A5%E7%A8%8B.html ) to quick start without hardware, or use the out-of-the-box develop board [Pika-Pi—Zero ](https://item.taobao.com/item.htm?spm=a2126o.success.result.1.76224831Y0X1gO&id=654947372034 ).
2021-11-11 15:10:11 +08:00
![image ](https://user-images.githubusercontent.com/88232613/141252834-93011ca7-f84b-4192-8e61-0e242796f62c.png )
2023-01-07 16:16:28 +08:00
The board based on STM32G030C8T6 MCU, only 64kB Flash, 8kB RAM can run pikapython with total peripheral device (GPIO、TIME、IIC、RGB、KEY、LCD、RGB).
2021-11-11 15:10:11 +08:00
CH340 is deployed to support USB to serial with Type-C USB, support download python script py serial, there are 4 RGB on the board and support the [LCD ](https://item.taobao.com/item.htm?spm=a1z10.3-c.w4002-23991764791.12.16f97c58fsLjVk&id=660745643102 ).
2022-05-30 10:13:15 +08:00
# Related Projects
2022-05-30 08:27:37 +08:00
2023-01-07 16:16:28 +08:00
- ▶️ [pikapython Binding For LVGL ](https://github.com/lvgl/lv_binding_pikascript )
2022-11-03 15:38:17 +08:00
2023-01-07 16:16:28 +08:00
- ⭐ [pikapython Bluepill Demo In PlatformIO — Python-like REPL 🐍🔌 ](https://github.com/maxgerhardt/pikascript-pio-bluepill )
2022-05-30 10:14:18 +08:00
2023-01-07 16:16:28 +08:00
- ⭐ [pikapython Bluepill Demo In GCC 🐍 ](https://github.com/Chandler-Kluser/pikascript_gcc_bluepill )
2022-05-30 10:14:18 +08:00
2021-11-09 13:33:37 +08:00
# Document
2022-04-09 13:56:09 +08:00
https://pikadoc.readthedocs.io/en/latest/index.html
2021-11-09 13:33:37 +08:00
2022-06-01 10:02:54 +08:00
## How to contribute
https://pikadoc.readthedocs.io/en/latest/%E5%A6%82%E4%BD%95%E5%8F%82%E4%B8%8E%E7%A4%BE%E5%8C%BA%E8%B4%A1%E7%8C%AE.html
2022-06-01 09:35:02 +08:00
2021-10-19 20:04:41 +08:00
## Folders
[src ](../../tree/master/src ) - core code
2021-10-19 19:50:14 +08:00
2021-10-19 20:04:41 +08:00
[bsp ](../../tree/master/bsp ) - mcu/board support
2021-10-19 19:50:14 +08:00
2022-08-27 15:01:12 +08:00
[port ](../../tree/master/port ) - OS and package manager
[test ](../../tree/master/port/linux/test ) - unit test
2021-10-19 19:50:14 +08:00
2021-10-19 20:04:41 +08:00
[document ](../../tree/master/document ) - developt document
2021-10-19 19:50:14 +08:00
2021-10-19 20:04:41 +08:00
[examples ](../../tree/master/examples ) - example scripts
2021-10-19 19:50:14 +08:00
2021-10-19 20:04:41 +08:00
[package ](../../tree/master/package ) - packages and moudles
2021-10-19 19:50:14 +08:00
2021-10-19 20:04:41 +08:00
[pikaCompiler ](../../tree/master/tools/pikaCompiler ) - pre-compiler write by Rust, used to bind C function to python moudle.
2021-10-19 19:50:14 +08:00
2021-10-19 20:04:41 +08:00
[pikaPackageManager ](../../tree/master/tools/pikaPackageManager ) - pacakge manager
2021-10-19 19:50:14 +08:00
2021-12-02 23:24:24 +08:00
# 2.Platform support
2021-12-14 19:06:49 +08:00
2022-06-29 21:45:51 +08:00
2021-12-14 19:06:49 +08:00
## MCU support
2022-11-30 20:44:28 +08:00
|MCU |bsp|gpio|time|uart|pwm|adc|i2c|dac|
|--- |---|--- |--- |--- |---|---|---|---|
|stm32g030c8 |√ |√ |√ |√ |√ |√ |√ | |
|stm32g070cB |√ |√ |√ |√ |√ |√ |√ | |
|stm32f103c8 |√ |√ |√ |√ |√ |√ |√ | |
|stm32f103rb |√ |√ |√ |√ |√ |√ |√ | |
|stm32f103ze |√ |√ |√ |√ |√ |√ |√ | |
|stm32f103rc |√ |√ |√ |√ |√ |√ |√ | |
|stm32f401cc |√ |√ |√ |√ |√ |√ |√ | |
|stm32f411ce |√ |√ |√ |√ |√ |√ |√ | |
|stm32f407ze |√ | | | | | | | |
|stm32f407zg |√ | | | | | | | |
|stm32h750vb |√ | | | | | | | |
|stm32f051r8 |√ | | | | | | | |
|air32f103cb |√ |√ |√ | | | | | |
|ch582 |√ |√ |√ |√ | |√ |√ | |
|ch32v103r8t6 |√ |√ |√ | | | | | |
|cm32m101a |√ | | | | | | | |
|w806 |√ |√ |√ |√ |√ |√ |√ | |
|apm32f030r8 |√ | | | | | | | |
|apm32e103vb |√ | | | | | | | |
|bl-602 |√ |√ | | |√ |√ | |√ |
|bl-706 |√ | | | | | | | |
|Raspberry Pico |√ | | | | | | | |
|ESP32C3 |√ |√ |√ | | | | | |
|TC264D |√ | | | | | | | |
|devc |√ | | | | | | | |
|visual-studio |√ | | | | | | | |
|EC600N |√ | | | | | | | |
|mm32f5277e9p |√ |√ | | | | | | |
|xr806(openharmony)|√ | | | | | | | |
2021-12-14 19:06:49 +08:00
2022-08-25 15:13:56 +08:00
2021-12-14 19:06:49 +08:00
## Board support
|Board|bsp|gpio|uart|pwm|adc|i2c|rgb|lcd|arm-2d|
|---|---|---|---|---|---|---|---|---|---|
|[Pika-Pi-Zero ](https://item.taobao.com/item.htm?spm=a230r.1.14.1.4f2e27a8R0qWJn&id=654947372034&ns=1&abbucket=15#detail )|√|√|√|√|√|√|√|√|√|
2021-12-21 15:54:47 +00:00
2022-07-06 23:58:29 +08:00
|Board|bsp|pika_lvgl|
|---|---|---|
|lvgl-vs-simu|√|√|
2022-10-19 23:00:40 +08:00
|swm320|√|√|
2022-07-06 23:58:29 +08:00
2021-12-21 15:54:47 +00:00
|Board|bsp|arm-2d|
|---|---|---|
|QEMU-arm2d|√|√|
|Board|bsp|LED|KEY|
|---|---|---|---|
|SmartLoong|√|√|√|√|
2021-12-21 16:16:45 +00:00
## OS support
2022-02-28 20:49:22 +08:00
|OS|port|GPIO|TIME|PWM|
|---|---|---|---|---|
|RT-Thread|√|√|√|√|
|vsf|√|√| | |
2021-12-21 16:16:45 +00:00
2021-12-23 02:49:15 +00:00
|OS|port|Google Test|Benchmark|
2021-12-21 16:16:45 +00:00
|---|---|---|---|
|linux|√|√|√|
2021-10-19 20:04:41 +08:00
# 3.Characteristic
### (1)Run environment
2021-10-19 19:50:14 +08:00
2023-01-10 14:43:48 +08:00
Support run in mcu without OS or file system. Can run in everywhere with **RAM ≥ 4kB** and **FLASH ≥ 64kB** , such as stm32g030, stm32f103c8t6, esp8266.
2021-10-19 19:50:14 +08:00
2021-10-19 20:04:41 +08:00
### (2)Develop enviroment
2022-05-21 16:08:30 +08:00
#### Support REPL by serial.
< img src = "assets/1641178790145-2f026e70-4ba1-4e9a-b05f-c602b2bd8cad.png" width = "400" alt = "微信交流群" / > < br / >
#### Support run and program python scripts by serial.
2021-10-19 19:50:14 +08:00
2022-02-20 07:44:38 +08:00
< img src = "document/image/134841230-85de6734-8467-4245-93a5-d452b5022b42.gif" width = "400" alt = "微信交流群" / > < br / >
2021-10-19 19:50:14 +08:00
2022-01-06 09:54:33 -05:00
Support IDEs like Keil, IAR, RT-Thread studio and segger embedded studio to develop C moudle.
2021-10-19 19:50:14 +08:00
2021-10-19 20:04:41 +08:00
Support build tools like CMake, makeFile and Scons.
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
Zero dependencies, zero configuration, out-of-the-box, easy to integrated into privious C projcet.
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
Eazy to extern customized C moudles.
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
Support linux.
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
### (3)Syntax
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
Support subaggregate of python 3 standard syntax.
2021-10-19 19:50:14 +08:00
2022-05-21 00:22:30 +08:00
Support class and method define, encapsulation-inheritance-polymorphism and moudles in `.pyi ` of C module.
2021-10-19 19:50:14 +08:00
2023-03-02 10:15:32 +08:00
< details > < summary > More Details About Syntax Support< / summary >
2022-04-09 08:52:01 +08:00
|Syntax|Compile-Time|Run-Time|Shell|
|---|---|---|---|
|Module Define |√|-|-|
2022-05-21 00:22:30 +08:00
|Module Import |√|√|√|
2022-04-11 22:58:12 +08:00
|Class Define |√|√|√|
|Class Inherit |√|√|√|
|Method Define |√|√|√|
|Method Override |√|√|√|
2022-04-09 08:52:01 +08:00
|Method Invoke |√|√|√|
|Argument Define |√|√|√|
|Argument Assignment |√|√|√|
|Object New |√|√|√|
|Object Free |√|√|√|
|Object Nest |√|√|√|
|Control flow |√|√|√|
2021-10-25 16:07:09 +08:00
#### Operator
2022-09-08 19:30:46 +08:00
| + | - | * | / | == | > | < | >= | <= | % | * * | // | != | & | >> | << | and | or | not | in | += | -= | *= | /= |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|√|
2021-10-25 16:07:09 +08:00
#### Control flow
2022-07-02 20:19:57 +08:00
| Syntax | State |
| --- | --- |
| if | √ |
| while | √ |
| for in [list] | √ |
| for in range(a, b) | √ |
| for in [dict] | √ |
| if elif else | √ |
| for break/continue | √ |
| while break/continue | √ |
2022-05-21 00:22:30 +08:00
#### Module
| Syntax | Python Module | C Module |
| --- | --- | --- |
| import [module] | √ | √ |
2022-05-21 20:01:02 +08:00
| import [module] as | √ | - |
2022-05-21 17:17:54 +08:00
| from [module] import [class/function>]| √ | - |
2022-05-21 20:01:02 +08:00
| from [module] import [class/function>] as | √ | - |
2022-05-21 00:22:30 +08:00
| from [module] import * | - | PikaObj Module Only |
#### List/Dict
2022-07-02 20:19:57 +08:00
| Syntax | State |
| --- | --- |
| l = list() | √ |
| l = [a, b, c] | √ |
| d = dict() | √ |
| d = {'a':x, 'b':y, 'c':z} | √ |
2022-05-21 00:22:30 +08:00
#### Exception
2022-07-02 20:19:57 +08:00
| Syntax | State |
| --- | --- |
2022-07-02 20:42:32 +08:00
|try:| √ |
|except:| √ |
|except [Exception]:| - |
|except [Exception] as [err]: | - |
|except: ... else:| - |
|raise:| √ |
|raise [Exception]:| - |
|finally:| - |
2022-05-21 00:22:30 +08:00
#### Slice
2022-07-02 20:19:57 +08:00
| Syntax | str | bytes | list |
| --- | --- | --- | --- |
| test[i] | √ | √ | √ |
2022-09-08 19:30:46 +08:00
| test[a : b] | √ | √ | √ |
| test[a :] | √ | √ | √ |
2022-05-21 00:22:30 +08:00
#### Other keywords/Syntax
| yield | is | comprehensions |
| --- | --- | --- |
2022-09-08 19:30:46 +08:00
| - | √ | - |
2023-03-02 10:15:32 +08:00
< / details >
2022-05-21 00:22:30 +08:00
2021-10-19 20:25:26 +08:00
### (4)Develop standard.
2021-10-19 19:50:14 +08:00
2021-10-21 10:26:35 +08:00
Readability first, nearly never use macro function and global argument.
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
Complete unit testes based on google test.
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
# 4.Both talk and show the code:
2021-10-19 19:50:14 +08:00
2021-10-21 07:34:26 +08:00
## E-mail: liang6516@outlook.com
2021-10-19 19:50:14 +08:00
2022-04-19 17:09:45 +00:00
# 5.Demo
2021-10-21 07:36:51 +08:00
2021-10-21 07:38:50 +08:00
The scripts in demos are in the [examples ](examples ) folder.
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
## Demo 01 GPIO
2021-10-19 19:50:14 +08:00
2023-03-02 10:15:32 +08:00
< details > < summary > View Code< / summary >
2023-03-02 10:10:22 +08:00
2022-01-10 08:41:42 +00:00
``` python
import PikaStdLib
import STM32G0
mem = PikaStdLib.MemChecker()
io1 = STM32G0.GPIO()
time = STM32G0.Time()
io1.setPin('PA8')
io1.setMode('out')
io1.enable()
io1.low()
2023-01-07 16:16:28 +08:00
print('hello pikapython')
2022-01-10 08:41:42 +00:00
print('mem.max :')
mem.max()
print('mem.now :')
mem.now()
while True:
io1.low()
time.sleep_ms(500)
io1.high()
time.sleep_ms(500)
```
2023-03-02 10:10:22 +08:00
2023-03-02 10:05:23 +08:00
< / details >
2021-10-19 19:50:14 +08:00
2022-02-20 07:44:38 +08:00
![Hnet-image (2) ](document/image/132943428-f2b365ca-140e-42f4-936c-db6a7d9f8dee.gif )
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
## Demo 02 USART
2021-10-19 19:50:14 +08:00
2023-03-02 10:15:32 +08:00
< details > < summary > View Code< / summary >
2023-03-02 10:10:22 +08:00
2022-01-10 08:41:42 +00:00
``` python
import PikaStdLib
import STM32G0
time = STM32G0.Time()
uart = STM32G0.UART()
uart.setId(1)
uart.setBaudRate(115200)
uart.enable()
2021-10-19 19:50:14 +08:00
2022-01-10 08:41:42 +00:00
while True:
time.sleep_ms(500)
readBuff = uart.read(2)
print('read 2 char:')
print(readBuff)
2021-10-19 19:50:14 +08:00
2022-01-10 08:41:42 +00:00
```
2023-03-02 10:10:22 +08:00
2023-03-02 10:05:23 +08:00
< / details >
2021-10-19 19:50:14 +08:00
2023-03-11 23:58:13 +08:00
![Hnet-image (3) ](document/image/132943365-0f7059b3-4f9d-4989-a5ec-2cce72b0cc96.gif )
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
## Demo 03 ADC
2021-10-19 19:50:14 +08:00
2023-03-02 10:05:23 +08:00
< details >
2023-03-02 10:10:22 +08:00
2023-03-02 10:08:09 +08:00
< summary > View Code< / summary >
2023-03-02 10:10:22 +08:00
2022-01-10 08:41:42 +00:00
``` python
import PikaStdLib
import STM32G0
time = STM32G0.Time()
adc1 = STM32G0.ADC()
2021-10-19 19:50:14 +08:00
2022-01-10 08:41:42 +00:00
adc1.setPin('PA1')
adc1.enable()
while True:
val = adc1.read()
print('adc1 value:')
print(val)
time.sleep_ms(500)
2022-05-20 23:38:40 +08:00
```
2023-03-02 10:10:22 +08:00
2023-03-02 10:05:23 +08:00
< / details >
2021-10-19 19:50:14 +08:00
2022-02-20 07:44:38 +08:00
![mmexport1631351523907 ](document/image/132944185-0a01b1ba-8cf7-4f9f-9d73-fe9cbcd52f0b.png )
2021-10-19 19:50:14 +08:00
2021-10-21 08:07:45 +08:00
## Demo 04 PWM output
2021-10-19 19:50:14 +08:00
2023-03-02 10:12:22 +08:00
< details > < summary > View Code< / summary >
2023-03-02 10:10:22 +08:00
2022-01-10 23:06:49 +08:00
``` python
2022-01-10 08:41:42 +00:00
import PikaStdLib
import STM32G0
time = STM32G0.Time()
pwm = STM32G0.PWM()
pwm.setPin('PA8')
pwm.setFrequency(2000)
pwm.setDuty(0.5)
pwm.enable()
while True:
time.sleep_ms(500)
pwm.setDuty(0.5)
time.sleep_ms(500)
pwm.setDuty(0.001)
```
2023-03-02 10:10:22 +08:00
2023-03-02 10:05:23 +08:00
< / details >
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
## Demo 05 RGB
2021-10-19 19:50:14 +08:00
2023-03-02 10:15:32 +08:00
< details > < summary > View Code< / summary >
2023-03-02 10:10:22 +08:00
2022-01-10 08:41:42 +00:00
``` python
import STM32G0
import PikaPiZero
import PikaStdLib
rgb = PikaPiZero.RGB()
mem = PikaStdLib.MemChecker()
rgb.init()
rgb.enable()
print('hello 2')
print('mem used max:')
mem.max()
while True:
print('flowing')
rgb.flow()
```
2023-03-02 10:10:22 +08:00
2023-03-02 10:05:23 +08:00
< / details >
2022-01-10 08:41:42 +00:00
## Demo 06 Snake(Need LCD)
2023-03-02 10:05:23 +08:00
< details >
2023-03-02 10:10:22 +08:00
2023-03-02 10:08:09 +08:00
< summary > View Code< / summary >
2023-03-02 10:12:22 +08:00
2022-01-10 08:41:42 +00:00
``` python
from PikaObj import *
import PikaStdLib
import PikaPiZero
import STM32G0
2022-01-10 16:49:51 +08:00
# hardware init
lcd = PikaPiZero.LCD()
lcd.init()
lcd.clear('white')
key = PikaPiZero.KEY()
key.init()
time = STM32G0.Time()
x_max = 120
y_max = 150
# snake init
s = PikaPiZero.Point()
w = 9
h = 9
s.x = 50
s.y = 10
len = 0
while len < 3:
b = s
2022-01-10 08:41:42 +00:00
i = 0
2022-01-10 16:49:51 +08:00
while i < len:
b = b.next
2022-01-10 08:41:42 +00:00
i = i + 1
2022-01-10 16:49:51 +08:00
b.next = PikaPiZero.Point()
b.next.x = b.x - 10
b.next.y = b.y
b.next.prev = b
len = len + 1
# ring link
b.next = s
s.prev = b
i = 0
b = s
while i < len:
lcd.fill(b.x, b.y, w, h, 'blue')
b = b.next
i = i + 1
print('snake lengh')
print(len)
# fruit init
f = PikaPiZero.Point()
f.x = 30
f.y = 20
lcd.fill(f.x, f.y, w, h, 'green')
# memory check
2022-01-10 08:41:42 +00:00
mem = PikaStdLib.MemChecker()
print('mem used max:')
mem.max()
2022-01-10 16:49:51 +08:00
# main loop
d = 0
2022-01-10 08:41:42 +00:00
isUpdate = 1
2022-01-10 16:49:51 +08:00
isEat = 0
2022-01-10 08:41:42 +00:00
while True:
if isUpdate:
2022-01-10 16:49:51 +08:00
# isUpdate = 0
# check eat fruit
if f.x == s.x and f.y == s.y:
# have eat fruit
isEat = 1
f.x = f.x + 30
if f.x > x_max:
f.x = f.x - x_max
f.y = f.y + 30
if f.y > y_max:
f.y = f.y - y_max
lcd.fill(f.x, f.y, w, h, 'green')
# move snake by the direction
if d == 0:
x_new = s.x + 10
y_new = s.y
if x_new > x_max:
x_new = 0
elif d == 1:
x_new = s.x
y_new = s.y - 10
if y_new < 0:
y_new = y_max
elif d == 2:
x_new = s.x
y_new = s.y + 10
if y_new > y_max:
y_new = 0
elif d == 3:
x_new = s.x - 10
y_new = s.y
if x_new < 0:
x_new = x_max
if isEat:
isEat = 0
b_new = PikaPiZero.Point()
b_new.x = x_new
b_new.y = y_new
b_new.prev = s.prev
b_new.next = s
s.prev.next = b_new
s.prev = b_new
s = b_new
len = len + 1
print('snake lengh')
print(len)
print('mem used max:')
mem.max()
# drow the snake and fruit
# clear last body
lcd.fill(s.prev.x, s.prev.y, w, h, 'white')
# new body
s.prev.x = x_new
s.prev.y = y_new
# head is last body
s = s.prev
lcd.fill(s.x, s.y, w, h, 'blue')
b = s
2022-01-10 08:41:42 +00:00
i = 0
2022-01-10 16:49:51 +08:00
# scan key
key_val = key.get()
if key_val == 0:
d = 0
2022-01-10 08:41:42 +00:00
isUpdate = 1
2022-01-10 16:49:51 +08:00
elif key_val == 1:
d = 1
2022-01-10 08:41:42 +00:00
isUpdate = 1
2022-01-10 16:49:51 +08:00
elif key_val == 2:
d = 2
2022-01-10 08:41:42 +00:00
isUpdate = 1
2022-01-10 16:49:51 +08:00
elif key_val == 3:
d = 3
2022-01-10 08:41:42 +00:00
isUpdate = 1
2022-01-10 16:49:51 +08:00
2023-03-02 10:15:32 +08:00
2022-01-10 08:41:42 +00:00
```
2023-03-02 10:10:22 +08:00
2023-03-02 10:05:23 +08:00
< / details >
2022-01-10 08:41:42 +00:00
2022-01-20 11:38:50 +08:00
![image ](https://user-images.githubusercontent.com/88232613/150269059-1fe3d62d-0c1b-40f4-9298-0d787f476a20.png )
2021-10-19 19:50:14 +08:00
2021-10-21 07:43:25 +08:00
The maximum RAM usage of these demos is only 3.56K, which is 4.56K if the 1K stack is included, and the maximum Flash usage is 30.4K. Refer to the 20K RAM and 64K Flash of STM32F103C8T6, less than 25% RAM and less than 50% Flash are used.
2021-10-21 07:45:47 +08:00
## About the custom extern module ?
2021-10-19 19:50:14 +08:00
2021-10-21 07:46:58 +08:00
In addition to device drivers, developing custom Python modules for MCU is very easy. The following two demos are extensions of the custom module, which developed python interfaces for the ARM-2D image driver library.
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
## Boxes~
2022-02-20 07:44:38 +08:00
![Hnet-image (7) ](document/image/132945282-bfd310df-8063-456d-b90c-6b798a2c8ed5.gif )
2021-10-19 19:50:14 +08:00
2021-10-19 20:25:26 +08:00
## Rotating suns~
2022-02-20 07:44:38 +08:00
![Hnet-image (6) ](document/image/132945107-e473a2cc-9fbc-47f9-aaed-a28d3ad1048c.gif )
2021-10-19 19:50:14 +08:00
2022-04-19 17:09:45 +00:00
# 6.Test and develop Core
2022-04-21 14:37:36 +08:00
## Test core in docker (recommend)
2022-06-24 10:23:18 +08:00
[get start with docker ](https://pikadoc.readthedocs.io/en/latest/get-start_linux.html )
2022-04-21 14:37:36 +08:00
2022-07-01 13:59:28 +08:00
# ✨ Contributors
2022-05-27 11:49:20 +08:00
2023-01-07 16:16:28 +08:00
< a href = "https://github.com/pikastech/pikapython/graphs/contributors" >
2023-01-07 16:18:02 +08:00
< img src = "https://contrib.rocks/image?repo=pikastech/pikascript" / >
2022-07-01 13:22:17 +08:00
< / a >
2022-05-27 11:49:20 +08:00
## [How to contribute](https://pikadoc.readthedocs.io/en/latest/%E5%A6%82%E4%BD%95%E5%8F%82%E4%B8%8E%E7%A4%BE%E5%8C%BA%E8%B4%A1%E7%8C%AE.html)
2022-08-02 13:31:31 +08:00
| Contributer | [Achivements ](document/achivement.md ) |
2022-08-02 13:02:41 +08:00
| ----------------------------------------------------- | :----------------------------------------------------------- |
| [甜航 ](https://github.com/easyzoom ) | < img src = "assets/26.png" alt = "26" width = "80" /> |
| 千帆(微信名) | < img src = "assets/26.png" alt = "26" width = "80" / > |
2022-08-02 13:45:15 +08:00
| [ Meco Jianting Man ](https://github.com/mysterywolf ) | < img src = "assets/22.png" alt = "12" width = "80" />< img src = "assets/26.png" alt = "26" width = "80" />< img src = "assets/23.png" alt = "23" width = "80" />< img src = "assets/15.png" alt = "15" width = "80" />< img src = "assets/11.png" alt = "15" width = "80" />< img src = "assets/41.png" alt = "41" width = "80" /> |
2022-08-02 13:02:41 +08:00
| [liuduanfei ](https://github.com/liuduanfei ) | < img src = "assets/26.png" alt = "26" width = "80" /> |
| [ sjy ](https://gitee.com/shanjiayang ) | < img src = "assets/26.png" alt = "26" width = "80" />< img src = "assets/13.png" alt = "13" width = "80" /> |
| 沧御 | < img src = "assets/26.png" alt = "26" width = "80" / > |
| [versaloon ](https://github.com/versaloon ) | < img src = "assets/26.png" alt = "26" width = "80" />< img src = "assets/13.png" alt = "13" width = "80" /> |
| 刘延(微信名) | < img src = "assets/36.png" alt = "36" width = "80" / > < img src = "assets/41-16594077379821.png" alt = "41" width = "80" / > |
| [GorgonMeducer ](https://github.com/GorgonMeducer ) | < img src = "assets/25.png" alt = "25" width = "80" />< img src = "assets/22.png" alt = "22" width = "80" />< img src = "assets/21.png" alt = "21" width = "80" />< img src = "assets/33.png" alt = "33" width = "80" />< img src = "assets/41-16594077379821.png" alt = "41" width = "80" /> |
| [unsigned ](https://gitee.com/unsigned0 ) | < img src = "assets/26.png" alt = "26" width = "80" />< img src = "assets/23.png" alt = "23" width = "80" /> |
| [梦程MI ](https://gitee.com/dreamcmi ) | < img src = "assets/36.png" alt = "36" width = "80" />< img src = "assets/23.png" alt = "23" width = "80" />< img src = "assets/41-16594077379821.png" alt = "41" width = "80" /> |
| [Maximilian Gerhardt ](https://github.com/maxgerhardt ) | < img src = "assets/12.png" alt = "12" width = "80" /> |
| [purewind7 ](https://gitee.com/purewind7 ) | < img src = "assets/24.png" alt = "24" width = "80" />< img src = "assets/31.png" alt = "31" width = "80" />< img src = "assets/33.png" alt = "33" width = "80" />< img src = "assets/41-16594077379821.png" alt = "41" width = "80" /> |
| [ onceday ](https://gitee.com/onceday ) | < img src = "assets/24.png" alt = "24" width = "80" />< img src = "assets/13.png" alt = "13" width = "80" /> |
2022-08-02 13:28:49 +08:00
< div class = "log" > < / div >
2023-03-02 10:45:44 +08:00
### Contribute Log On 2023
2022-05-27 11:49:20 +08:00
| Contribute log | Contributer |
2022-04-19 17:09:45 +00:00
| --- | --- |
2023-04-13 15:59:58 +08:00
|codecov CI support| [Renzhihan ](https://github.com/Renzhihan ) |
|rt-thread build script fix and improve| [supperthomas ](https://github.com/supperthomas ) |
|support pikafs pack and unpack to path|[sjy ](https://gitee.com/shanjiayang )|
|fix pika_platform_get_tick() in linux port|[梦程MI ](https://gitee.com/dreamcmi ) |
2023-03-16 10:06:12 +08:00
|CH307开发板、BL618开发板 | [VeriMake ](https://space.bilibili.com/356383684 ) |
2023-03-16 10:03:21 +08:00
|VM instruction extension framework | [GorgonMeducer ](https://github.com/GorgonMeducer ) |
|iotcloud module|[梦程MI ](https://gitee.com/dreamcmi ) |
2023-03-02 11:07:23 +08:00
|implement shell filter | [GorgonMeducer ](https://github.com/GorgonMeducer ) |
|修复socket模块在lwip中fcntl的参数数量错误|[梦程MI ](https://gitee.com/dreamcmi ) |
2023-03-02 11:10:40 +08:00
|support GPIO pika_hal for BLMCU|[codercmd ](https://gitee.com/codercmd )|
2023-03-02 11:09:01 +08:00
|Fix Typo on PikaVM.c|[Ikko Eltociear Ashimine ](https://gitee.com/eltociear )|
2023-03-02 11:07:23 +08:00
|Fix type assert on dataArgs.c|[itschina ](https://gitee.com/itschina )|
|add examples/Device/KEY_POLL.PY|[codercmd ](https://gitee.com/codercmd )|
2023-01-11 13:08:26 +08:00
| hmac hashlib base64 aes modules | [梦程MI ](https://gitee.com/dreamcmi ) |
2023-03-02 11:07:23 +08:00
|fix pikaCompiler build error on macos|[梦程MI ](https://gitee.com/dreamcmi ) |
2023-03-02 10:45:44 +08:00
< details > < summary > Contribute Log On 2022 < / summary >
| Contribute log | Contributer |
| --- | --- |
2023-01-11 13:08:26 +08:00
| request module | [onceday ](https://gitee.com/onceday ) |
| mqtt module | [FlintJ ](https://gitee.com/flintj ) |
2022-11-20 16:39:25 +08:00
| Donate: 500¥ | [hardsofttech ](https://gitee.com/hardsofttech ) |
2022-10-20 18:14:25 +08:00
| Donate: 500¥ | [edmund_wz ](https://gitee.com/edmund_wz ) |
2022-10-20 08:59:45 +08:00
| Donate: 500¥ | [Meco Jianting Man ](https://github.com/mysterywolf ) |
| Donate: 500¥ | [hardsofttech ](https://gitee.com/hardsofttech ) |
2023-03-02 11:07:23 +08:00
|PikaNN module| [Renzhihan ](https://github.com/Renzhihan ) |
2022-08-29 19:11:53 +08:00
| re module | [eglwang ](https://gitee.com/eglwang ) |
2022-07-14 17:02:33 +08:00
| PikaMath.Quaternion() | [purewind7 ](https://gitee.com/purewind7 ) |
2022-07-13 13:21:09 +08:00
| contrubute to PikaCV | [purewind7 ](https://gitee.com/purewind7 ) |
2022-07-10 23:24:04 +08:00
| xr806(openharmony) bsp |[sjy ](https://gitee.com/shanjiayang )|
2022-06-28 10:24:33 +08:00
| ESP32 package |沧御|
| MM32F5277E9P package |[unsigned ](https://gitee.com/unsigned0 )|
2022-06-25 22:50:17 +08:00
| mm32f5277e9p BSP |[unsigned ](https://gitee.com/unsigned0 )|
2022-06-24 09:53:16 +08:00
| Add [CMSIS-PACK ](https://pikadoc.readthedocs.io/en/latest/get-start_cmsis-pack.html ) | [GorgonMeducer ](https://github.com/GorgonMeducer ) |
2022-06-24 09:56:13 +08:00
| donate: air32f103 board * 20 | 合宙 [xinxi204 ](https://gitee.com/xinxi204 ) |
2022-06-12 10:57:53 +08:00
| contrubute to PikaMath.Math() | [onceday ](https://gitee.com/onceday ) |
2022-06-04 15:48:13 +08:00
| add support for Unix Time | [onceday ](https://gitee.com/onceday ) |
2022-06-02 08:04:54 +00:00
| contrubute to PikaStdLib.String() | [purewind7 ](https://gitee.com/purewind7 ) |
2023-01-07 16:16:28 +08:00
| Add [PLOOC ](https://github.com/GorgonMeducer/PLOOC ) support for pikapython Core | [GorgonMeducer ](https://github.com/GorgonMeducer ) |
2023-03-02 10:45:44 +08:00
| Donate: 500¥ (ctypes 相关) | 蒋太平 |
2022-04-19 17:09:45 +00:00
| fix linux install script | [Maximilian Gerhardt ](https://github.com/maxgerhardt ) |
| ch582 package | [梦程MI ](https://gitee.com/dreamcmi ) |
| ch582 BSP | [梦程MI ](https://gitee.com/dreamcmi ) |
2022-05-27 11:49:20 +08:00
| Donate: EC600X QuecPython Develop board| 移远通信 武加玉 |
2022-04-19 17:09:45 +00:00
| Performance Point: 900->1400 | [GorgonMeducer ](https://github.com/GorgonMeducer ) |
| stm32f051r8 BSP |[unsigned ](https://gitee.com/unsigned0 )|
| stm32f407ze BSP |[unsigned ](https://gitee.com/unsigned0 )|
| devc BSP |[unsigned ](https://gitee.com/unsigned0 )|
| TC264D BSP |[unsigned ](https://gitee.com/unsigned0 )|
| PikaVM improvement | [GorgonMeducer ](https://github.com/GorgonMeducer ) |
| W801Device package | 刘延(微信名) |
| W806 bsp | 刘延(微信名) |
2022-05-27 11:49:20 +08:00
| Donate: ESP32C3 5pic, linker|启明云端 沧御|
| Donate: LS1C101 mcu 10pic, LS1c101 develop board, debuger|龙芯俱乐部 石南|
2022-04-19 17:09:45 +00:00
| PikaVSF OS package | [versaloon ](https://github.com/versaloon ) |
| ESP32C3 BSP |沧御|
2023-03-02 10:45:44 +08:00
< / details >
< details > < summary > Contribute Log On 2021 < / summary >
| Contribute log | Contributer |
| --- | --- |
2022-05-27 11:49:20 +08:00
| Donate: ESP32 board、ink lcd*4 | name(微信名) |
| Donate: smartloong board | 龙芯俱乐部 石南 |
2022-04-19 17:09:45 +00:00
| package/STM32F1 | [sjy ](https://gitee.com/shanjiayang ) |
| package/STM32F103RBBooter | [sjy ](https://gitee.com/shanjiayang ) |
| bsp/stm32f103rb | [sjy ](https://gitee.com/shanjiayang ) |
2022-05-27 11:49:20 +08:00
| QEMU ARM-2D simulation proejct | [liuduanfei ](https://github.com/liuduanfei ) |
| Donate: GD32E103TB2 2 pic | 信息牛(微信名) |
| Rt-thread bsp、port、module| [Meco Jianting Man ](https://github.com/mysterywolf ) |
| Donate: EC600S-CN 4G| 移远模块 |
| Donate: BL706 board|博流智能 [bouffalolab ](https://github.com/bouffalolab )|
| Donate: CM32M101A 开发板| 孟巍(微信名) |
| Donate: APM32F030R8 board | 极海半导体 陈成 |
| Donate: APM32E103VB board | 极海半导体 陈成 |
| Donate: APEX-Link| 极海半导体 陈成 |
| corde format, add gitattributes| [Meco Jianting Man ](https://github.com/mysterywolf ) |
2022-04-19 17:09:45 +00:00
| demo/simulation-keil | 千帆(微信名) |
| demo/stm32f103zet6/demo01-led-stm32f103zet6 | [甜航 ](https://github.com/easyzoom ) |
| demo/stm32f103zet6/demo02-led-stm32f103zet6_tworoot | [甜航 ](https://github.com/easyzoom ) |
| demo/stm32f407zgt/demo01-led-stm32f407vgt | [甜航 ](https://github.com/easyzoom ) |
2022-05-27 21:21:54 +08:00
2023-03-02 10:45:44 +08:00
< / details >
2022-07-02 20:13:13 +08:00
2022-05-27 21:21:54 +08:00
## Star History
2023-01-07 16:18:02 +08:00
[![Star History Chart ](https://api.star-history.com/svg?repos=pikastech/pikascript&type=Date )](https://star-history.com/#pikastech/pikascript & Date)