- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
numpy,一维数组垂直堆栈上的 Hadmard 乘积比循环一维数组列表并在每个数组上执行 Hadamard(按元素)乘积要快得多(这是有道理的,无论如何我都测试过) .
我有一种情况需要在一组 numpy 数组和另一组数组之间执行 Hadamard 乘积:
stacked_arrays = np.vstack([1D-arrays...])
stacked_arrays *= np.power(factor, np.arange(1, num_arrays))
但是,我需要这个操作来改变列表中的每个一维数组组件,而且这个操作需要经常发生。我知道这听起来像是一个奇怪的功能,但是有没有办法在没有循环的情况下做到这一点,例如:
factors = factor ** np.arange(1, num_arrays)
for array, f in zip([1D..arrays], factors):
array *= f
或者不拆栈操作结果?
还有 map
自 map
后无法使用像这样创建 numpy 数组的副本:
result = map(lambda x, y: x * y, zip([1D..arrays], factors))
因为你不能做 *=
与 lambda
返回一个 numpy 数组列表,原始数组保持不变。
有没有办法得到np.vstack
仍然以某种方式引用旧的组件数组,或者另一种方法来实现数组之间的 Hadamard 乘积的速度 stacked
在改变未堆叠的那些?如果不需要进行拆垛 (np.split
),可以节省一些时间。
TimeIt 结果:
m = []
for _ in range(100):
m.append(np.array([1, 2, 4, 5], dtype=np.float64))
factors = np.expand_dims(np.power(2, np.arange(100, dtype=np.float64)), axis=1)
def split_and_unstack():
l = np.vstack(m)
l *= factors
result = np.split(l, 100)
def split_only():
l = np.vstack(m)
l *= factors
print(timeit.timeit(split_and_unstack, number=10000))
# 1.8569015570101328
print(timeit.timeit(split_only, number=10000))
# 0.9328480050317012
# makes sense that with unstacking it is about double the time
澄清: 上面提到的 [1D arrays] 列表是更大的 1D 数组列表的子列表。 这个更大的列表是 collections.deque
.还有这个deque
需要 在提取子列表之前进行洗牌(即这是随机梯度下降的体验重播缓冲区)。
缓冲区 pop
和 append
速度:
times = int(1e4)
tgt = np.array([1, 2, 3, 4])
queue = collections.deque([tgt] * times, maxlen=times)
reg_list = [tgt] * times
numpy_list = np.array([tgt] * times)
def pop():
queue.pop()
def pop_list():
reg_list.pop()
def pop_np():
global numpy_list
numpy_list = numpy_list[1:]
print(timeit.timeit(pop, number=times))
# 0.0008135469979606569
print(timeit.timeit(pop_list, number=times))
# 0.000994370027910918
print(timeit.timeit(pop_np, number=times))
# 0.0016436030273325741
def push():
queue.append(tgt)
def push_list():
reg_list.append(tgt)
numpy_list = np.array([tgt] * 1)
def push_np():
numpy_list[0] = tgt
print(timeit.timeit(push, number=times))
# 0.0008797429618425667
print(timeit.timeit(push_list, number=times))
# 0.00097957398975268
print(timeit.timeit(push_np, number=times))
# 0.003331452957354486
最佳答案
让我们把问题分解一下。您希望拥有对所有可变数组的引用列表,但您希望能够将它们作为一个 block 来执行操作。
我认为您的方法是倒退的。与其尝试将数组打包和解包到单独的缓冲区中,不如将 View 维护到单个缓冲区中。
替换你当前的循环
m = [np.array([1, 2, 4, 5], dtype=np.float64) for _ in range(100)]
使用单个缓冲区,并查看每一行:
buf = np.vstack([np.array([1, 2, 4, 5], dtype=np.float64) for _ in range(100)])
m = list(buf) # check that m[0].base is b
现在您有一个数组列表 m
,您可以单独修改每个数组。只要您将修改保留在原地并且不重新分配列表元素,所有更改将直接出现在 buf
中。同时,您可以在 buf
上执行批量计算,只要就地执行,m
就会反射(reflect)所有更改。
实际上,您甚至可能不需要 m
。请注意 list(buf)
如何为 block 的每一行创建 View 。您可以轻松地直接索引到缓冲区中。例如,m[3][8]
通常会根据 buf
编写为 buf[3, 8]
,但您可以还利用 buf
是一个序列这一事实并编写 buf[3][8]
。这是低效的,因为它每次都会创建一个新 View (buf[3]
),但不会太多。
要提取打乱的行子集,您也可以使用序列索引。假设您的缓冲区保留了最后的 M
行,您希望从中洗牌并提取 N
行的子序列。您可以通过创建索引数组并一遍又一遍地洗牌来做到这一点:
indices = np.arange(M)
# inside the loop:
np.random.shuffle(indices)
chunk = buf[indices[:N]]
# do your math on `chunk`
只要 M
不变并且您相信洗牌足够随机,您就不需要重新分配或重新排序 indices
。
关于python - Hadamard 在数组列表上的效率,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53974705/
如标题所示,ans_list是一个答案列表,ans_index是一个数字(答案在词汇表中的索引,但与atm无关) 这里生成的 tree.anslist 是什么? (例如,仅针对第一个),忽略迭代。 f
我目前将用户的输入存储在逗号分隔的列表中,如下所示: Userid | Options 1 | 1,2,5 用户在一个数组形式中勾选一组选项,然后用逗号连接起来 1,2,5 然后 MySQ
我目前将用户的输入存储在逗号分隔的列表中,如下所示: Userid | Options 1 | 1,2,5 用户在一个数组形式中勾选一组选项,然后用逗号连接起来 1,2,5 然后 MySQ
我想知道如何完全展平列表和包含它们的东西。除其他外,我想出了一个解决方案,它可以将具有多个元素的东西滑倒并将它们放回原处,或者在滑倒后将具有一个元素的东西拿走。 这与 How do I “flatte
我想知道如何完全展平列表和包含它们的东西。除其他外,我想出了一个解决方案,它可以将具有多个元素的东西滑倒并将它们放回原处,或者在滑倒后将带有一个元素的东西拿走。 这与 How do I “flatte
这个问题已经有答案了: Convert nested list to 2d array (3 个回答) 已关闭 7 年前。 java中有没有快捷方式可以转换 List> 到 String[][] ?
我在排序时遇到问题 List> 。我创建了一个自定义比较器,在其中编写了对数据进行排序的代码。 public class CustomComparator implements Comparator
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Java Generics: Cannot cast List to List? 我只是想知道为什么下面的java代
试图想出一个 LINQy 方法来做到这一点,但我什么也没想到。 我有一个对象列表<>,其中包含一个属性,该属性是逗号分隔的字母代码列表: lst[0].codes = "AA,BB,DD" lst[1
假设我有这些任务: points = [] point = (1, 2) 我怎么会这样做: points += point 它工作得很好,并且给了我点 = [1, 2]。但是,如果我这样做: poin
如何在 scala 中将 List[Task[List[Header]]] 类型转换为 Task[List[Header]]。 我有一个方法返回 Task[List[Header]] 并多次调用 do
如何在 Java 中查找二维列表的元素? 我有一个参数为 List> 的函数我想知道如何找到这个列表的行和列。 最佳答案 如果你喜欢 List> obj 然后你就可以像这样访问 obj.get(cur
分配 List到 List工作正常。 分配 List>到 List>不编译。 代码 public class Main { public static void main(String[] a
我正在用 Java 编写一个方法,该方法必须接收并迭代 Serializable 的 List。 有什么区别: public void myMethod(List list) { } 和 public
我看到很多人想用 mvvm 更新网格/列表/树的一部分,但他们不想刷新整个列表。 对于所有遇到此问题的人,我做了以下示例。 希望这对你有用。 最佳答案 这是一个简单的例子。整个代码中最重要的是: Bi
我正在为现有的 C++ 库编写包装器,该库使用列表,其中 T 是自定义结构。我被建议使用 vector 而不是列表,但我试图避免修改库。 为了更好地理解这个场景,我做了一个简单的应用程序,使用一个列表
List list List list 这两种声明有什么区别吗? 谢谢, 最佳答案 是的。 List可以包含所有派生自 Base 的不同事物的混合物. List包含同质项(从某种意义上说,它们必须全部
有人可以尽可能详细地解释以下类型之间的区别吗? List List List 让我更具体一点。我什么时候想使用 // 1 public void CanYouGiveMeAnAnswer(List l
我有一个元组列表,每个元组都是一对列表。所以我的数据看起来像: mylist = [(['foo', 'bar'], ['bar', 'bar']),(['bar', 'bar'],['bar', '
也许是一个时髦的标题,但我遇到了以下问题: 给定一个类型为 (a * b) list 的列表,我想创建一个类型为 (a * b list) list 的新列表。一个例子: 给定列表 let testL
我是一名优秀的程序员,十分优秀!