码迷,mamicode.com
首页 > 其他好文 > 详细

Keras实践:实现非线性回归

时间:2019-02-09 17:51:38      阅读:678      评论:0      收藏:0      [点我收藏+]

标签:ace   alt   idt   全连接   ras   mamicode   keras   rand   mod   

Keras实践:实现非线性回归

代码

import os
os.environ["KMP_DUPLICATE_LIB_OK"]="TRUE"

import keras
import numpy as np
import matplotlib.pyplot as plt
 #顺序模型
from keras.models import  Sequential
 #全连接层
from keras.layers import Dense
from keras.optimizers import  SGD

#使用numpy生成100个随机点
x_data = np.linspace(-0.5,0.5,200)
noise = np.random.normal(0,0.01,x_data.shape)
y_data = np.square(x_data)+noise


#显示随机点
plt.scatter(x_data,y_data)
plt.show()


#构建一个顺序模型
model = Sequential()
#在模型中添加一个全连接层
model.add(Dense(units=10,input_dim=1,activation=‘tanh‘))
#NOTE:input_dim=10可以省略,Keras默认会赋予正确值
model.add(Dense(units=1,input_dim=10,activation=‘tanh‘))

#提高学习率
sgd = SGD(lr=0.3)
model.compile(optimizer=sgd,loss=‘mse‘)



for step in range(3001):
    #每次训练一个批次
    cost = model.train_on_batch(x_data,y_data)
    #每500次打印一下cost值
    if step %500 ==0:
        print("COST",cost)


# x_data输入网络中,得到预测值
y_pred = model.predict(x_data)

#显示随机点
plt.scatter(x_data,y_data)
plt.plot(x_data,y_pred,‘r-‘,3)
plt.show()

  拟合效果如下:

  技术图片

 

Keras实践:实现非线性回归

标签:ace   alt   idt   全连接   ras   mamicode   keras   rand   mod   

原文地址:https://www.cnblogs.com/MrSaver/p/10357696.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!