阅读 64

梯度下降 以y=2x为例

本文内容,参考自:https://peterroelants.github.io/posts/neural-network-implementation-part01/

 

 

import numpy as np
from matplotlib import pyplot as plt

#定义--------------------------------------------------------begin

#训练数据 x
x = np.linspace(0,2,20) #以0.1为间隔,在0-2之间生成20个数据。
data_size = len(x)

#Guassian noise
np.random.seed(5)
noise = np.random.randn(data_size) * 0.2 #高斯分布~ N(0,0.04)

#target y
y = 2 * x + noise #在真实情况下,我们并不知道 y与x的关系。我们要计算求解的正是这个关
系。


#weights w
np.random.seed(6)
w = np.random.randn() #梯度下降求解权重参数w,随机初始化

#learning rate u
u = 0.1

#network
def network(x,w):
    return x*w


def loss(pred,y): #预测值和target值,在此使用MSE
    return np.sum(np.square(y-pred)) / len(pred)

#定义--------------------------------------------------------end

epochs = 20
delta_w_list = []

for i in range(epochs):
    pred = network(x,w)
#画出当前预测值 plt.plot(x,pred,marker
=x,linestyle=--, label=str(i) + w:%.3f % w)
#梯度计算公式 delta_w
= np.sum(2 * x * u * ( pred - y)) / data_size delta_w_list.append(delta_w)
#梯度更新w w
= w - delta_w #画出delta_w plt.plot(x, delta_w_list, marker=+,linestyle=-,label=delta_w)
#画出训练数据 plt.plot(x,y,marker
=o,linestyle=:,label=target) plt.legend(loc=upper left) plt.show()

显示结果图:

 

 

原文:https://www.cnblogs.com/yibule/p/15305931.html

文章分类
代码人生
文章标签
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐