首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >优化工具

优化工具
EN

Stack Overflow用户
提问于 2011-12-14 21:38:31
回答 3查看 2.3K关注 0票数 0

我想知道有什么工具可以在循环展开方面优化我的程序,我该如何使用它?

我有以下python代码:

代码语言:javascript
复制
for i in range(0, 1000):
       a = a * 10 + a%4 + i
for j in range(0, 1000):
       j = j + a 
for b in range(0, 1000):
      result = j + b

我想优化这个代码段,这样我就可以试着理解一点循环展开。对于Python,我想知道一个C优化器。

EN

回答 3

Stack Overflow用户

发布于 2011-12-14 21:48:17

代码语言:javascript
复制
a = 30
for i in range ( 0,1000 ) :
    a = a * 10 + a%4 + i

可以重写为:

代码语言:javascript
复制
a = reduce(lambda a,b: a * 10 + a%4 + b, xrange(1000), 30)

所需时间大致相同(在我的计算机上约为4ms)。

代码语言:javascript
复制
for j in range ( 0, 1000 ) :
       j = j + a

这没有多大意义。您在0-999上迭代j,并且每次都向其中添加巨大的a,这会立即被忘记,因为将采用下一个j。它可以重写为:

代码语言:javascript
复制
j = 999 + a

代码语言:javascript
复制
for b in range ( 0 , 1000 ) :
      result = j + b

也没什么意义。相当于:

代码语言:javascript
复制
result = j + 999 
票数 4
EN

Stack Overflow用户

发布于 2011-12-14 21:53:46

如果您对代码的性能不满意,并对其进行了分析,并且发现像这样的低级循环是一个瓶颈,那么您应该能够通过使用cython将代价高昂的代码转换为C扩展来极大地提高代码的速度。此外,如果您使用的是Python2.x,则应该使用xrange而不是range

票数 3
EN

Stack Overflow用户

发布于 2011-12-14 21:50:40

有一篇关于Python中循环展开的影响的科学论文(pdf link)。These是相关演讲的幻灯片。

但是,在自动C代码优化方面,您可以将LLVMLooPo结合使用,也可以与Polly结合使用。无论如何,LLVM是一个很好的起点。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8505417

复制
相关文章

相似问题

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