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

此书地址:

《【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.rhkb.cn/news/429502.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[Excel VBA办公]如何使用VBA批量删除空行

在处理Excel数据时,空行可能会干扰数据分析和展示。以下是一个VBA代码示例,帮助你批量删除工作表中的空行。 1. 代码说明 此代码将遍历指定工作表,删除所有空行,确保数据整洁。 2. VBA代码 删除sheet1的空行 Sub DeleteEmptyRow…

VMware虚拟机因磁盘空间不足黑屏无法登录

在虚拟机里存储了一些文件之后,再打开发现进不去了,只有光标一直在左上角,登录的框都是黑的,具体如下: 明明知道登录框的存在却怎么也触碰不到它T_T ,先说解决方法: 产生这个问题的原因是因为磁…

大数据Flink(一百二十一):Flink CDC基本介绍

文章目录 Flink CDC基本介绍 一、什么是CDC 二、CDC的实现机制 三、​​​​​​​​​​​​​​传统 CDC ETL 分析 四、​​​​​​​​​​​​​​基于 Flink CDC 的 ETL 分析 五、​​​​​​​​​​​​​​什么是 Flink CDC 六、​​​​​​​​​​​​​​…

OpenCV特征检测(10)检测图像中直线的函数HoughLinesP()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 在二值图像中使用概率霍夫变换查找线段。 该函数实现了用于直线检测的概率霍夫变换算法,该算法在文献 181中有所描述。 HoughLines…

go webapi上传文件

一、导入依赖 import "net/http" 我这里用到了Guid所以安装依赖 go get github.com/google/uuid 二、main.go package mainimport ("fmt""github.com/jmoiron/sqlx""github.com/tealeg/xlsx""log""path/filepath&q…

Cpp类和对象(中续)(5)

文章目录 前言一、赋值运算符重载运算符重载赋值运算符重载赋值运算符不可重载为全局函数前置和后置的重载 二、const修饰成员函数三、取地址及const取地址操作符重载四、日期类的实现构造函数日期 天数日期 天数日期 - 天数日期 - 天数日期类的大小比较日期类 > 日期类日…

【CSS in Depth 2 精译_036】5.6 Grid 网格布局中与对齐相关的属性 + 5.7本章小结

当前内容所在位置(可进入专栏查看其他译好的章节内容) 第一章 层叠、优先级与继承(已完结) 1.1 层叠1.2 继承1.3 特殊值1.4 简写属性1.5 CSS 渐进式增强技术1.6 本章小结 第二章 相对单位(已完结) 2.1 相对…

桶排序和计数排序(非比较排序算法)

桶排序 桶排序是一种基于分配的排序算法,特别适合用来排序均匀分布的数据。它的基本思想是将输入的数据分到有限数量的桶里,然后对每个桶内的数据分别进行排序,最后再将各个桶内的数据合并得到最终的排序结果。(通常用于浮点数,因…

Go-知识-定时器

Go-知识-定时器 1. 介绍2. Timer使用场景2.1 设定超时时间2.2 延迟执行某个方法 3. Timer 对外接口3.1 创建定时器3.2 停止定时器3.3 重置定时器3.4 After3.5 AfterFunc 4. Timer 的实现原理4.1 Timer数据结构4.1.1 Timer4.1.2 runtimeTimer 4.2 Timer 实现原理4.2.1 创建Timer…

【Godot4.3】基于状态切换的游戏元素概论

提示 本文的设想性质比较大,只是探讨一种设计思路。完全理论阶段,不可行就当是闹了个笑话O(∩_∩)O哈哈~但很符合我瞎搞的气质。 概述 一些游戏元素,其实是拥有多个状态的。比如一个宝箱,有打开和关闭两个状态。那么只需要设定两个状态的图…

并发编程多线程

1.线程和进程的区别? 进程是正在运行程序的实例,进程中包含了线程,每个线程执行不同的任务不同的进程使用不同的内存空间,在当前进程下的所有线程可以共享内存空间线程更轻量,线程上下文切换成本一般上要比进程上下文…

axure的下载,激活,汉化全过程,多图

1.前言 下载地址:https://pan.baidu.com/s/12xo1mJer2hmBK7QrYM5v-Q?pwd0107#list/path%2Fcsdn%E5%85%B1%E4%BA%AB%E6%96%87%E4%BB%B6 源文章:https://blog.csdn.net/iwanttostudyc/article/details/123773796?ops_request_misc%257B%2522request%25…

STM32 单片机最小系统全解析

STM32 单片机最小系统全解析 本文详细介绍了 STM32 单片机最小系统,包括其各个组成部分及设计要点与注意事项。STM32 最小系统在嵌入式开发中至关重要,由电源、时钟、复位、调试接口和启动电路等组成。 在电源电路方面,采用 3.3V 直流电源供…

.Net网络通信组件 - TouchSocket

文章目录 .Net网络通信组件 - TouchSocket1、新建.Net8控制台项目2、Nuget安装TouchSocket组件3、编写服务端代码4、编写客户端代码5、编写Program代码6、运行效果7、日志组件(NLog)参考我的另一篇博客 .Net网络通信组件 - TouchSocket 1、新建.Net8控制…

PyCharm的使用

PyCharm的入门使用教程 下载和安装PyCharm: 首先,访问JetBrains官方网站(https://www.jetbrains.com/pycharm/)下载PyCharm的最新版本。根据您的操作系统选择合适的版本进行下载。 安装完成后,打开PyCharm。 创建新…

深度学习03-神经网络02-激活函数

可以使用这个进行跳转链接​​​​​​​http://playground.tensorflow.org/#activationrelu&batchSize11&datasetspiralDatasetreg-gauss&learningRate0.01ularizationRate0.1&noise0&networkShape7,5,4,3,2&seed0.54477&showTestDatafalse&d…

【Unity设计模式】Unity MVC/MVP架构介绍,及MVC/MVP框架的简单应用

文章目录 什么是MVC?MVC眼花缭乱设计图MVP和MVC最经典的MVC的业务流程Unity MVC 框架示例1. 创建项目结构2. 实现模型3. 实现视图4. 实现控制器5. 使用示例 总结参考完结 什么是MVC? MVC自1982年被设计出来,至今都有着很大比重的使用率&…

HCIA--实验十八:配置全局DCHP

一、实验内容 1.需求/要求: 使用一台5700交换机和一台PC,实现全局DHCP的配置,并且自定义配置网关,配置DNS。 二、实验过程 1.拓扑图: 2.步骤: 1.SW1激活DHCP服务,创建vlan10 2.SW1给vlan10添加ip地址 …

Transformer模型-7- Decoder

概述 Decoder也是N6层堆叠的结构,每层被分3层: 两个注意力层和前馈网络层,同Encoder一样在主层后都加有Add&Norm,负责残差连接和归一化操作。 Encoder与Decoder有三大主要的不同: 第一层 Masked Multi-Head Attention: 采用…

Linux 动静态库

目录 一.静态库 1.理解静态库 a.什么是静态库? b.创建静态库的理论? 2.打包静态库 3.静态库的使用方法 a.头文件找不着 b.链接报错——库函数文件找不着 4.将静态库文件写到系统目录下 a.直接拷贝 b.建立软链接 二.动态库 1.什么是动态库&am…