Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
MicroPython
【RTT-MPY】不太成功的圆周率测试
发布于 2018-07-26 21:01:49 浏览:2039
订阅该版
[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
被浏览
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
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
国产MCU移植系列教程汇总,欢迎查看!
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
RT-Thread Vision Board - Bare Metal Project with VSCode/PyOCD/Cortex-Debug
2
【学习分享】libc切换 -- 从newlib切换到mlibc
3
FRDM-MCXN947开发板之i2c应用
4
esp32 s3使用cherryusb cdc
5
【Vision Board 创客营】Vision Board上的DAC实践
热门标签
RT-Thread Studio
串口
LWIP
SPI
Env
Bootloader
AT
ART-Pi
Hardfault
CAN总线
FinSH
USB
文件系统
DMA
RT-Thread
SCons
线程
RT-Thread Nano
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
ota在线升级
WIZnet_W5500
I2C_IIC
UART
flash
cubemx
packages_软件包
freemodbus
潘多拉开发板_Pandora
PWM
定时器
ADC
BSP
中断
编译报错
socket
keil_MDK
GD32
MicroPython
msh
Debug
ulog
SFUD
flashDB
SDIO总线
rt_mq_消息队列_msg_queue
本月问答贡献
用户名由3_15位
18
个答案
3
次被采纳
xiaorui
7
个答案
3
次被采纳
sakumisu
4
个答案
3
次被采纳
踩姑娘的小蘑菇
15
个答案
2
次被采纳
三世执戟
32
个答案
1
次被采纳
本月文章贡献
比特饼干
3
篇文章
8
次点赞
Z_Y
2
篇文章
5
次点赞
Alipay
2
篇文章
3
次点赞
xusiwei1236
2
篇文章
3
次点赞
yinxiangxv
2
篇文章
3
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部