【Python】全连接神经网络

2024-01-08 09:45:56

一、前言

全连接神经网络(Fully Connected Neural Network)是一种常见的深度学习模型,也称为密集神经网络(DNN)。在全连接神经网络中,每一层的神经元都与前一层的所有神经元相连,并通过权重和激活函数来处理输入数据,产生输出结果。

二、反向传播算法(Backpropagation)

3.1 简单介绍

反向传播算法(Backpropagation)是一种监督学习算法,常被用于训练多层神经网络。在多层神经网络中,每个神经元接收前一层的输出作为输入,并将自己的输出传递给下一层。通过反向传播算法,可以计算出每个神经元的误差,并根据误差调整权重参数,以不断优化神经网络的性能。

反向传播算法基于梯度下降法,通过计算损失函数对神经网络参数的梯度来更新参数,从而最小化损失函数。在训练过程中,神经网络的输出结果与真实值之间的误差被计算出来,并反向传播到网络中。通过计算损失函数对权重的梯度,不断调整权重参数,使得损失函数逐渐减小。反复迭代训练,神经网络能够逐渐学习到输入数据中的特征,提高分类或回归任务的准确率。

3.2 核心思想

反向传播算法的核心思想是将误差反向传递给各层神经元,使得每个神经元的误差可以被计算和修正。这种算法可以有效地优化多层神经网络中的参数,让模型具备学习能力。

3.3 应用

反向传播算法适合于多层神经元网络的一种学习算法,它建立在梯度下降法的基础上。BP网络的输入输出关系实质上是一种映射关系:一个n输入m输出的BP神经网络所完成的功能是从n维欧氏空间向m维欧氏空间中一有限域的连续映射,这一映射具有高度非线性。它的信息处理能力来源于简单非线性函数的多次复合,因此具有很强的函数复现能力。这是BP算法得以应用的基础。

反向传播算法的具体步骤包括前向传播、计算误差、反向传播和权重更新等步骤。在前向传播阶段,输入数据通过网络向前传递,计算出每个神经元的输出结果。在计算误差阶段,根据神经元的输出结果和真实值计算出误差。在反向传播阶段,根据误差调整权重参数,计算出每个权重的梯度。在权重更新阶段,根据梯度调整权重参数,使得损失函数逐渐减小。

反向传播算法在多层神经网络的训练中起着至关重要的作用,是深度学习领域中非常重要的算法之一。它使得神经网络能够不断学习和优化,从而在各种机器学习任务中表现出色。

三、全连接神经网络

3.1 基本原理

全连接神经网络(Fully Connected Neural Network)是一种多层感知机(MLP),由输入层、隐藏层和输出层组成。其基本原理是反向传播算法(Backpropagation)。在训练过程中,神经网络的输出结果与真实值之间的误差被计算出来,并反向传播到网络中,通过计算损失函数对权重的梯度,不断调整权重参数,使得损失函数逐渐减小。

全连接神经网络通过不断调整权重参数,能够学习到输入数据中的特征,从而对输入数据进行分类或回归等任务。该网络通常包含输入层、隐藏层和输出层。输入层接收外部输入的数据,隐藏层通过一系列非线性变换将输入数据映射到高维空间,输出层将隐藏层的输出结果进行处理并产生最终的输出结果。

在全连接神经网络中,每个神经元都与前一层的所有神经元相连,因此每个神经元的输出结果都是前一层所有神经元输出结果的加权和。同时,每个神经元都包含一个激活函数,用于将神经元的输出结果转换成非线性形式,以便能够更好地处理复杂的数据特征。

除了反向传播算法,全连接神经网络还涉及到一些重要的概念和技术,如前向传播、激活函数、损失函数、梯度下降等。这些概念和技术对于理解全连接神经网络的基本原理和实现方式非常重要。

全连接神经网络是一种重要的深度学习模型,通过不断调整权重参数,能够学习到输入数据中的特征,并在分类、回归等任务中表现出色。为了解决训练过程中可能遇到的问题,如梯度消失和过拟合等,研究者们提出了各种改进方法,如残差网络(ResNet)、批归一化(Batch Normalization)和正则化(Regularization)等。这些方法可以有效地提高全连接神经网络的性能和泛化能力。

3.2 学习率和损失率

学习率和损失率是机器学习中常用的两个参数,尤其在神经网络中更为关键。

学习率是一个超参数,决定了模型在每次迭代中权重调整的幅度。较高的学习率可能导致模型训练不稳定,而较低的学习率可能导致训练速度缓慢或陷入局部最小值。选择合适的学习率对于模型的训练至关重要。一种常见的方法是使用学习率衰减,即随着训练轮次的增加,逐渐减小学习率。

损失率通常是指模型的损失函数值,用于衡量模型预测结果与真实结果之间的差距。损失函数的目标是最小化,因此损失率越低,模型的性能通常越好。损失函数的选择取决于具体任务,例如分类问题中常用的交叉熵损失函数或回归问题中的均方误差损失函数。

在神经网络的训练过程中,通过不断调整学习率和损失率,可以找到一个合适的平衡点,使模型能够快速收敛并获得良好的性能。同时,这些参数的选择也会受到数据集、模型结构等因素的影响,因此在实际应用中需要根据具体情况进行调整和优化。

3.2 实现

全连接神经网络的一个简单实现,需要使用到NumPy库。

这个简单的全连接神经网络包含输入层、隐藏层和输出层,并使用sigmoid函数作为激活函数。在训练过程中,通过前向传播计算输出结果,并通过反向传播计算误差和梯度,不断调整权重参数。训练完成后,可以使用predict方法对新的输入数据进行分类预测。

# 导入numpy库,numpy是一个强大的科学计算库,提供了高性能的多维数组对象和工具  
import numpy as np  
  
# 定义一个名为FullyConnectedNeuralNetwork的类,表示一个全连接的神经网络  
class FullyConnectedNeuralNetwork:  
    # 初始化函数,接受输入层大小、隐藏层大小和输出层大小作为参数  
    def __init__(self, input_size, hidden_size, output_size):  
        # 将输入参数值存储在相应的实例变量中  
        self.input_size = input_size    
        self.hidden_size = hidden_size    
        self.output_size = output_size    
        
        # 使用随机正态分布初始化权重矩阵,大小为(输入层大小, 隐藏层大小)  
        self.weights1 = np.random.randn(self.input_size, self.hidden_size)    
        # 使用随机正态分布初始化权重矩阵,大小为(隐藏层大小, 输出层大小)  
        self.weights2 = np.random.randn(self.hidden_size, self.output_size)    
        # 使用全0数组初始化偏置项,形状为(1, 隐藏层大小)  
        self.bias1 = np.zeros((1, self.hidden_size))    
        # 使用全0数组初始化偏置项,形状为(1, 输出层大小)  
        self.bias2 = np.zeros((1, self.output_size))    
        
    # 前向传播函数,输入数据通过权重和偏置进行变换得到输出结果  
    def forward_propagation(self, input_data):    
        # 通过权重矩阵weights1和偏置项bias1进行线性变换  
        self.input = np.dot(input_data, self.weights1) + self.bias1    
        # 使用sigmoid函数对线性变换的结果进行激活,得到隐藏层的输出结果  
        self.hidden = sigmoid(self.input)    
        # 通过权重矩阵weights2和偏置项bias2进行线性变换,得到输出层的输出结果  
        self.output = np.dot(self.hidden, self.weights2) + self.bias2    
        
        return self.output    
        
    # 反向传播函数,根据误差计算权重和偏置的梯度,用于更新权重和偏置  
    def backward_propagation(self, input_data, target_data, learning_rate):    
        # 计算预测值与真实值之间的误差  
        error = target_data - self.output    
        # 计算输出层的梯度,使用sigmoid函数的导数(sigmoid_derivative)与误差相乘得到  
        output_delta = error * sigmoid_derivative(self.output)    
        # 计算隐藏层的梯度,通过输出层的梯度与权重矩阵的转置相乘得到  
        hidden_error = np.dot(output_delta, self.weights2.T)    
        # 计算隐藏层的梯度,使用sigmoid函数的导数(sigmoid_derivative)与误差相乘得到  
        hidden_delta = hidden_error * sigmoid_derivative(self.hidden)    
        
        # 根据学习率和梯度更新权重矩阵weights2和偏置项bias2  
        self.weights2 += learning_rate * np.dot(self.hidden.T, output_delta)    
        self.bias2 += learning_rate * np.sum(output_delta, axis=0, keepdims=True)    
        # 根据学习率和梯度更新权重矩阵weights1和偏置项bias1  
        self.weights1 += learning_rate * np.dot(input_data.T, hidden_delta)    
        self.bias1 += learning_rate * np.sum(hidden_delta, axis=0, keepdims=True)    
        
    # 训练函数,接受输入数据、目标数据、学习率和训练轮数作为参数,进行神经网络的训练  
    def train(self, input_data, target_data, learning_rate=0.01, epochs=1000):    
        # 循环训练轮数epochs次,进行前向传播、反向传播和误差打印的操作  
        for epoch in range(epochs):    
            output = self.forward_propagation(input_data)  # 前向传播计算输出结果  
            error = target_data - output  # 计算误差
            gradients = self.backward_propagation(input_data, target_data, learning_rate)  
            if epoch % 100 == 0:  
                print("Epoch:", epoch, "Error:", error)  
      
    def predict(self, input_data):  
        output = self.forward_propagation(input_data)  
        return sigmoid(output) > 0.5

文章来源:https://blog.csdn.net/qq_19774249/article/details/135448373
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。