Python深度学习入门:从零构建CNN和RNN作者: [美]韦德曼 出版时间:2021年版内容简介 本书全面介绍了深度学习知识,借助数学公式、示意图和代码,旨在帮助读者从数学层面、概念层面和应用层面理解神经网络。读者可以跟随本书构建和训练神经网络模型,从而解决实际问题。另外,本书着重介绍卷积神经网络和循环神经网络,并提供PyTorch开源神经网络库的使用方法,有助于学习构建更高级的神经网络架构。目录第 1章 基本概念 11.1 函数 21.2 导数 61.3 嵌套函数 81.4 链式法则 91.5 示例介绍 121.6 多输入函数 151.7 多输入函数的导数 161.8 多向量输入函数 171.9 基于已有特征创建新特征 181.10 多向量输入函数的导数 201.11 向量函数及其导数:再进一步 221.12 包含两个二维矩阵输入的计算图 251.13 有趣的部分:后向传递 281.14 小结 34第 2章 基本原理 352.1 监督学习概述 362.2 监督学习模型 382.3 线性回归 382.3.1 线性回归:示意图 392.3.2 线性回归:更有用的示意图和数学 412.3.3 加入截距项 412.3.4 线性回归:代码 422.4 训练模型 422.4.1 计算梯度:示意图 432.4.2 计算梯度:数学和一些代码 432.4.3 计算梯度:完整的代码 442.4.4 使用梯度训练模型 452.5 评估模型:训练集与测试集 462.6 评估模型:代码 462.7 从零开始构建神经网络 492.7.1 步骤1:一系列线性回归 492.7.2 步骤2:一个非线性函数 502.7.3 步骤3:另一个线性回归 502.7.4 示意图 512.7.5 代码 522.7.6 神经网络:后向传递 532.8 训练和评估第 一个神经网络 552.9 小结 57第3章 从零开始深度学习 583.1 定义深度学习 583.2 神经网络的构成要素:运算 593.2.1 示意图 603.2.2 代码 613.3 神经网络的构成要素:层 623.4 在构成要素之上构建新的要素 643.4.1 层的蓝图 663.4.2 稠密层 683.5 NeuralNetwork类和其他类 693.5.1 示意图 703.5.2 代码 703.5.3 Loss类 713.6 从零开始构建深度学习模型 723.6.1 实现批量训练 733.6.2 NeuralNetwork: 代码 733.7 优化器和训练器 753.7.1 优化器 763.7.2 训练器 773.8 整合 793.9 小结与展望 80第4章 扩展 814.1 关于神经网络的一些直觉 824.2 softmax交叉熵损失函数 844.2.1 组件1:softmax函数 844.2.2 组件2:交叉熵损失 854.2.3 关于激活函数的注意事项 874.3 实验 904.3.1 数据预处理 904.3.2 模型 914.3.3 实验:softmax交叉熵损失函数 924.4 动量 924.4.1 理解动量 934.4.2 在Optimizer类中实现动量 934.4.3 实验:带有动量的随机梯度下降 944.5 学习率衰减 954.5.1 学习率衰减的类型 954.5.2 实验:学习率衰减 974.6 权重初始化 974.6.1 数学和代码 994.6.2 实验:权重初始化 1004.7 dropout 1004.7.1 定义 1004.7.2 实现 1014.7.3 实验:dropout 1024.8 小结 104第5章 CNN 1055.1 神经网络与表征学习 1055.1.1 针对图像数据的不同架构 1065.1.2 卷积运算 1075.1.3 多通道卷积运算 1085.2 卷积层 1095.2.1 实现意义 1105.2.2 卷积层与全连接层的区别 1115.2.3 利用卷积层进行预测:Flatten层 1115.2.4 池化层 1125.3 实现多通道卷积运算 1145.3.1 前向传递 1145.3.2 后向传递 1175.3.3 批处理 1205.3.4 二维卷积 1215.3.5 最后一个元素:通道 1235.4 使用多通道卷积运算训练CNN 1265.4.1 Flatten运算 1265.4.2 完整的Conv2D层 1275.4.3 实验 1285.5 小结 129第6章 RNN 1306.1 关键限制:处理分支 1316.2 自动微分 1326.3 RNN的动机 1376.4 RNN简介 1386.4.1 RNN的第 一个类:RNNLayer 1396.4.2 RNN的第二个类:RNNNode 1406.4.3 整合RNNNode类和RNNLayer类 1406.4.4 后向传递 1426.5 RNN:代码 1436.5.1 RNNLayer类 1446.5.2 RNNNode类的基本元素 1476.5.3 vanilla RNNNode类 1486.5.4 vanilla RNNNode类的局限性 1506.5.5 GRUNode类 1516.5.6 LSTMNode类 1546.5.7 基于字符级RNN语言模型的数据表示 1566.5.8 其他语言建模任务 1576.5.9 组合RNNLayer类的变体 1586.5.10 将全部内容整合在一起 1586.6 小结 159第7章 PyTorch 1607.1 PyTorch Tensor 1607.2 使用PyTorch进行深度学习 1617.2.1 PyTorch元素:Model类及其Layer类 1627.2.2 使用PyTorch实现神经网络基本要素:DenseLayer类 1637.2.3 示例:基于PyTorch的波士顿房价模型 1647.2.4 PyTorch元素:Optimizer类和Loss类 1657.2.5 PyTorch元素:Trainer类 1657.2.6 PyTorch优化学习技术 1687.3 PyTorch中的CNN 1687.4 PyTorch中的LSTM 1737.5 后记:通过自编码器进行无监督学习 1757.5.1 表征学习 1757.5.2 应对无标签场景的方法 1767.5.3 在PyTorch中实现自编码器 1767.5.4 更强大的无监督学习测试及解决方案 1817.6 小结 182附录 深入探讨 183关于作者 192关于封面 192 上一篇: Python数据分析与挖掘实战 翟世臣 2022年版 下一篇: Python游戏开发从入门到精通 张有菊 2021年版