首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >为什么numpy multi_dot比numpy.dot慢?

为什么numpy multi_dot比numpy.dot慢?
EN

Stack Overflow用户
提问于 2017-08-24 10:58:18
回答 1查看 1.9K关注 0票数 0

我正在尝试优化一些执行大量顺序矩阵运算的代码。

我认为numpy.linalg.multi_dot (docs here)将执行C或BLAS中的所有操作,因此它将比arr1.dot(arr2).dot(arr3)等要快得多。

我真的很惊讶在笔记本上运行这段代码:

代码语言:javascript
复制
v1 = np.random.rand(2,2)

v2 = np.random.rand(2,2)



%%timeit 
    ​    
v1.dot(v2.dot(v1.dot(v2)))

The slowest run took 9.01 times longer than the fastest. This could mean that an intermediate result is being cached.
100000 loops, best of 3: 3.14 µs per loop



%%timeit        ​

np.linalg.multi_dot([v1,v2,v1,v2])

The slowest run took 4.67 times longer than the fastest. This could mean that an intermediate result is being cached.
10000 loops, best of 3: 32.9 µs per loop

发现使用multi_dot进行同样的操作大约要慢10倍。

我的问题是:

  • 我是不是漏掉了什么?这有什么意义吗?
  • 有没有其他优化顺序矩阵运算的方法?
  • 我应该期待使用cython时也有同样的行为吗?
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45852228

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档