paddlepaddle demo——基于y=3*x+2的线性回归预测

开发环境


Jupyter Notebook

Python版本   python 3.7

框架版本   PaddlePaddle 1.8.4

具体实现


import paddle
import numpy as np
import paddle.fluid as fluid
import matplotlib.pyplot as plt

BATCH_SIZE=10
iter=0;
iters=[] #训练轮数
train_costs=[] #损失值,判断收敛程度

#创建神经网络
x = fluid.layers.data(name='x',shape=[1],dtype='float32')
hidden = fluid.layers.fc(input=x,size=100,act='relu')
net = fluid.layers.fc(input=hidden,size=1,act=None)

#定义损失函数
y = fluid.layers.data(name='y',shape=[1],dtype='float32')
cost = fluid.layers.square_error_cost(input=net,label=y)
avg_cost = fluid.layers.mean(cost) #square_error_cost()求的是一个Batch的损失值,所以还要用mean()再求一个平均值。

#优化函数
optimizer = fluid.optimizer.SGDOptimizer(learning_rate=0.01)
opts = optimizer.minimize(avg_cost)

#创建cpu解释器
place = fluid.CPUPlace()
exe = fluid.Executor(place)
exe.run(fluid.default_startup_program())

x_train_data = np.array([[1.0],[2.0],[3.0],[4.0],[5.0]]).astype('float32')
y_train_data = np.array([[5.0], [8.0], [11.0], [14.0], [17.0]]).astype('float32') #对应关系:y=3*x+2
test_data = np.array([[6.0]]).astype('float32') #预测数据

#定义可视化函数
def draw_train_process(iters,train_costs):
    title="training cost"
    plt.title(title, fontsize=24)
    plt.xlabel("iter", fontsize=14) #横坐标表示训练轮数
    plt.ylabel("cost", fontsize=14) #纵坐标表示收敛程度
    plt.plot(iters, train_costs,color='red',label='training cost') 
    plt.grid()
    plt.show()
    
#训练n轮
n = 400
for pass_id in range(n):
    train_cost = exe.run(
        program=fluid.default_main_program(),
        feed={'x':x_train_data,'y':y_train_data},
        fetch_list=[avg_cost]
    )
    if pass_id % 10 ==0: #每BATCH_SIZE条打印一次数据,BATCH_SIZE=10
        print("id:%d,cost:%0.5f"%(pass_id,train_cost[0])) 
        iter=iter+BATCH_SIZE
        iters.append(iter)
        train_costs.append(train_cost[0])
    
draw_train_process(iters,train_costs)

test_program = fluid.default_main_program().clone(for_test=True)

#预测
result = exe.run(
    program=test_program,
    feed={'x':test_data,'y':np.array([[0.0]]).astype('float32')},
    fetch_list=[net]
)
#输出预测结果
print("当x为6.0时,y为:%0.5f" % result[0])

预测结果


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值