鱼C论坛

 找回密码
 立即注册
查看: 1139|回复: 4

timeit无法正确计算代码执行效率问题?

[复制链接]
发表于 2019-1-30 18:07:14 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 syf040916 于 2019-1-30 18:08 编辑

发现在计算同一个代码运算效率的时候,IDLE环境下的timeit和ipython下的答案不同,请问是怎么回事啊? 在IDLE中timeit计算的结果这么久(难道是微秒?? 感觉运行时间很长......,应该是秒),在ipython中那么短。另外,据说,np.sum()的运行效率要比sum() 高的,完全没感觉到啊。
>>>import numpy as np
>>>n=np.random.random((2,3))
>>>n
array([0.40131221, 0.73381901, 0.17952003, 0.47163449, 0.1569086 ,
       0.47766951, 0.82419673, 0.04052931, 0.99183377, 0.13766227])
>>>def fun():
            return sum(n)
>>>def func():
            return np.sum(n)
>>> timeit.Timer(lambda:fun()).timeit()
          
2.057096468000964
>>> timeit.Timer(lambda:func()).timeit()
          
2.6367056939998292

WeChat Screenshot_20190130180049.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-1-30 18:33:39 | 显示全部楼层
ipython里显示的就是算了100000次的平均时间吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-1-30 18:33:49 | 显示全部楼层
数据量大才体现,ipython基于浏览器,idle是cpython
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-1-30 18:36:47 | 显示全部楼层
所以,根据结果来看,是浏览器中,sum()和np.sum()代码的运行效率差不多,而且都比cpython中相同的代码要高很多了吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-1-13 18:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表