- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在类的强循环中使用numpy.random.normal
函数。
class MyClass(MyBaseClass):
def run(self):
while True:
...
self.L.append(numpy.random.normal(0,1))
我知道在 Python 中使用多个查找非常慢。在 numpy.random.normal
中有 3 次查找:首先查找 numpy
,然后是 random
,然后是 normal
.
所以我决定通过将 numpy.random.normal
分配给局部变量 _normal
来解决这个问题。
开始吧:
class MyClass(MyBaseClass):
_normal = numpy.random.normal
def run(self):
while True:
...
self.L.append(MyClass._normal(0,1))
我真正关心的是描述符。当访问类中的变量时,将查找所有基类以查找具有相同名称的数据描述符。它描述了here :
Check
objectname.__class__.__dict__
for attrname. If it exists and is a data-descriptor, return the descriptor result. Search all bases ofobjectname.__class__
for the same case.
所以,我想,如果我像上面那样将 _normal
放在本地空间中,它会查找数据描述符的所有基类。我担心它会成为经济放缓的根源。
我的担忧是否合理?
我是否应该担心在基类中查找描述符所花费的时间?
当在类中使用时,是否有更好的方法来加快访问位于模块深处的函数?
在评论中对答案进行了讨论。
我决定提供一些额外的实现细节,这些细节似乎很重要(对于我的特定案例)。
实际上,代码更接近于此(非常非常简化):
class MyClass(MyBaseClass):
def __iter__(self):
return self
def next(self):
self.L.append(numpy.random.normal(0,1))
def run(self):
while True:
self.next()
最佳答案
如果你必须做这样的事情(函数查找实际上是主要成本吗?随机数生成并不便宜)你应该意识到一个全局 + 一个属性查找(MyClass._normal
)不是这比一个全局 + 三个 attr 查找便宜得多 (numpy.random.normal
)。您真正想要的是在循环内获取零 全局或 attr 查找,这只能通过在函数内定义 _normal
来实现。如果你真的很想减少周期,你还应该预绑定(bind)列表追加调用:
class MyClass(MyBaseClass):
def run(self):
_normal = numpy.random.normal
_Lappend = self.L.append
while True:
...
_Lappend(_normal(0,1))
对比反汇编输出(仅针对 append
语句):
LOAD_FAST 0 (self)
LOAD_ATTR 1 (L)
LOAD_ATTR 2 (append)
LOAD_GLOBAL 3 (numpy)
LOAD_ATTR 4 (random)
LOAD_ATTR 5 (normal)
LOAD_CONST 1 (0)
LOAD_CONST 2 (1)
CALL_FUNCTION 2
CALL_FUNCTION 1
POP_TOP
对比
LOAD_FAST 2 (_Lappend)
LOAD_FAST 1 (_normal)
LOAD_CONST 1 (0)
LOAD_CONST 2 (1)
CALL_FUNCTION 2
CALL_FUNCTION 1
更好的方法是矢量化——生成许多随机法线偏差并将它们一次性添加到列表中——你可以使用 numpy 的
.size
参数来做到这一点.random.normal
关于python - 考虑到描述符,将函数放入本地 namespace 以加快访问速度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8377460/
我想使用 ffmpeg 框架更改视频速度。我为此使用了这个命令: ffmpeg -y -i /storage/extSdCard/Video/1.avi -filter_complex [0:v]fp
我有以下数据数组,有 200 万个条目: [20965 1239 296 231 -1 -1 20976 1239 299 314 147 337 255
我正在使用 Oracle 数据库,并且想获取一个包含 3000 万条记录的表。 library(RODBC) ch <- odbcConnect("test", uid="test_user",
我在 android 上使用 FFmpeg 来: 1- 合并 3 个视频 2-添加音频 3-添加标志 4-修剪 3 个视频之一 5-改变输出的fps 我已经实现了正确的代码,但花了 30 分钟。对于(
我使用 GLPKMathProgInterface 和 JuMP 编写了一个程序来解决 Julia 中的线性程序。 Julia 代码由 python 程序调用,该程序通过多个命令行调用运行多个 Jui
我们使用 POV-Ray 每次运行生成大约 80 张图像,我们将这些图像拼接在一起形成两个移动的 GIF 文件(一个场景的两个 360 度 View )。我们正在寻找尽可能加快此镜像创建的方法(在 h
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我将数据从一个数据库插入到另一个数据库,所以我有 2 个连接(Conn1 和 Conn2)。下面是代码(使用pypyodbc)。 import pypyodbc Conn1_Query = "SE
在我的应用程序中,我显示 EKEvents 列表,我想在 UITableView 中显示一个月的所有事件,每个部分包含各自的日期。嗯,这可行,我得到了我需要的所有数据,但获取速度非常慢。 问题在于事件
我有一个移动速度非常慢的传送带。我不知道什么JS脚本控制速度,我需要它来加速。无法从主题制作者那里获得任何帮助。任何建议都会非常有帮助。谢谢 页面: http://krankgolf2017.wpen
有没有办法加快这段代码的速度?我需要它来删除相同的内容并将其写入单元格,以强制其他 VBA 代码运行另一列上的代码。这就是它的作用,只是 super 慢。有时此表上有 2000 个条目/行。每个单元大
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 LINQ 查询,它正在搜索包含大约 250,000 条记录的 SQL 表,并且仅搜索 2 个字段。这两个字段都已建立索引,但我发现它的运行速度仍然相当慢。 下面是代码,有人可以提出任何建议来
对于相对较大的 Pandas DataFrame(几十万行),我想创建一个应用函数结果的系列。问题是该功能不是很快,我希望它能以某种方式加快速度。 df = pd.DataFrame({ 'valu
这个问题在这里已经有了答案: Faster weighted sampling without replacement (3 个答案) 关闭 9 年前。 如何在 R 中加快概率加权采样。 # Let
在运行 PhantomJS 提供的 rasterize.js 示例时,我发现我必须等待 20 秒或更长时间才能生成网页图像。 有没有可能在不消耗大量资源的情况下加快速度的方法?我基本上希望快速生成从加
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 Excel 工作簿,用户通过单击按钮导入文本文件。我的代码完全按照我的需要工作,但是在填写 H 列“阅读日期”时速度非常慢。将文本文件导入 Excel 工作表后,我的 Excel 工作簿如下
我是一名优秀的程序员,十分优秀!