我正在学习 keras 中的神经网络。我在合成数据上指定了一个简单的模型。
model=tf.keras.models.Sequential()
model.add(tf.keras.layers.Dense(2, input_dim=2))
model.compile(optimizer='sgd', loss='mean_squared_error')
我有两个属性来预测两个值。
这是我初始化数据的地方:
x=[]
y=[]
for x1 in range (6):
x2=int(random.random()*10)
x.append([x1,x2])
y.append([2*x1+x2**2-2, x1*x2])
xs = np.array(x, dtype=float)
xs=xs.reshape(6,2)
ys = np.array(y, dtype=float)
ys=ys.reshape(6,2)
model.fit(xs, ys, epochs=500)
请注意,我仅将这些数据用于学习目的。在我尝试观察模型之后。我跑model.summary()和model.get_weights()。
Model: "sequential"
_________________________________________________________________
Layer (type) Output Shape Param #
=================================================================
dense (Dense) (None, 2) 6
=================================================================
Total params: 6
Trainable params: 6
Non-trainable params: 0
_________________________________________________________________
None
model weights [array([[0.5137405, 5.477211 ],
[8.750836 , 1.6910588]], dtype=float32), array([-5.701193, -7.874653], dtype=float32)]
我不明白为什么有 6 个参数和 6 个权重。根据我的理解,每个输入应该有两个,或者我应该在某个地方专门定义输出层?
慕尼黑8549860
拉丁的传说
相关分类