当前位置: 首页 > article >正文

一篇文章入门机器学习与PyTorch张量

机器学习机器学习常见算法分类机器学习方式有监督学习无监督学习半监督学习强化学习。机器学习建模流程机器学习建模流程获取数据、数据基本理、特征工程、机器学习训练模型、模型评估模型拟合问题拟合用在机器学习领域用来表示模型对样本点的拟合情况欠拟合模型在训练集上表现很差、在测试集表现也很差过拟合模型在训练集上表现很好、在测试集表现很差泛化 具体的、个别的扩大为一般的能力深度学习深度学习区别于机器学习的显著特征是学习过程不可观测深度学习入门顺序PyTorch中的Tensor张量 ANN人工神经网络 CNN卷积神经网络 RNN循环神经网络Tensor张量PyCharm快捷键1、altshift鼠标左键纵向复制2、鼠标选中报错地方altenter自动导包3、alt1:左侧隐藏 alt4右侧隐藏4、ctrlaltinsert新建python文件5、altshift↓内容下移一行6、shiftf6:重命名张量的创建张量创建基本方式torch.tensor 根据指定数据创建张量创建全1、全0、内容全一样的张量创建线性和随机张量torch.arange(起始值终止值步长)#【包左不包右】torch.linspace(起始值终止值元素个数)#【等差数列】torch.manual_seed()#【设置随机种子】torch.rand(size(2,3))#【设置指定形状的均匀分布随机张量】torch.randn(size(2,3))# 【设置指定形状的正态分布随机张量】torch.randint(最小值最大值size(2,3))datetorch.tensor([1,4,,5,6,8],dtypetorch.float)t2date.type(torch.int16)张量元素类型转换张量的类型转换1、使用 from_numpy 可以将 ndarray 数组转换为 Tensor默认共享内存使用 copy 函数避免共享。2、使用 torch.tensor 可以将 ndarray 数组转换为 Tensor默认不共享内存。# 张量 numpyt1torch.tensor([1,2,3,4,5])n1t1.numpy()张量数值计算张量基本运算张量点乘、乘法运算张量运算函数PyTorch 为每个张量封装很多实用的计算函数均值平方根求和指数计算对数计算等等张量索引操作简单行列索引列表索引范围索引布尔索引依据文字的前后顺序看函数时从里到外看多维索引张量形状操作1、reshape 函数可以在保证张量数据不变的前提下改变数据的维度将其转换成指定的形状。2、squeeze 函数删除形状为 1 的维度降维unsqueeze 函数添加形状为1的维度升维。3、transpose 函数可以实现交换张量形状的指定维度, 例如: 一个张量的形状为 (2, 3, 4) 可以通过 transpose 函数把 3 和 4 进行交换, 将张量的形状变为 (2, 4, 3) 。 permute 函数可以一次交换更多的维度。4、view 函数也可以用于修改张量的形状只能用于修改连续的张量。在 PyTorch 中有些张量的底层数据在内存中的存储顺序与其在张量中的逻辑顺序不一致view 函数无法对这样的张量进行变形处理例如: 一个张量经过了 transpose 或者 permute 函数的处理之后就无法使用 view 函数进行形状操作。# 获取张量维度大小张量.shape[0]#【第0维大小】张量.shape[1]#【第1维大小】# 1、使用 reshape 函数修改张量形状datatorch.tensor([[10,20,30],[40,50,60]])new_datadata.reshape(1,6)print(new_data.shape)#torch.Size([1, 6])#2、使用squeeze 函数降维与unsqueeze 函数升维mydata1torch.tensor([1,2,3,4,5])mydata2mydata1.unsqueeze(dim0)print(在0维度上 拓展维度,mydata2,mydata2.shape)#1*5mydata3mydata1.unsqueeze(dim1)print(在1维度上 拓展维度,mydata3,mydata3.shape)#5*1mydata4mydata1.unsqueeze(dim-1)print(在-1维度上 拓展维度,mydata4,mydata4.shape)#5*1mydata5mydata4.squeeze()print(压缩维度,mydata5,mydata5.shape)#1*5# 3、使用transpose 函数与permute 函数datatorch.tensor(np.random.randint(0,10,[3,4,5]))print(data shape:,data.size())# 3.1 交换1和2维度mydata2torch.transpose(data,1,2)print(mydata2.shape---,mydata2.shape)# 3.2 将data 的形状修改为 (4, 5, 3), 需要变换多次mydata3torch.transpose(data,0,1)mydata4torch.transpose(mydata3,1,2)print(mydata4.shape---,mydata4.shape)# 3.3 使用 permute 函数将形状修改为 (4, 5, 3)# 3.3.1 方法1mydata5torch.permute(data,[1,2,0])print(mydata5.shape---,mydata5.shape)# 3.3.2 方法2mydata6data.permute([1,2,0])print(mydata6.shape---,mydata6.shape)#4、使用is_contiguous()判断是否为连续张量使用 contiguous 函数转换为连续的张量再使用 view 函数# 使用 transpose 函数修改形状datatorch.tensor([[10,20,30],[40,50,60]])mydata3torch.transpose(data,0,1)mydata4mydata3.contiguous().view(2,3)张量拼接操作1、torch.cat()函数可以将多个张量根据指定的维度拼接起来不改变维度数。2、torch.stack()函数会在一个新的维度上连接一系列张量这会增加一个新维度并且所有输入张量的形状必须完全相同。注意行列宽从外层到内层想象三维张量时建立空间感【行–左右列–上下宽–里外】自动微分模块1、PyTorch不支持向量张量对向量张量的求导,只支持标量张量对向量张量的求导x如果是张量,y必须是标量(一个值)才可以进行求导2、计算梯度: y.backward(), y是一个标量3、获取x点的梯度值: x.grad, 会累加上一次的梯度值4、梯度下降法公式: w w - r*grad (r是学习率, grad是梯度值)5、清空上一次的梯度值: x.grad.zero_()6、梯度计算不能将自动微分的张量转换成numpy数组会发生报错可以通过detach()方法实现案例-演示自动微分真实应用场景

相关文章:

一篇文章入门机器学习与PyTorch张量

机器学习 机器学习常见算法分类 机器学习方式:有监督学习,无监督学习,半监督学习,强化学习。机器学习建模流程 机器学习建模流程:获取数据、数据基本理、特征工程、机器学习(训练模型)、模型评估…...

零代码玩转mPLUG视觉问答:本地图片分析工具部署

零代码玩转mPLUG视觉问答:本地图片分析工具部署 1. 为什么选择本地化视觉问答工具 1.1 解决实际业务痛点的利器 在日常工作中,我们经常遇到需要从图片中提取信息的场景。传统的人工处理方式不仅效率低下,还容易出错。本工具基于mPLUG视觉问…...

Gstreamer中MP4/FLV推流RTP的编码陷阱:为何必须解码再编码?

1. 为什么MP4/FLV直接推流RTP会翻车? 第一次用Gstreamer推MP4文件时我也懵了——明明用.h264原始文件推流很顺利,换成MP4就死活播不出来。后来发现这其实是H.264的两种封装格式在作怪。就像你把同一本书分别装进精装盒和平装盒,虽然内容相同&…...

实测Qwen-Image-Edit-2511:换装效果惊艳,角色一致性太强了

实测Qwen-Image-Edit-2511:换装效果惊艳,角色一致性太强了 标签:Qwen-Image-Edit、AI换装、图像编辑、角色一致性、LoRA模型 1. 效果惊艳:换装前后对比展示 最近测试了Qwen-Image-Edit-2511这个AI图像编辑工具,最让…...

Win10下高效统计代码行数:CLOC工具一键安装与实战指南

1. 为什么开发者需要代码统计工具? 作为一个写过五年项目的程序员,我深刻体会到代码行数统计的重要性。刚开始接手新项目时,第一件事就是摸清代码规模——这就像装修房子前要先量尺寸一样基础。你可能遇到过这种情况:领导突然问&…...

初级运维-系统优化-7

Linux系统优化完全指南 本文档涵盖CentOS/RHEL 7.x系统的常用优化配置,适用于初级运维工程师 目录 编辑器技巧系统命令精讲系统信息查看时间同步管理安全服务配置YUM仓库优化网络与连接优化系统性能优化常用软件安装 一、编辑器技巧 1.1 Vim批量注释 操作步骤&am…...

企业级AI助手搭建:星图平台+Clawdbot,让Qwen3-VL:30B在飞书落地(下篇)

企业级AI助手搭建:星图平台Clawdbot,让Qwen3-VL:30B在飞书落地(下篇) 1. 飞书开放平台:创建企业自建应用 1.1 初始化应用 首先登录飞书开放平台开发者后台: 点击"创建企业自建应用"填写应用名…...

别再只用鼠标点!Blender 3.6.5效率翻倍的键盘流操作指南(拯救你的右手腕)

Blender 3.6.5键盘流操作指南:解放右手的高效建模艺术 刚接触Blender时,我们总是不自觉地依赖鼠标点击菜单和工具栏——这就像用勺子吃牛排,虽然也能完成,但效率低下且容易疲劳。真正的Blender高手往往双手不离键盘,仅…...

AI技术演进的两极:模型“校准”革命与生命“设计”时代

当多模态大模型学会“承认看不清”,而生物学AI开始“编写染色体”,我们见证的不仅是技术进步,更是AI发展路径的根本分岔。这两项突破,一项向内追求可靠,一项向外追求创造,共同定义了AI技术的下一个十年。引…...

“刺头”零件的驯服记:6pin折弯针如何从产线噩梦变成自动化香饽饽

老张在产线摸爬滚打八年,最近总爱拍着新来的小徒弟肩膀念叨:“这6pin折弯针啊,比我家那口子还难伺候!”可不是嘛,这零件长得跟个“钩子精”似的——六个引脚弯弯绕绕,往料斗里一倒,自己就能勾连…...

BH1750FVI光传感器驱动开发与I²C通信实战

1. BH1750FVI数字光强传感器技术解析与嵌入式驱动实践 1.1 传感器核心特性与工程定位 BH1750FVI是由ROHM Semiconductor推出的高精度、低功耗数字环境光传感器(Ambient Light Sensor, ALS),采用IC接口通信,具备16位分辨率&#x…...

解密Qwen3-VL三大黑科技:从MRoPE到DeepStack的进化之路

Qwen3-VL技术演进:从MRoPE到DeepStack的架构革命 1. 多模态模型的进化挑战 在人工智能领域,视觉语言模型(VLM)正经历着从简单感知到复杂推理的范式转变。传统模型往往面临三大核心挑战:长上下文理解能力的局限、跨模态对齐的不足,…...

superpowers

一:简介 Superpowers (https://github.com/obra/superpowers) 是一个为 AI 编程代理(如 Claude Code、Codex、OpenCode)打造的完整软件开发工作流系统。它的核心理念是:通过一套可组合的”技能”&#xff0…...

挖到宝了!这个报表工具让我告别加班,新手也能轻松做出专业报表✨

挖到宝了!这个报表工具让我告别加班,新手也能轻松做出专业报表✨ 家人们谁懂啊!以前做报表真的要被熬疯😭 要么是操作复杂,学习就得学好久,要么是做数据模型要写复杂的SQL,搭报表格式更是调半天…...

学习DHCP服务器

一、基本定义DHCP(Dynamic Host Configuration Protocol 动态主机配置协议)是用于自动为网络设备分配 IP 及网络参数的标准协议,最初定义于 RFC 1541,现已被 RFC 2131 取代。二、架构与端口采用 C/S 客户端 / 服务器 模型传输层协…...

盛思锐SEN66 - 关于环境监测类传感器的久远回忆(跑题)

先说点闲话 :)自己都没有注意到,其实接触盛思锐的产品,有好多年了.那时候,是制作一个给农作物植株测量温湿度的叉状设备,里面封装了大名鼎鼎的SHT20.因为整个电路板,被塑胶外壳完全封印,只留下雪亮的金属探针,所以我们亲切的称呼这个产品"小黑叉"(这充分的体现了我们…...

水墨江南模型C语言基础调用示例:轻量级嵌入式集成探索

水墨江南模型C语言基础调用示例:轻量级嵌入式集成探索 最近在捣鼓一些嵌入式设备上的AI应用,发现很多现成的框架对资源要求太高,动不动就要几百兆内存,这让很多单片机或者低功耗MCU望而却步。正好看到水墨江南这个模型&#xff0…...

SEER‘S EYE预言家之眼自动化测试:构建模型推理服务的CI流水线

SEERS EYE预言家之眼自动化测试:构建模型推理服务的CI流水线 最近在折腾一个叫“预言家之眼”的AI模型服务,它主要用在一些策略分析场景里。模型本身挺厉害,但每次更新版本或者调整代码,心里总有点打鼓:这次改动会不会…...

人脸识别OOD模型部署指南:基于Docker的容器化部署

人脸识别OOD模型部署指南:基于Docker的容器化部署 1. 引言 人脸识别系统在实际应用中经常面临低质量图像、噪声干扰以及分布外数据的挑战。传统方法往往难以有效处理这些异常情况,导致识别准确率下降。基于随机温度缩放技术的人脸识别OOD模型&#xff…...

探索考虑负荷类型与时间尺度的配电网故障恢复

考虑负荷类型和时间尺度的配电网故障恢复。 代码利用Matlab编程,基本复现考虑负荷类型和时间尺度的配电网故障恢复,分别在不同的故障时刻,不同的故障时段进行故障恢复,考虑到可控负荷削减。在电力系统领域,配电网故障恢…...

seo搜索引擎排名影响因素主要有

好的,以下是一些主要的SEO搜索引擎排名影响因素: 关键词密度和分布:关键词在网页中的使用频率和分布是影响搜索引擎排名的因素之一。关键词密度的合适范围是2%-8%,一般来说,保持在5%-7%的关键词密度是比较理想的。关键…...

OWL ADVENTURE与ComfyUI工作流结合:构建可视化AI视觉创作平台

OWL ADVENTURE与ComfyUI工作流结合:构建可视化AI视觉创作平台 最近在折腾AI图像生成时,我发现了一个挺有意思的组合:把OWL ADVENTURE这个能“看懂”图片的模型,塞进ComfyUI的可视化工作流里。这么一搞,整个创作流程就…...

CT1780 K型热电偶传感器:单总线高温测量方案

1. 项目概述DFRobot_CT1780 是一款基于单总线(1-Wire)协议的高精度K型热电偶温度传感器模块,专为工业级高温测量场景设计。该模块并非传统意义上的“数字温度传感器”,而是一个集成了冷端补偿(Cold Junction Compensat…...

Comsol锁相热成像模型:探索与实践

comsol锁相热成像模型在热成像技术领域,锁相热成像因其独特的优势受到广泛关注。而Comsol作为强大的多物理场仿真软件,为构建锁相热成像模型提供了有力工具。 锁相热成像原理简述 锁相热成像(Lock - in Thermography)通过对加热源…...

OpCore-Simplify:让黑苹果配置效率提升96%的自动化工具解决方案

OpCore-Simplify:让黑苹果配置效率提升96%的自动化工具解决方案 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify OpCore-Simplify是一款专为…...

金融文档的自动化分类平台

1. 政策背景数字经济发展浪潮下,金融行业数字化转型步入深水区,政策层面持续推动金融机构提升数字化服务能力、强化数据治理与风险管控,对金融业务全流程的效率与合规性提出更高要求。作为金融业务的核心信息载体,合同、流水、财报…...

Virtuino ESP库详解:ESP32/8266与手机App的轻量级寄存器通信协议

1. Virtuino ESP 库概述Virtuino ESP 是专为 ESP8266 和 ESP32 系列微控制器设计的轻量级通信协议栈,其核心目标是实现与 Virtuino 移动端应用(Android/iOS)之间的稳定、低开销双向数据交互。该库并非通用网络协议实现,而是面向嵌…...

别光顾着看小龙虾openclaw了,水产圈的“硬核”多组学研究已经卷到了这种程度...

最近,“OpenClaw”小龙虾意外走红,成为不少人热议的话题。热点之外,我们也想借这个颇具“科技感”的名字,把视线拉回到真正推动水产研究不断深入的核心力量——多组学技术。近年来,随着水产科研从表型观察逐步迈向机制…...

现有项目怎么平滑接入 AI Coding,又不破坏原有架构?

很多团队急着把 AI Coding 塞进旧项目,结果技术债雪崩。其实真正让企业头疼的,从来不是生成速度不够快,而是生成的代码根本没法维护。当 Oinone 这样的框架开始被讨论时,大家才意识到:没有工程纪律的加持,A…...

开箱即用!AI超清画质增强镜像部署与使用全流程

开箱即用!AI超清画质增强镜像部署与使用全流程 1. 技术背景与核心价值 在数字图像处理领域,分辨率提升一直是个经典难题。传统方法如双三次插值虽然简单快速,但放大后的图像往往模糊失真,细节丢失严重。AI超分辨率技术的出现彻底…...