运行时间测试

  • 脚本级别
python -m cProfile -o del.out timeit_and_numba.py 
# 或者  line_profile
  • 函数,方法级别
# 4 class.functions
def timers(origin_func):
    def wrapper(self, *args, **kwargs):
        try:
            t1 = time.time()
            u = origin_func(self, *args, **kwargs)
            print(time.time() - t1)
            return u
        except Exception as e:
            print(e)
    return wrapper


# 4 functions
def timer(func):
    def inner(self, *args, **kwargs):
        t1 = time.time()
        func(*args, **kwargs)
        print(time.time()-t1)
    return inner

-timeit函数

import numba as nb
from numba import jit
import numpy as np
from timeit import timeit

@jit('f8(f8[:])')
def sum1d(array):
    s = 0.0
    n = array.shape[0]
    for i in range(n):
        s += array[i]
    return s

array = np.random.random(10000)

# print(timeit(sum1d(array), number=100))
# print(timeit(np.sum(array), number=100))
# print(timeit(sum(array), number=100))
t1 = timeit('sum1d', "from __main__ import sum1d", number=1000)
print(t1)
t2 = timeit('np.sum(array)', "from __main__ import array, np", number=1000)
print(t2)
t3 = timeit('sum(array)', "from __main__ import array", number=1000)
print(t3)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值