我正在通过多个点计算机翼的浮力。为此,我有特定的表面和气压数据。我现在想要的是将计算值存储在变量via循环中,如下所示:
w = 0.7
# air pressure data
pt = np.array([0, -18.63, -80.41, -88.25, 90.21, -95.61])
pb = np.array([-112.28, 34.32, -101.98, -85.31, -3.33, 11.47, 14.71])
#top wing x-pos.
xt = np.array([11, 9.1, 6.85, 4.7, 1.7, 0.6, 1.9])
#bottom wing x-pos.
xb = np.array([2.85,0.8, 0.85, 2.5, 4.225, 6.7, 9.025, 11])
#top wing y-pos.
yt = np.array([1, 2.1, 3.05, 3.8, 3.7, 2.1, 1])
#bottom wing y-pos.
yb = np.array([4.05, 3, 1.55, 0.95, 1.125, 1.3, 1.225,1])
for i in range(0,5):
at[i] = sqrt( (xt[i] - xt[i+1]) ** 2 + (yt[i] - yt[i+1]) **2 ) * w
ab[i] = sqrt( (xb[i] - xb[i+1]) ** 2 + (yb[i] - yb[i+1]) **2 ) * w
在左侧,它应该创建多个变量,如:
at0 = ...
:
:
at5 = ...
ab0 = ...
:
:
ab5 = ...
并在右侧显示np.array()
s
但这会出现此错误:NameError: name 'at' is not defined
然后继续这样:
for x in range(0,5):
Ft = sum( at[x] * pt[x] )
Fb = sum( ab[x] * pb[x] )
到现在为止,我试图用字典,循环给出的循环......但它不起作用。
顺便说一下:我使用np.sum()
和np.sqrt()
而不是sum()
和sqrt()
是否有用?
非常感谢你!
答案 0 :(得分:1)
在尝试对其进行分配之前,您需要定义变量at
。您收到错误,因为该变量不存在。如果您只需要一个简单的列表,那么在循环之前需要at = []
。
然后,在你的循环中,你可以只使用at.append(<computation>)