给出点
x = [1,4,5,8,12]
y = [7,9,15,14,27]
data:image/s3,"s3://crabby-images/cfb9f/cfb9f591517c86fe101a7af3ed585522f96ca6e7" alt=""
要找出温度和冰淇淋销量之间的关系,通过线性回归来拟合求出属性和结果之间的线性关系。
如果直接把这些点连起来,是吃力不讨好的,因为如果有新数据进来大概率不在这条线上,这个行为也叫做过拟合。
对于这种明显有相关关系的数据,直接用一条直线去拟合这些数据,一次函数y=kx+b,k、b确定了直线也就确定了。找最合适的直线的过程就叫线性回归。
评判标准
找出每个真实数据点到直线的距离。
data:image/s3,"s3://crabby-images/5b45f/5b45f0d772013be152beb9115a687269e70bddd4" alt=""
列个表看看:
data:image/s3,"s3://crabby-images/c0e73/c0e73cc588193e434d50f3ab047add744905c72e" alt=""
定义损失函数 f(k,b)=z
python
import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
x = np.array([1, 4, 5, 8, 12])
y_true = np.array([7, 9, 15, 14, 27])
def model(x, k, b):
return k * x + b
def mse_loss(y_true, y_pred):
return np.mean((y_true - y_pred) ** 2)
# 生成参数 k 和 b 的取值范围
k_values = np.linspace(0, 3, 100)
b_values = np.linspace(-5, 5, 100)
# 创建网格
K, B = np.meshgrid(k_values, b_values)
# 计算每个 (k, b) 组合下的损失值
Z = np.zeros_like(K)
for i in range(len(k_values)):
for j in range(len(b_values)):
y_pred = model(x, K[i, j], B[i, j])
Z[i, j] = mse_loss(y_true, y_pred)
# 绘制三维损失函数曲面图
fig = plt.figure(figsize=(10, 7))
ax = fig.add_subplot(111, projection='3d')
ax.plot_surface(K, B, Z, cmap='viridis')
ax.set_xlabel('Slope (k)')
ax.set_ylabel('Intercept (b)')
ax.set_zlabel('MSE Loss')
ax.set_title('3D Loss Function Surface')
plt.show()
data:image/s3,"s3://crabby-images/28ace/28ace6ab2708e4234101ef4169ac67e41ab26577" alt=""
问题就转化成了找到图像的谷底。
对于一次函数:
data:image/s3,"s3://crabby-images/65271/65271f7e04e4b3f1a48f12169bfe5d5c2e0a5ad8" alt=""
data:image/s3,"s3://crabby-images/53987/53987a4112aef3d29f21df89a6b03823cb2289a3" alt=""
data:image/s3,"s3://crabby-images/036af/036af373d8248daba8e726d1c9917cde098627a9" alt=""
data:image/s3,"s3://crabby-images/ef86a/ef86ac3248a2eb75360306fb92b9132c5a134946" alt=""
data:image/s3,"s3://crabby-images/47cd8/47cd8559f1af0c55ad9d6c808e9ffc233ed77a33" alt=""
高等数学下中对于梯度的介绍:
data:image/s3,"s3://crabby-images/4a548/4a54886998f70490602537290b5ce635b0300c5c" alt=""
data:image/s3,"s3://crabby-images/4b8d2/4b8d29baf07b7af0c9a95c9668304ceb3190d84d" alt=""
data:image/s3,"s3://crabby-images/c8dc1/c8dc180abdf08cad1abc964f3c92fd04817fa314" alt=""