深度学习-从零基础快速入门到项目实践,这本书上市了!!!

server/2024/9/22 14:28:06/

此书地址:

《【2024新书】深度学习 从零基础快速入门到项目实践 文青山 跟我一起学人工智能 机器学习算法原理代码实现教程 深度学习项目分析 深度学习 从零基础快速入门到项目实践》【摘要 书评 试读】- 京东图书
深度学习外我还写了一本软件测试书。我大概是国内第1个,跨2个领域书籍的作者吧!

《Python软件测试实战宝典 系统覆盖5大软件测试技术主题,深解析软件测试的理论、方法、工具及管理方法,精准定位软件测试痛点》(智谷一川)【摘要 书评 试读】- 京东图书 (jd.com)

如何学习深度学习呢?

       针对这个问题也许每个人都有不同的观点,本书的编排目录也就是我的学习过程。

        大概是在2022年的时候,很偶然接触到这个领域,刚开始是没有什么信心觉得自己能够入门,因为这个领域十分的陌生,听起来也非常的高端,随便翻翻书,密密麻麻的数学公式真的看得头晕眼花。本着复杂的东西工作需要一定要搞懂的心态,然后立志坚定地开始了密集的学习,学习的过程是有点忙碌的,每天大概研究原理和看代码到23:00,周末也没有休息。

        好在经过1个多月的样子,原来复杂的原理似乎懂了一些,根据原理看开源的代码也没有那么痛苦,也可以根据工作需要修改开源的代码实现某些功能,七七八八能够用了,但是自己觉得有点云里雾里的。赶巧在2022年底作为“新冠”最后阶段的密接人员在家闭关半个月,闲着无聊突发其想打算重写一些经典模型的代码,加强加深对于经典算法的理解。于是出于打发时光的目的,虽然代码写得很丑、可能还有较多错误之处,但好歹完成了本书大部分代码的主体。

        然后又在机缘巧合之下跟出版社这边加上了好友,聊着、聊着就讨论到了如何学习深度学习,如何用最短的时间入门深度学习,也就有了此书的初衷。

        因为定位0基础,所以准备了较多基础知识,本着更好的理解并在学习过程中逐步提高代码能力,也没有调用一些知名第3方集成库、或者直接解析开源代码,每个例子的每行代码都是经过自己理解(水平有限,可能有误)手敲过的,代码虽臭、但都有参考意义。

        另外,阅读此书需要很强的数学吗?个人感觉读者只要会求导就行。本书涉及到的数学知识不够严谨。因为基本上对复杂的数学公式通过数值代入进行了“破坏性”计算,有着很详细的步骤(数学好的略过),这样做的目的是为了更好的理解。在编程的世界里,复杂的数学公式很多时候就是一个Python函数,作为应用层,个人觉得怎么算、严不严谨,不是极度重要的,理解它背后做了什么事、意义是什么,够用就行。

        以上只是个人观点,如有不妥之处,都是我的理解有误,还请指正。最后,本人水平有限和时间有限,书中难免有不妥之处,恳请广大读者批评指正。

本书内容简介:

        本书从Python基础入手,循序渐进地讲到机器学习、深度学习等领域的算法原理和代码实现,在学习算法理论的同时也强调了代码工程能力的逐步提高

本书共分为6个章节

        第1章从零基础介绍Python基础语法、Python数据处理库NumPy、Pandas、Matplotlib、OpenCV的使用;

        第2章,主要介绍了机器学习算法的原理并配有代码实例,方便在理解原理的同时也能写出代码;

        第3章,主要介绍深度学习框架TensorFlow、Keras、PyTorch的API和网络模型的搭建方法,力保读者能够掌握主流深度学习框架的使用;

        第4章,主要介绍了CNN卷积神经网络各种卷积的特性,并同时代码实战了多个经典分类网络;

        第5章,主要介绍了目标检测领域中多个经典算法的原理,并配套展现了代码调试的过程,将算法原理与代码进行了结合,方便更深入的理解算法原理;

        第6章,主要分享了深度学习项目的分析和实现过程。

本书目录:

自序... 1

内容简介... 2

第1章 Python编程基础... 2

1.1     环境搭建... 2

总结... 10

练习... 10

1.2     基础数据类型... 10

1.2.1数值型... 10

1.2.2字符串... 12

1.2.3元组... 14

1.2.4列表... 15

1.2.5字典... 17

1.2.6集合... 19

1.2.7数据类型的转换... 20

总结... 21

练习... 21

1.3     条件语句... 22

总结... 26

练习... 26

1.4     循环语句... 26

总结... 29

练习... 29

1.5     函数... 29

总结... 33

练习... 33

1.6     类... 33

总结... 38

练习... 38

1.7     文件处理... 38

总结... 38

练习... 38

1.8     异常处理... 38

总结... 39

练习... 39

1.9     模块与包... 39

总结... 41

练习... 41

1.10       包的管理... 41

总结... 46

练习... 46

1.11       NumPy简介... 46

1.11.1 NDArray的创建... 46

1.11.2 NDArray索引与切片... 47

1.11.3 NDArray常用运算函数... 51

1.11.4 NDArray广播机制... 53

总结... 54

练习... 54

1.12       Pandas简介... 54

1.12.1 Pandas对象的创建... 54

1.12.2 Pandas的索引与切片... 55

1.12.3 Pandas常用统计函数... 57

1.12.4 Pandas文件操作... 58

总结... 59

练习... 59

1.13       Matplotlib简介... 59

1.13.1 Matplotlib基本使用流程... 59

1.13.2 Matplotlib绘直方图、饼图等... 61

1.13.3 Matplotlib绘3D图像... 63

总结... 64

练习... 64

1.14       OpenCV简介... 65

1.14.1图片的读取和存储... 65

1.14.2画矩形、圆形等... 66

1.14.2在图中增加文字... 67

1.14.2读取视频或摄像头... 68

总结... 69

练习... 69

第2章 机器学习基础... 69

2.1HelloWorld之KNN算法... 69

2.1.1KNN算法原理... 69

2.1.2KNN算法代码实现... 71

总结... 73

练习... 73

2.2梯度下降... 74

2.2.1什么是梯度下降... 74

2.2.2梯度下降的代码实现... 76

2.2.3SGD、BGD和MBGD. 77

2.2.4Momentum优化算法... 83

2.2.5NAG优化算法... 86

2.2.6AdaGrad优化算法... 89

2.2.7RMSprop优化算法... 92

2.2.8AdaDelta优化算法... 95

2.2.9Adam优化算法... 98

2.2.10学习率的衰减... 101

总结... 106

练习... 106

2.3线性回归... 107

2.3.1梯度下降求解线性回归... 107

2.3.2梯度下降求解多元线性回归... 113

总结... 117

练习... 117

2.4逻辑回归... 117

2.4.1最大似然估计... 117

2.4.2梯度下降求解逻辑回归... 118

总结... 126

练习... 126

2.5聚类算法... 126

总结... 133

练习... 133

2.6神经网络... 133

2.6.1什么是神经网络... 133

2.6.2反向传播算法... 139

2.6.3SoftMax反向传播... 145

总结... 149

练习... 149

2.7欠拟合与过拟合... 149

总结... 153

练习... 153

2.8正则化... 153

总结... 161

练习... 161

2.9梯度消失与梯度爆炸... 161

总结... 170

练习... 170

第3章 深度学习框架... 171

3.1基本概念... 171

总结... 172

练习... 172

3.2环境搭建... 172

总结... 179

练习... 179

3.3TensorFlow基础函数... 179

3.3.1TensorFlow初始类型... 179

3.3.2TensorFlow指定设备... 180

3.3.3TensorFlow数学运算... 181

3.3.4TensorFlow维度变化... 184

3.3.5TensorFlow切片取值... 185

3.3.6TensorFlow中gather取值... 186

3.3.7TensorFlow中布尔取值... 189

3.3.8TensorFlow张量合并... 190

3.3.9TensorFlow网格坐标... 191

3.3.10TensorFlow自动求梯度... 192

总结... 193

练习... 193

3.4TensorFlow中的Keras模型搭建... 193

3.4.1tf.keras简介... 193

3.4.2基于tf.keras.Sequential模型搭建... 194

3.4.3继承tf.keras.Model类模型搭建... 196

3.4.4函数式模型搭建... 196

总结... 197

练习... 197

3.5TensorFlow中模型的训练方法... 197

3.5.1使用model.fit训练模型... 197

3.5.2使用model.train_on_batch训练模型... 201

3.5.3 自定义模型训练... 202

总结... 204

练习... 204

3.6TensorFlow中Metrics评价指标... 205

3.6.1准确率... 205

3.6.2精确率... 206

3.6.3召回率... 207

3.6.4P-R曲线... 208

3.6.6ROC曲线... 211

3.6.7AUC曲线... 213

3.6.8混淆矩阵... 214

总结... 216

练习... 216

3.7TensorFlow中推理预测... 216

总结... 217

练习... 217

3.8PyTorch搭建神经⽹络... 217

3.8.1PyTorch转换为张量... 217

3.8.2PyTorch指定设备... 218

3.8.3PyTorch数学运算... 219

3.8.4PyTorch维度变化... 219

3.8.5PyTorch切片取值... 220

3.8.6PyTorch中gather取值... 220

3.8.7PyTorch中布尔取值... 220

3.8.8PyTorch张量合并... 221

3.8.9PyTorch模型搭建... 221

3.8.10PyTorch模型自定义训练... 223

3.8.11PyTorch调用Keras训练... 225

3.8.12PyTorch调用TorchMetrics评价指标... 227

3.8.13PyTorch中推理预测... 230

总结... 231

练习... 231

第4章 卷积神经网络... 231

4.1卷积... 232

4.1.1为什么用卷积... 232

4.1.2单通道卷积计算... 232

4.1.3多通道卷积计算... 236

4.1.4卷积padding和valid. 239

4.1.5感受野... 242

4.1.6卷积程序计算过程... 243

总结... 246

练习... 246

4.2池化... 246

总结... 250

练习... 250

4.3卷积神经网络的组成要素... 250

总结... 251

练习... 251

4.4常见卷积分类... 251

4.4.1分组卷积... 251

4.4.2逐点卷积... 252

4.4.3深度可分离卷积... 253

4.4.4空间可分离卷积... 255

4.4.5空洞卷积... 255

4.4.6转置卷积... 257

4.4.7可变形卷积... 258

总结... 260

练习... 260

4.5卷积神经网络LeNet5. 260

4.5.1模型介绍... 260

4.5.2代码实战... 261

总结... 264

练习... 264

4.6深度卷积神经网络AlexNet. 265

4.6.1模型介绍... 265

4.6.2代码实战... 265

总结... 269

练习... 269

4.7使用重复元素的网络VGG. 270

4.7.1模型介绍... 270

4.7.2代码实战... 271

总结... 272

练习... 272

4.8合并连接网络GoogleNet. 273

4.8.1模型介绍... 273

4.8.2代码实战... 278

总结... 282

练习... 282

4.9残差网络ResNet. 282

4.9.1残差块... 282

4.9.2归一化... 285

4.9.3模型介绍... 292

4.9.4代码实战... 293

总结... 295

练习... 295

4.10轻量级网络MobileNet. 295

4.10.1模型介绍... 295

4.10.2注意力机制... 300

4.10.3代码实战... 310

总结... 314

练习... 314

4.11轻量级网络ShuffleNet. 314

4.11.1模型介绍... 314

4.11.2代码实战... 320

总结... 323

练习... 323

4.12重参数网络RepVGGNet. 323

4.12.1模型介绍... 323

4.12.2代码实战... 328

总结... 332

练习... 332

第5章 目标检测... 332

5.1标签处理及代码... 333

总结... 338

练习... 338

5.2开山之作R-CNN. 338

5.2.1模型介绍... 338

5.2.2 代码实战选择区域搜索... 339

5.2.3 代码实战正负样本选择... 339

5.2.4 代码实战特征提取... 344

5.2.6 代码实战SVM分类训练... 345

5.2.7 代码实战边界框回归训练... 346

5.2.8 代码实战预测推理... 348

总结... 352

练习... 352

5.3 两阶段网络Faster R-CNN. 352

5.3.1模型介绍... 352

5.3.2 代码实战RPN、ROI模型搭建... 357

5.3.3 代码实战RPN损失函数及训练... 360

5.3.4 代码实战ROI损失函数及训练... 365

5.3.5 代码实战预测推理... 369

总结... 371

练习... 371

5.4 单阶段多尺度检测网络SSD. 371

5.4.1模型介绍... 371

5.4.2 代码实战模型搭建... 375

5.4.3 代码实战建议框的生成... 380

5.4.4 代码实战损失函数的构建及训练... 386

5.4.5 代码实战预测推理... 389

总结... 390

练习... 390

5.5 单阶段速度快的检测网络Yolo1. 390

5.5.1模型介绍... 390

5.5.2代码实战模型搭建... 393

5.5.3无建议框时标注框编码... 394

5.5.4代码实现损失函数的构建及训练... 396

5.4.5 代码实战预测推理... 401

总结... 404

练习... 405

5.6 单阶段速度快的检测网络Yolo2. 405

5.6.1模型介绍... 405

5.6.2代码实战模型搭建... 407

5.6.3代码实战聚类得到建议框宽高... 409

5.6.4代码实战建议框的生成... 410

5.6.5代码实现损失函数的构建及训练... 413

5.6.5 代码实战预测推理... 419

总结... 424

练习... 424

5.7 单阶段速度快多检测头网络Yolo3. 424

5.7.1模型介绍... 424

5.7.2代码实战模型搭建... 431

5.7.3代码实战建议框的生成... 433

5.7.4代码实现损失函数的构建及训练... 437

5.7.5 代码实战预测推理... 439

总结... 443

练习... 443

5.8 单阶段速度快多检测头网络Yolo4. 443

5.8.1模型介绍... 443

5.8.2代码实战模型搭建... 448

5.8.3代码实战建议框的生成... 452

5.8.4代码实现损失函数的构建及训练... 454

5.8.5 代码实战预测推理... 457

总结... 457

练习... 457

5.9 单阶段速度快多检测头网络Yolo5. 457

5.9.1模型介绍... 457

5.9.2代码实战模型搭建... 461

5.9.3代码实战建议框的生成... 465

5.9.4代码实现损失函数的构建及训练... 469

5.9.5 代码实战预测推理... 471

总结... 471

练习... 472

5.10 单阶段速度快多检测头网络Yolo7. 472

5.10.1模型介绍... 472

5.10.2代码实战模型搭建... 474

5.10.3代码实战建议框的生成... 479

5.10.5代码实现损失函数的构建及训练... 494

5.10.6 代码实战预测推理... 496

总结... 496

练习... 497

5.11 数据增强... 497

5.11.1 数据增强的作用... 497

5.11.3代码实现MixUp数据增强... 499

5.11.4代码实现随机复制Label数据增强... 500

5.11.5代码实现Mosic数据增强... 501

总结... 504

练习... 504

第6章 项目实战... 504

6.1 计算机视觉项目的工作流程... 504

总结... 505

练习... 506

6.2 条形码项目实战... 506

6.2.1 项目背景分析... 506

6.2.2 整体技术方案... 506

6.2.3 数据分布分析... 508

6.2.4 参数设置... 520

6.2.5 训练结果分析... 521

6.2.6 OpenCV DNN实现推理... 523

总结... 527

练习... 527

致谢... 527

参考文献... 527

重点内容图形介绍:


http://www.ppmy.cn/server/120314.html

相关文章

概率论与数理统计(2)

第一节博客已经整理了求导的公式,一些常用的概念。链接如下:高等数学基础(1)-CSDN博客。 第二节博客整理了微积分的公式及其相关概念。链接如下:高等数学基础(2)——微积分-CSDN博客 第三节博客…

【运维项目经历|044】云迁移与CI/CD管道优化项目

🍁博主简介: 🏅云计算领域优质创作者 🏅2022年CSDN新星计划python赛道第一名 🏅2022年CSDN原力计划优质作者 🏅阿里云ACE认证高级工程师 🏅阿里云开发者社区专家博主 💊交流社区:CSDN云计算交流社区欢迎您的加入! 文章目录 项目名称项目背景项目目标项目成果我…

Python基础(十)——闭包、装饰器、设计模式与多线程编程

十一.高级用法 1.闭包 在函数嵌套的前提下,内部函数使用了外部函数的变量,并且外部函数返回了内部函数,把这个使用外部函数变量的内部函数称为闭包。 解释: 外部函数的参数因为作用域的原因,只是一个临时变量&…

Vue.js与Flask/Django后端配合

Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架,而 Flask 和 Django 是两个流行的 Python Web 框架,分别用于构建轻量级和全功能的 Web 应用程序。将 Vue.js 与 Flask 或 Django 后端配合使用,可以创建一个现代化的、前后端分离的 W…

2024华为杯E题成品文章已出!

E题高速公路应急车道紧急启用模型 点击链接加入群聊【2024华为杯数学建模助攻资料】:http://qm.qq.com/cgi-bin/qm/qr?_wv1027&kxtS4vwn3gcv8oCYYyrqd0BvFc7tNfhV7&authKeyedQFZne%2BzvEfLEVg2v8FOm%2BWNg1V%2Fiv3H4tcE6X%2FW6lCmkhaSaZV4PwQ%2FOVPDtF%2B&…

缓存预热方案详解

在高性能Web应用中,缓存技术是提升系统响应速度的关键手段之一。然而,在系统启动或重启后,缓存往往是空的,此时来自用户的请求将直接打到数据库上,导致响应时间增加。为了避免这种情况,缓存预热就显得尤为重…

如何安装和注册 GitLab Runner

如何安装和注册 GitLab Runner GitLab Runner 是一个用于运行 GitLab CI/CD (Continuous Integration/Continuous Deployment) 作业。它是一个与 GitLab 配合使用的应用程序,可以在本地或云中运行。Runner 可以执行不同类型的作业,例如编译代码、运行测…

【Docker】安装全流程与配置完整镜像源(可安装 nginx)

目录 一、卸载历史版本(选)二、配置 yum 源三、安装 docker四、配置 docker 镜像源加速(选、强烈建议)4.1 配置阿里镜像加速4.2 配置其他镜像源 五、启动 docker参考文章与视频 本文基于 Linux - CentOS 7 操作系统。 一、卸载历史…