Keras非线性回归
import keras
import numpy as np
import matplotlib.pyplot as plt
from keras.models import Sequential
from keras.layers import Dense,Activation
from keras.optimizers import SGD
x_data = np.linspace(-0.5,0.5,200)
noise = np.random.normal(0,0.02,x_data.shape)
y_data = np.square(x_data) + noise
model = Sequential()
model.add(Dense(units=10,input_dim=1,activation='tanh'))
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)
if step % 500 == 0:
print('cost',cost)
y_pred = model.predict(x_data)
plt.scatter(x_data,y_data)
plt.plot(x_data,y_pred,'r',lw=3)
plt.show()
![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/cf0e748dc93d4a375155a07fe01f69cf.png)