python梯度下降法实现线性回归_用梯度下降法实现线性回归

我刚开始学习机器学习,目前正修读吴志强的机器学习课程。我已经用python实现了线性回归算法,但结果并不理想。I python代码如下:import numpy as np

x = [[1,1,1,1,1,1,1,1,1,1],[10,20,30,40,50,60,70,80,90,100]]

y = [10,16,20,23,29,30,35,40,45,50]

x = np.array(x)

y = np.array(y)

theta = np.zeros((2,1))

def Cost(x,y,theta):

m = len(y)

pred_ions = np.transpose(theta).dot(x)

J = 1/(2*m) * np.sum((pred_ions - y)*(pred_ions - y))

return J

def GradientDescent(x,y,theta,iteration,alpha):

m = len(y)

pred_ions = np.transpose(theta).dot(x)

i = 1

while i <= iteration:

theta[0] = theta[0] - alpha/m * np.sum(pred_ions - y)

theta[1] = theta[1] - alpha/m * np.sum((pred_ions - y)*x[1,:])

Cost_History = Cost(x,y,theta)

i = i + 1

return theta[0],theta[1]

itera = 1000

alpha = 0.01

a,b = GradientDescent(x,y,theta,itera, alpha)

print(a)

print(b)

我不知道到底是什么问题。但是,我的结果很奇怪。根据上述代码,参数值为298和19890。任何帮助都将不胜感激。谢谢。在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值