gpt4 book ai didi

python - 对 x_i + x_k 的 k≠i 求和

转载 作者:行者123 更新时间:2023-11-28 21:12:50 24 4
gpt4 key购买 nike

在 Python 中,我有一个值 xi 的 numpy 数组 X,我想创建一个数组 F,其中每个条目都是对 X 的所有其他条目求和。

然后 F 看起来像这样:

F= np.array[(x2+x3+...+xn),(x1+x3+...+xn),...,(x1+x2+...+xn-1)]

这是使用 for 循环:

import numpy as np
X=np.array[a,b,c,d,e,f,g]
F=np.zeros_like(X)
for i,f in enumerate(F):
f = sum(np.delete(i,F))

有没有办法在不显式使用 for 循环的情况下做一些 numpy 魔术?

如果等式变得更复杂会怎样

F= np.array[(x2+x3+...+xn)^2+x1,(x1+x3+...+xn)^2+x2,...,(x1+x2+...+xn-1)^2+xn]

如果是for循环

import numpy as np
X=np.array[a,b,c,d,e,f,g]
F=np.zeros_like(X)
for i,f in enumerate(F):
f = sum(np.delete(i,F))**2+X[i]

最佳答案

简单地说,x.sum() - x:

>>> x
array([0, 3, 1, 8, 3, 5, 6, 3, 8, 1])
>>> x.sum()
38
>>> x.sum() - x
array([38, 35, 37, 30, 35, 33, 32, 35, 30, 37])

对于另一个方程,每个分量等于:

(sum(x) - x(i))^2 + x(i) == sum(x)^2 + x(i)^2 - 2 * x(i) * sum(x) + x(i)

因此您仍然可以将其写成矢量化形式,如:

>>> acc = x.sum()
>>> acc**2 + x**2 - 2 * x * acc + x

关于python - 对 x_i + x_k 的 k≠i 求和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33847481/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com