pytorch 合并与分割

本文详细介绍了PyTorch中张量的扩展、堆叠、拆分和按数量拆分等操作,通过实例展示了如何使用cat、stack、split和chunk函数对张量进行高效处理。
部署运行你感兴趣的模型镜像

cat 在原本的维度上扩展自己

import torch
import numpy as np
a = torch.rand(4,3,8)
b = torch.rand(5,3,8)
# dim 代表维度
print("合并第一维度后的 shape: {}".format(torch.cat([a,b],dim=0).shape))
合并第一维度后的 shape: torch.Size([9, 3, 8])

stack 会创建一个新的维度,要求合并的张量大小需要一致

import torch
import numpy as np
a = torch.rand(4,3)
b = torch.rand(4,3)
# dim 代表维度
print("合并后在最前面插入一个维度 shape: {}".format(torch.stack([a,b],dim=0).shape))
print("合并后在最后面插入一个维度 shape: {}".format(torch.stack([a,b],dim=-1).shape))
合并后在最前面插入一个维度 shape: torch.Size([2, 4, 3])
合并后在最后面插入一个维度 shape: torch.Size([4, 3, 2])

split

import torch
import numpy as np
a = torch.rand(4,3,8)
#按不同组合大小比例拆分 为 第一维度 4 拆分为 1 和 3
b , d = a.split([1,3],dim=0)
print(b.shape,d.shape)
#将第一维度 按单位数量为2 进行拆分
b , d = a.split(2,dim=0)
print(b.shape,d.shape)
torch.Size([1, 3, 8]) torch.Size([3, 3, 8])
torch.Size([2, 3, 8]) torch.Size([2, 3, 8])

chunk 按数量拆分

import torch
import numpy as np
a = torch.rand(4,3,8)

#将第一维度分成4份
b , d , e, f = a.chunk(4,dim=0)
print(b.shape,d.shape,e.shape,d.shape)
torch.Size([1, 3, 8]) torch.Size([1, 3, 8]) torch.Size([1, 3, 8]) torch.Size([1, 3, 8])

您可能感兴趣的与本文相关的镜像

PyTorch 2.5

PyTorch 2.5

PyTorch
Cuda

PyTorch 是一个开源的 Python 机器学习库,基于 Torch 库,底层由 C++ 实现,应用于人工智能领域,如计算机视觉和自然语言处理

### 实现图像分割原始图像叠加 在 PyTorch实现图像分割并把分割结果原始图像叠加显示涉及多个步骤,包括读取图像、执行分割操作以及将分割掩膜应用到原始图像上。 #### 准备开发环境 为了确保所有必要的库都已安装并且可以正常导入,建议先设置好开发环境。这通常涉及到一些基础包的引入: ```python import os import torch from torchvision import transforms from PIL import Image import numpy as np import matplotlib.pyplot as plt ``` #### 加载待分割的图片 加载一张用于演示目的的图片,并对其进行预处理以便于后续的操作。这里假设已经有一个名为 `read_image` 的函数来完成这项任务[^1]。 ```python img_path = "/content/semantic_example_highway.jpg" img_original = read_image(img_path) # 将图像转换成适合模型输入的形式 transform = transforms.Compose([ transforms.ToTensor(), ]) img_tensor = transform(Image.open(img_path)) batch_img = torch.unsqueeze(img_tensor, 0).float() ``` #### 执行图像分割 利用训练好的神经网络模型来进行预测,得到对应的类别标签矩阵作为分割的结果。此处简化表示为调用某个预先定义好的模型实例 `model` 进行推理的过程。 ```python with torch.no_grad(): model.eval() # 设置模型评估模式 output = model(batch_img) segmentation_mask = torch.argmax(output.squeeze(), dim=0).numpy().astype(np.uint8) ``` #### 创建颜色映射表 对于不同的对象类别赋予特定的颜色值,从而使得最终可视化效果更加直观清晰。例如,如果目标是标记车辆,则可以选择蓝色代表此类别[^2]。 ```python color_map = {0: [0, 0, 0], # 背景设为黑色 1: [0, 0, 255]} # 类别1(比如汽车)设为红色 mask_rgb = np.zeros((segmentation_mask.shape[0], segmentation_mask.shape[1], 3), dtype=np.uint8) for key in color_map.keys(): mask_rgb[segmentation_mask == key] = color_map[key] ``` #### 合并分割结果原图 通过调整透明度参数 alpha 来控制两个图像层之间的混合程度,进而达到视觉上的融合效果。 ```python alpha = 0.6 # 控制透明度的比例因子 overlayed_img = cv2.addWeighted(mask_rgb, alpha, np.array(img_original.convert('RGB')), 1-alpha, 0) plt.imshow(overlayed_img) plt.axis('off') plt.show() ``` 上述过程展示了如何基于 PyTorch 构建一个简单的图像分割流程,并实现了将分割后的区域以不同色彩覆盖回原始图像之上进行展示的功能。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值