机器学习入门与进阶
本文档详细讲解了机器学习的重要概念和技术,以神经网络为核心,结合实践工具TensorFlow,帮助读者深入理解机器学习中的理论与实现。
1. 神经网络基础
1.1 感知机
感知机是最早的人工神经网络模型之一,由Frank Rosenblatt提出。它的基本结构是一个单层神经元,具有以下特性:
- 输入:向量形式的特征值 ( (x_1, x_2, ..., x_n) )
- 权重:与输入对应的权重 ( (w_1, w_2, ..., w_n) )
- 偏置:一个常数 ( b )
- 输出:通过激活函数 ( f ) 计算得出:
y = f\left(\sum_{i=1}^{n} w_i x_i + b\right)
其中,( f ) 通常是一个阶跃函数或其他非线性激活函数。
特点:
- 线性可分问题:感知机能够有效解决线性可分问题,也就是说,它能够找到一条决策边界将不同类别的样本分开。
- 局限性:感知机无法解决更复杂的非线性问题,例如异或(XOR)问题,因其只能通过线性决策边界进行分类。
感知机是神经网络的基础,为后来的多层感知机(MLP)和深度学习模型的提出奠定了基础。
1.2 多层感知机(MLP)
多层感知机通过增加隐藏层的数量解决了感知机无法处理非线性问题的限制。MLP的特点:
- 多层结构:包含输入层、一个或多个隐藏层、输出层。
- 激活函数:常用的有Sigmoid、ReLU等。
- 前向传播:输入经过每一层的权重、偏置和激活函数依次传递到输出层。
MLP是实现深度学习的基本模型之一。
1.3 整流线性单元(ReLU)
ReLU(Rectified Linear Unit)是深度学习中广泛使用的激活函数,其定义如下:
f(x) = \max(0, x)
优点:
- 计算简单:ReLU的计算非常简单,对于输入值 ( x ),如果 ( x > 0 ),则输出为 ( x ),否则输出为 0。这使得ReLU在计算时非常高效。
- 避免了梯度消失问题:传统的激活函数如Sigmoid和Tanh在较大的输入值下容易出现梯度消失的问题,而ReLU通过将负值归零,仅保留正值,避免了这一问题。
- 加速网络收敛:由于ReLU的非线性和梯度的有效传播,它通常能加速网络的收敛速度。
ReLU已成为现代神经网络中最常用的激活函数,尤其在卷积神经网络(CNN)和深度神经网络(DNN)中具有重要应用。
1.4 神经网络内积问题
神经网络的核心计算是内积运算,公式如下:
z = \sum_{i=1}^{n} w_i x_i + b
其中:
- ( w_i ) 是第 ( i ) 个特征的权重,
- ( x_i ) 是第 ( i ) 个特征的输入,
- ( b ) 是偏置项,
- ( n ) 是特征的总数。
问题:
- 大规模数据计算时效率低:对于大规模数据集,内积运算需要处理大量的计算,导致效率较低。通常需要采用优化方法或并行计算来提高效率。
内积运算受输入值和权重初始化的影响:内积运算的结果依赖于输入特征和权重的初始化。若初始权重设置不当,可能导致训练过程中的梯度消失或梯度爆炸问题。因此,合理的权重初始化和输入数据归一化(如标准化或归一化)是非常重要的。
1.5 TensorFlow初使用
TensorFlow是一个开源的机器学习框架,具有高效的数值计算能力。简单的示例如下:
import tensorflow as tf
# 创建一个张量
x = tf.constant([[1.0, 2.0], [3.0, 4.0]])
y = tf.constant([[5.0, 6.0], [7.0, 8.0]])
# 计算矩阵乘法
result = tf.matmul(x, y)
print(result)
1.6 损失函数
损失函数是衡量模型预测值与真实值差距的指标,常用的损失函数包括:
- 均方误差(MSE):用于回归问题,计算预测值与真实值之间的平方差的平均值。
- 交叉熵(Cross-Entropy):用于分类问题,衡量两个概率分布之间的差异,通常用于多分类问题。
1.7 反向传播
反向传播(Backpropagation)是神经网络训练的关键算法,用于计算每个参数的梯度值。其基本步骤:
1. 计算损失函数:根据模型的输出和真实标签,计算损失值。
2. 逐层计算误差的梯度:从输出层开始,逐层向输入层反向传播误差。
3. 利用链式法则更新参数:根据梯度更新模型的权重和偏置。
1.8 神经网络求梯度值
梯度是优化算法中的核心概念,用于指示损失函数在当前参数空间的下降方向。在TensorFlow中,可以使用GradientTape计算梯度:
with tf.GradientTape() as tape:
y_pred = model(x) # 模型的前向传播
loss = loss_function(y_true, y_pred) # 计算损失
gradients = tape.gradient(loss, model.trainable_variables) # 计算梯度
1.9 高阶内容
1.9.1 神经网络反向传播求梯度
链式法则用于反向传播时计算每一层的梯度。对于一个多层神经网络,梯度计算公式如下:
\frac{\partial L}{\partial w} = \frac{\partial L}{\partial y} \cdot \frac{\partial y}{\partial z} \cdot \frac{\partial z}{\partial w}
其中:
- ( L ) 是损失函数,
- ( y ) 是当前层的输出,
- ( z ) 是当前层的加权输入,
- ( w ) 是当前层的权重。
这个公式通过链式法则将梯度从输出层逐层传播回输入层,计算每一层的权重梯度。
1.9.2 神经网络全微分公式求偏导(梯度)
利用全微分公式,逐层展开计算每一层的偏导数,递归更新权重。通过反向传播算法,计算损失函数相对于每个参数的梯度,并使用这些梯度来更新模型的参数。
1.9.3 SGD优化
随机梯度下降(SGD)是最简单的优化算法,核心公式:
\theta_{t+1} = \theta_t - \eta \nabla_{\theta} J(\theta_t; x^{(i)}, y^{(i)})
其中:
- ( \theta_t ) 是当前参数向量,
- ( \theta_{t+1} ) 是更新后的参数向量,
- ( \eta ) 是学习率,
- ( \nabla_{\theta} J(\theta_t; x^{(i)}, y^{(i)}) ) 是目标函数 ( J ) 相对于参数 ( \theta ) 的梯度,计算时仅使用单个样本 ( (x^{(i)}, y^{(i)}) )。
1.9.4 五层神经网络(fivelayerNN)
五层神经网络通常包括:
- 输入层:接收输入数据。
- 三个隐藏层:通过非线性激活函数(如ReLU)进行转换。
- 输出层:根据任务类型(回归或分类)输出结果。
每一层的计算都包括加权求和和激活函数,最后通过反向传播调整权重和偏置。
2. 神经网络高级技术
2.1 Dropout(0-10)
Dropout是一种正则化技术,旨在减少过拟合。它通过在训练过程中随机“丢弃”部分神经元来迫使模型更加鲁棒。通常Dropout的值在0到1之间,实践中常取0.2到0.5。
2.2 测试im2col优化
im2col 是CNN计算中的优化方法,将卷积操作转化为矩阵乘法,提升计算效率。它通过将图像矩阵转换为列形式,使得卷积过程可以使用高效的矩阵乘法来加速运算。
2.3 CNN模型搭建
卷积神经网络(CNN)是处理图像任务的核心模型,通常包括以下层:
- 卷积层:提取图像的局部特征。
- 池化层:通过下采样降低特征图的维度。
- 全连接层:用于最后的分类或回归任务。
一个简单的CNN模型可以使用TensorFlow构建:
import tensorflow as tf
from tensorflow.keras import layers, models
model = models.Sequential([
layers.Conv2D(32, (3, 3), activation='relu', input_shape=(28, 28, 1)),
layers.MaxPooling2D((2, 2)),
layers.Flatten(),
layers.Dense(64, activation='relu'),
layers.Dense(10, activation='softmax')
])
以上是神经网络的基础理论和技术实现,涵盖了从感知机到深度神经网络的演进,包含常用的优化方法和TensorFlow实现。
Comments NOTHING