让我们从头开始。这是我获取x
和y
值的方式:
from mpl_toolkits.mplot3d import Axes3D
fig = plt.figure()
ax = fig.gca(projection='3d') # get current axis
w0 = np.arange(30, 80, 1) # x - values
w1 = np.arange(-3, 3, 0.1) # y - values
X, Y = np.meshgrid(w0, w1) # no idea why to do that
因为我不知道如何避免循环,所以我采用这种方式来计算Z值:
sizeWo = len(w0)
sizeW1 = len(w1)
Z = np.zeros((sizeWo, sizeW1))
for i in xrange(0,sizeWo):
for j in xrange(0,sizeW1):
Z[i,j] = errorLose(w0[i], w1[j])
surf = ax.plot_surface(X, Y, Z) # that lines generates the error (ValueError: shape mismatch: objects cannot be broadcast to a single shape)
即使这段代码也会产生同样的错误:
surf = ax.plot_surface(w0, w1, Z) shape mismatch: objects cannot be broadcast to a single shape
plt.show()
这里有什么问题以及如何使其发挥作用?
errorLose
函数使用两个值并使用后面的数据框data
计算错误:
def errorLose(w0,w1):
return np.sum((data.Height - (w0 + w1 *data.Weight))**2)
这是您获取相同数据的方法。这是指向csv file的链接:
data = pd.read_csv('weights_heights.csv', index_col='Index')
答案 0 :(得分:4)
你非常接近。问题是您要创建Z
为sizeWo x sizeW1
,但 meshgrid
创建X
和Y
,其大小为{{1} }}。您可以以不同方式设置sizeW1 x sizeW0
:
Z
或者你可以保持Z = np.zeros((sizeW1, sizeWo))
for i in xrange(0,sizeWo):
for j in xrange(0,sizeW1):
Z[j,i] = errorLose(w0[i], w1[j])
相同,只需将Z
的转置传递给你的情节构造函数
Z
<强>更新强>
您需要使用surf = ax.plot_surface(X, Y, np.transpose(Z))
的原因是您的x和y坐标最初只是 1D数组而meshgrid
期望plot_surface
和{{1成为2D数组。 X
做的是它从两个输入创建二维数组,每个输入都是两个输入。 This answer包含对Y
。