tensorflow:添加隐藏层 搭建神经网络

本文演示了如何使用TensorFlow构建一个包含隐藏层的神经网络模型,通过添加一个ReLU激活函数的隐藏层和一个输出层,并利用梯度下降优化器进行训练。在训练过程中,损失函数随着迭代次数减少,实现对输入数据平方加噪声后的拟合。
摘要由CSDN通过智能技术生成
# coding:UTF-8
import os
import tensorflow as tf
import numpy as np
import matplotlib.pyplot as plt

os.environ['TF_CPP_MIN_LOG_LEVEL'] = '2'  # 忽略不必要的警告


# 添加隐藏层
def add_layer(inputs, in_size, out_size, activation_function=None):
    loc_w = tf.Variable(tf.random_normal([in_size, out_size]))
    loc_b = tf.Variable(tf.zeros([1, out_size]) + 0.1)  # 官方推荐biases初始值不为0
    loc_y = tf.matmul(inputs, loc_w) + loc_b
    if activation_function is None:
        loc_outputs = loc_y
    else:
        loc_outputs = activation_function(loc_y)
    return loc_outputs


# 输入数据
x_data = np.linspace(-1, 1, 250)[:, np.newaxis]
noise = np.random.normal(0, 0.05, x_data.shape)
y_data = np.square(x_data) + noise

# 数据可视化,输出原始数据
fig = plt.figure()
ax = fig.add_subplot(1, 1, 1)  # 参数为输出图框的编号
ax.scatter(x_data, y_data)
plt.ion()
plt.show()

# 创建结构 start
xs = tf.placeholder(tf.float32, [Non
TensorFlow中,构建一个简单的神经网络通常涉及以下几个步骤: 1. **导入库和模块**: ```python import tensorflow as tf from tensorflow.keras.layers import Dense, Input from tensorflow.keras.models import Model ``` 2. **定义输入和模型结构**: 使用`Input`函数定义输入张量,并指定其形状。例如,如果处理的是二维数组(如图像),我们可以这样定义: ```python input_shape = (height, width, channels) # 根据实际需求替换 inputs = Input(shape=input_shape) ``` 然后添加隐藏和输出。对于一个有两和一个单个节点的输出的全连接网络,可以这样编写: ```python hidden_layer_1 = Dense(units=units1, activation='relu')(inputs) hidden_layer_2 = Dense(units=units2, activation='relu')(hidden_layer_1) outputs = Dense(units=1, activation='sigmoid') # 如果任务是二分类,激活函数可能是'softmax' ``` 3. **创建完整模型**: 将隐藏和输出连接起来构成完整的模型。Keras会自动处理权重的初始化和反向传播: ```python model = Model(inputs=inputs, outputs=outputs) ``` 4. **编译模型**: 设置优化器、损失函数和评估指标: ```python model.compile(optimizer='adam', loss='binary_crossentropy', metrics=['accuracy']) # 对于二分类问题 ``` 5. **训练模型**: 使用`fit`函数提供训练数据、标签以及可能的其他超参数: ```python history = model.fit(x_train, y_train, epochs=num_epochs, batch_size=batch_size, validation_split=0.2) ``` 6. **评估模型**: 使用`evaluate`函数对测试集进行性能评估: ```python test_loss, test_accuracy = model.evaluate(x_test, y_test) ``` 注意这里的参数需要根据具体的任务(如图像分类、回归等)、数据集大小和复杂度进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值