Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
MicroPython
【RTT-MPY】不太成功的圆周率测试
发布于 2018-07-26 21:01:49 浏览:2169
订阅该版
[tocm] 这一篇本来前几天就预备写,但是因为加班耽误了。以前用python计算圆周率,用来测试CPU的性能,于是想在SWM320上也测试一下,看看性能在什么水平。圆周率的计算方法如下: ```import time def pi(places=10): # 3 + 3*(1/24) + 3*(1/24)*(9/80) + 3*(1/24)*(9/80)*(25/168) # The numerators 1, 9, 25, ... are given by (2x + 1) ^ 2 # The denominators 24, 80, 168 are given by (16x^2 -24x + 8) extra = 8 one = 10 ** (places+extra) t, c, n, na, d, da = 3*one, 3*one, 1, 0, 0, 24 while t > 1: n, na, d, da = n+na, na+8, d+da, da+32 t = t * n // d c += t return c // (10 ** extra) def pi_t(n=10): t1=time.ticks_ms() t=pi(n) t2=time.ticks_ms() print('elapsed: ', time.ticks_diff(t2,t1)/1000, 's') return t``` 将代码用ctrl-E粘贴到micropython中,就可以进行计算了。但是系统gc机制影响了计算,使得计算时间不准确,就无法进行比较了。 ```>>> a=pi_t(10) elapsed: _space_0.02_space_s >>> a=pi_t(20) GC: total: 7936, used: 1840, free: 6096 No. of 1-blocks: 29, 2-blocks: 5, max blk sz: 37, max free sz: 203 elapsed: _space_0.05_space_s >>> a=pi_t(100) GC: total: 7936, used: 1952, free: 5984 No. of 1-blocks: 24, 2-blocks: 5, max blk sz: 37, max free sz: 158 GC: total: 7936, used: 2064, free: 5872 No. of 1-blocks: 25, 2-blocks: 5, max blk sz: 37, max free sz: 158 GC: total: 7936, used: 2016, free: 5920 No. of 1-blocks: 25, 2-blocks: 8, max blk sz: 37, max free sz: 158 GC: total: 7936, used: 1984, free: 5952 No. of 1-blocks: 25, 2-blocks: 7, max blk sz: 37, max free sz: 158 GC: total: 7936, used: 1984, free: 5952 No. of 1-blocks: 25, 2-blocks: 7, max blk sz: 37, max free sz: 158 GC: total: 7936, used: 1920, free: 6016 No. of 1-blocks: 25, 2-blocks: 5, max blk sz: 37, max free sz: 158 elapsed: _space_0.24_space_s``` 希望尽早出一个改进的版本。
查看更多
4
个回答
默认排序
按发布时间排序
armink
2018-07-26
这家伙很懒,什么也没写!
GC 的日志可以关闭,你注释掉这行代码就行了 [https://github.com/RT-Thread-packages/micropython/blob/master/port/gccollect.c#L63](https://github.com/RT-Thread-packages/micropython/blob/master/port/gccollect.c#L63)
shaoziyang
2018-07-27
这家伙很懒,什么也没写!
>GC 的日志可以关闭,你注释掉这行代码就行了 > >https://github.com/RT-Thread-packages/micropython/blob/ma ... --- 关闭了只是不显示,但是gc的回收还是会影响运行的。
我夏了夏天
认证专家
2018-07-27
Life isn't about finding yourself, life is about creating yourself.
>关闭了只是不显示,但是gc的回收还是会影响运行的。 --- 这样啊
呵呵哒
2018-10-29
这家伙很懒,什么也没写!
>关闭了只是不显示,但是gc的回收还是会影响运行的。 --- gc完全关了,你手动释放object?new and delete?
撰写答案
登录
注册新账号
关注者
0
被浏览
2.2k
关于作者
shaoziyang
这家伙很懒,什么也没写!
提问
1
回答
1
被采纳
0
关注TA
发私信
相关问题
1
请问rt-thread有没有移植micropython呢
2
micropython import 文件名的方式执行脚本问题
3
第一篇:Micropython 的起源和发展
4
第二篇:RT-Thread Micropython 简介
5
第三篇:RT-Thread Micropython 快速入门
6
第四篇:Micropython DIY 项目汇总
7
第五篇:Micropython 教程和资源
8
第六篇: RT-Thread MicroPython 学习经验和学习路线
9
RT-Thread MicroPython 最新开发板固件汇总【已失效】
10
有Mpy专门的板块啦~
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
在用clangd开发RTT吗,快来试试如何简单获得清晰干净的工作区
2
GD32F450 片内 flash驱动适配
3
STM32H7R7运行CherryUSB
4
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
5
使用RC522软件包驱动FM1722
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
freemodbus
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
a1012112796
10
个答案
1
次被采纳
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
6
次点赞
YZRD
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
Woshizhapuren
1
篇文章
5
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部