用Python绘制梯度下降算法的等高线图

我在尝试将梯度下降应用于一个简单的线性回归模型时,当绘制二维图形时得到了预期的结果,但当我切换到等高线图时却没有得到预期的图形,我想知道我的错误在哪里。

这是代码:

def J(b_0, b_1, x, y):  return (1/len(y))*(y - b_0 - b_1*x)**2def dJ_1(b_0, b_1, x, y):  return (2/len(y))*np.sum(x*(b_1*x + b_0 - y))def dJ_0(b_0, b_1, x, y):  return (2/100)*np.sum((b_1*x + b_0 - y))x = np.linspace(-1, 1, 100)y = np.linspace(-2, 2, 100)b_0 = 5b_1 = 5parameters_0 = [b_0]parameters_1 = [b_1]for i in range(99):  b_1 -= 0.1*dJ_1(b_0, b_1, x, y)  b_0 -= 0.1*dJ_0(b_0, b_1, x, y)  parameters_0.append(b_0)  parameters_1.append(b_1)plt.figure(figsize=(4, 8))plt.plot(np.linspace(-2, 7, 100), J(np.linspace(-2, 7, 100), parameters_1[-1], -1, -2))plt.plot(np.array(parameters_0), J(np.array(parameters_0), parameters_1[-1], -1, -2), color="C1")plt.plot(np.array(parameters_0), J(np.array(parameters_0), parameters_1[-1], -1, -2), '-o', color="C1")plt.xlabel(r"$\beta_0$")plt.ylabel(r"$J(\beta_0)$")plt.show()

第一个图:

enter image description here

plt.figure(figsize=(4, 8))plt.plot(np.linspace(-4, 7, 100), J(parameters_0[-1], np.linspace(-4, 7, 100), -1, -2))plt.plot(np.array(parameters_1), J(parameters_0[-1], np.array(parameters_1), -1, -2), color="C1")plt.plot(np.array(parameters_1), J(parameters_0[-1], np.array(parameters_1), -1, -2), '-o', color="C1")plt.xlabel(r"$\beta_1$")plt.ylabel(r"$J(\beta_1)$")plt.show()

第二个图:

enter image description here

b_0 = np.linspace(-10, 10, 100)b_1 = np.linspace(-10, 10, 100)X, Y = np.meshgrid(b_0, b_1)Z = J(X, Y, x=-1, y=-2)fig,ax=plt.subplots(1,1)cp = ax.contourf(X, Y, Z)fig.colorbar(cp) ax.set_xlabel(r"$\beta_0$")ax.set_ylabel(r"$\beta_1$")plt.show()

等高线图是:

enter image description here

为什么我得到上面的图形而不是像下面这样的图形,例如当成本函数的全局最小值在(0, 2)时?提前感谢。

enter image description here


回答:

我认为这里没有错误,你可以从二维图中看到你的梯度下降图是一个二次函数,因此你从等高线图中看到的就像是从天空俯瞰山谷。至于为什么它看起来不像一个圆形,嗯,这是因为它只是一个三维的二次函数。我也曾经做过类似的事情,梯度下降图就像你绘制的那样。查看这里页面末尾的内容

Related Posts

使用LSTM在Python中预测未来值

这段代码可以预测指定股票的当前日期之前的值,但不能预测…

如何在gensim的word2vec模型中查找双词组的相似性

我有一个word2vec模型,假设我使用的是googl…

dask_xgboost.predict 可以工作但无法显示 – 数据必须是一维的

我试图使用 XGBoost 创建模型。 看起来我成功地…

ML Tuning – Cross Validation in Spark

我在https://spark.apache.org/…

如何在React JS中使用fetch从REST API获取预测

我正在开发一个应用程序,其中Flask REST AP…

如何分析ML.NET中多类分类预测得分数组?

我在ML.NET中创建了一个多类分类项目。该项目可以对…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注