Pytorch(Overview)

news2024/11/23 17:39:19

目标

如何利用pytorch完成学习系统?

理解神经网络(neural networks)和深度学习(deep learning)基础。

需要了解线性代数和概率论数理统计等相关关系,和python编程语言。

讨论+理解

到底什么是human intelligence(人工智能)?

大家可以思考平时中午同学们去吃饭,去哪吃?吃什么?或者说今天穿什么衣服?

我们可能会考虑到时间问题(比如下午还有课),或者经济问题(月末可能就得在食堂将就将就了),也可能有很多其他干扰因素(不同菜的口味,或者最近身体状况等的影响),综合所有的问题,我们会最终选择一个答案。其实这个过程就是一个人工智能的算法,通过现有的条件,推理出最终的结果。大家看下面两张图,看见一张图,我们可以推测它是只猫,这就是把视觉信息转化为抽象的概念。或者把自然语言文本转化为抽象的概念(那关于为什么说数字是个抽象的概念,大家感兴趣可以自己去了解下)。那说了这么多,其实人工智能就是使用算法代替人脑里面进行处理的过程。

那其实对于我们深度学习的内容基本使用的都是有监督(supervise)学习。有监督学习其实就是我们会有一些打了标签(label)的数据集,我们知道每一个图像的答案,之后通过这些数据对于模型进行训练,最后完成我们的算法。

此时我们说的machine learning与我们算法课中的算法不太相同。

算法课中的主要的思维想法:穷举法,贪心算法,分治算法,动态规划算法。我们需要对这几种思维方式人工去设计出一套计算过程。

此时我们也发现了,我们刚刚说我们的machine learning是先有了数据集(DataSet),之后从数据集中把我们想要的算法给找出来,但是我们算法课中是需要我们人工去设计一套计算。

我们可以看这个人工智能(Ai)其实包括了很多的内容。我们可以看见Machine learning中包含我们将要学习的Deep learnin,当然Deep learning中还包含着很多的不同架构。

历史的发展

Rule-Base syste

最先出现的是基于规则的的系统(rule-base)。如图就是,我们先得到一些输入,之后手工的去设计设计程序,最后输出结果。(那相信小伙伴也看出,其实设计一个合理且满足需求的程序其实有很大难度,并且为了满足越来越多的需求,会最终导致无法维护的情况)。

Classic Machine learning

经典机器学习,首先也是得到输入,接着需要手工去提取特征(比如说吃饭,我们发现价格和味道对最终的结果有影响,那我们就把这两个特征(feature)提取出来)把这些特征建立成向量或者张量,然后把这个向量和我们的输出之间建立出一个映射的函数。

Representation learning

表示学习,与经典机器学习不同的就是,第二步的特征提取,我们现在不想手工提取了,希望中国feature也可以通过学习学会。

暂停一下下

为什么不管是在经典机器学习还是在表示学习中,都提到了feature这个概念。

我们思考一个问题,对于input中的feature如果越多,是不是就意味着input需要越多。(还是吃饭的例子,如果说价格,味道,时间,距离,心情。都会对我们选择吃什么产生影响,那是不是我们就需要更多的例子input提供作为参考,不然无法通过几次的output就可以训练出我们的模型,就无法准确判断去吃什么这样的output)(现在想,如果只有价格这一个单因素feature,那是不是我只需要几次的训练我就知道有钱的时候吃什么,没钱的时候吃什么。这样得到的结果是不是就很容易出来)。

现在我们会提到一个“维度诅咒”的概念

如果现在只有一个feature,那我就可以在一维的维度下进行采样,如果是10个样本就可以得到结果。那此时如果feature是两个,那就需要在二维下采样,就变成了10*10,100个样本。同理4个feature需要1000个样才能满足我们的大数定律。所以说当feature越多,需要的input也就越多,最终就无法承担(这个地方的input不是简单的一张图就可以,这个需要是我们大过标签的label,这个过程是非常耗时间的,大都会请其他的人来打标签,这样的成本就无法控制了(我们实验室正在面临这样的问题))。

所以此时我们希望feature比如是10维,压缩成3维。就需要用线性或非线性映射。此时就需要我们使用矩阵的知识。

继续

那此时从高维到低维这个过程就是我们的representation,也就是我们表示学习中的一步。其中有一个分支叫manifold(流行),我们称降维过程叫从高维分布中的低维流行。

Deep learning

之前在表示学习中需要训练特征提取器,而现在直接把原始特征拿进来,但是我们休要设计额外的一个层Additional layers来提取特征,然后进入学习器,最后输出。这个学习器通常就是我们说的多层的神经网路。

我们在representation learning中feature特征学习和mapping from feature是分开进行学习的,但是我们的deep learning中的所有训练过程都是统一的(end2end)

这个是scikit-learn官方提供的流程,都是较为简单的英语,可以跟着他的条件选择合适的方法。

神经网络发展一个重要的算法啊,反向传播

反向传播的的核心是计算图,就是上面这个。

总结

刚刚上面说的计算图算法,我们不需要自己去实现的。我们通常使用现成的deep learning framework 去进行实现(当然也可以自己去写framework,但是这个比我们写深度神经网络要难)

我们将会用到的deep learning frameworks是pytorch(facebook),当然还有其他的如TensorFlow(Google),还有一个就是已近和pytorch合并的Caffe(facebook),还有如MxNet。

感谢观看!欢迎大家一起学习Pytorch相关知识!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1699347.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vue3项目+TypeScript前端项目 ———— elemnet-plus,svg图标配置,sass,mock数据

一.集成element-plus 官网地址 安装 pnpm install element-plus 引入 // main.ts import { createApp } from vue import ElementPlus from element-plus import element-plus/dist/index.css import App from ./App.vueconst app createApp(App)app.use(ElementPlus) app.…

esp32-idf 开发踩坑记录

现象 直接使用原始命令编译idf.py build 但是提示idf 版本错误 卸载旧版本 编译出错build 问题 然后删除编译文件后,重新编译,还是出错 解决方法1 最后发现是因为项目所在文件夹有中文目录,把项目迁移到英文目录后,重新编译&a…

重学java 46.集合 ① Collection集合

事常与人违,事总在人为 —— 24.5.26 集合 知识导航 1.集合的特点以及作用 2.使用collection接口中的方法 3.使用迭代器迭代集合 4.ArrayList以及LinkedList的使用 5.使用增强for遍历集合 一、单列集合框架的介绍 1.长度可变的容器:集合 2.集合的特点 a.…

TCP/IP协议(一)

一.报文和协议 协议有什么作用?协议定义通信实体间所交换报文的格式和次序,以及在报文发送和/或接收或者其他事件方面所采取的行动(响应)。 什么是报文?指在网络中传输的数据单元,网络通讯的基本单位。(HTTP报文、TCP报…

录屏技巧:win11怎么录屏?这5个电脑录屏方法快速了解下

无论您是想进行工作演示还是游戏直播,电脑录屏都有很大帮助。录制 Win 11 屏幕在很多方面都非常有效,因为它能让事情变得更简单。但 Win11怎么录屏呢?如果您仍有困惑,请查看本篇文章中列出的5个方法。在本文中,我们列出…

Python 获取当前IP地址(爬虫代理)

Python 获取当前IP地址(爬虫代理) 在Python中,获取当前的公网IP地址通常涉及到发送一个请求到外部服务,因为本地IP地址通常只在你的私有网络内部是可见的,而公网IP地址是由你的ISP(互联网服务提供商&#x…

猫抓(cat-catch)插件的常规用法

目录 1.1、前言1.2、抓取图片资源1.3、抓取音频资源1.4、抓取视频资源 1.1、前言 本文将介绍利用猫抓(cat-catch)插件如下抓取网页上的图片、音频、视频等资源,猫抓(cat-catch)插件的安装及设置请参考推荐一款媒体影音…

【网络技术】【Kali Linux】Wireshark嗅探(十五)SSDP(简单服务发现协议)报文捕获及分析

往期 Kali Linux 上的 Wireshark 嗅探实验见博客: 【网络技术】【Kali Linux】Wireshark嗅探(一)ping 和 ICMP 【网络技术】【Kali Linux】Wireshark嗅探(二)TCP 协议 【网络技术】【Kali Linux】Wireshark嗅探&…

picamera配opencv做发现移动物体后录像50秒

本来是想配合上一篇写的测距传感器数据打开摄像头录制个50秒实时画面,后来这个测距传感器(因为我是歪用,用来识别范围内的移动物体)给的数据,false alarming还是太高了。于是想到使用本人之前深恶痛绝的opencv来试一试…

如何使用Kimi和通义千问辅助快速阅读论文

说明 上一篇博文我介绍了最新阅读的一篇TinyML的论文。我有个习惯就是使用Google Schloar跟踪当前最新的论文,只要在Google Schloar中设置好关键字,它每天就把最新的相关论文的链接和摘要发送到邮箱里面。不过现在论文太多了,每篇都认真读取…

分享免费的手机清理软件app,一款国外开发的手机清理神器,让手机再战两年!

手机内存越来越大,软件却越来越占地方,就像微信这家伙,轻轻松松就吃了十几个G! 害得阿星8128G的手机,本来想换新的,结果用了这款Avast Cleanup软件,瞬间感觉手机还能再战两年! 注意…

让大模型变得更聪明三个方向

让大模型变得更聪明三个方向 随着人工智能技术的飞速发展,大模型在多个领域展现出了前所未有的能力,但它们仍然面临着理解力、泛化能力和适应性等方面的挑战。那么,如何让大模型变得更聪明呢? 方向一:算法创新 1.1算…

Generative Action Description Prompts for Skeleton-based Action Recognition

标题:基于骨架的动作识别的生成动作描述提示 源文链接:https://openaccess.thecvf.com/content/ICCV2023/papers/Xiang_Generative_Action_Description_Prompts_for_Skeleton-based_Action_Recognition_ICCV_2023_paper.pdfhttps://openaccess.thecvf.c…

【云原生】kubernetes声明式管理-----YAML文件

目录 引言 一、声明式管理简介 (一)什么是声明式管理 (二)支持格式 二、YAML文件 (一)YAML文件基本格式 (二)YAML文件实践 三、YAML文件创建方式 (一&#xff0…

TabAttention:基于表格数据的条件注意力学习

文章目录 TabAttention: Learning Attention Conditionally on Tabular Data摘要方法实验结果 TabAttention: Learning Attention Conditionally on Tabular Data 摘要 医疗数据分析通常结合成像数据和表格数据处理,使用机器学习算法。尽管先前的研究探讨了注意力…

2024/05/25学习记录

1、面经复习:前端广度 2、代码随想录刷题:动态规划 3、rosebush 完成input组件基础

汇编原理(二)

寄存器:所有寄存器都是16位(0-15),可以存放两个字节 AX,BX,CX,DX存放一般性数据,称为通用寄存器 AX的逻辑结构。最大存放的数据为2的16次方减1。可分为AH和AL,兼容8位寄存器。 字:1word 2Byte…

互联网十万个为什么之 什么是Kubernetes(K8s)?

Kubernetes(通常简称为K8s)是一款用于自动部署、扩缩和管理容器化应用程序的开源容器编排平台。Kubernetes已发展为现代企业实现敏捷开发、快速迭代、资源优化及灵活扩展的关键技术组件之一。它拥有庞大的开源社区和丰富的生态系统。围绕Kubernetes已经形…

【vue2配置】Vue Router

Vue Router官网 1、npm install vue-router4 2、创建模块,在src目录小创/views/map/MapIndex.vue模块和创router/index.js文件 3、在router/index.js配置路由 import Vue from "vue"; import Router from "vue-router"; // 引入模块 const Ma…

特殊变量笔记3

输入一个错误命令, 在输出$? 特殊变量:$$ 语法 $$含义 用于获取当前Shell环境的进程ID号 演示 查看当前Shell环境进程编号 ps -aux|grep bash输出 $$ 显示当前shell环境进程编号 小结 常用的特殊符号变量如下 特殊变量含义$n获取输入参数的$0, 获取当前She…