pytorch - view函数 实例详解

pytorch - view函数

简而言之,view()函数 改变 对张量的观察角度
即可以理解为 改变维度

实例:
例如 y=torch.randn(5,3)
y是一个5×3的tensor

①y.view(15,1):把 5×3的tensor → 15×1的tensor

②还有一个小细节:-1的用法
y是一个5×3的tensor
y.view(-1,5)
-1可以理解为未知数,表示这个维度不用计算,系统自己算出来=3
因为已知另外一个维度是5,5×3 / 5 = 3
只是直接写-1是不用人为计算罢了

代码如下:

# 创建一个tensor
import torch
y = torch.rand(5,3) #使用随机数初始化“矩阵”
print(y)

# y的输出
tensor([[0.0960, 0.2431, 0.5571],
        [0.1512, 0.8189, 0.7945],
        [0.9520, 0.0782, 0.6903],
        [0.7898, 0.0922, 0.3124],
        [0.7378, 0.7426, 0.2018]])
# 使用view函数
y.view(15,1)

# 输出为:5×3 → 15×1
tensor([[0.0960],
        [0.2431],
        [0.5571],
        [0.1512],
        [0.8189],
        [0.7945],
        [0.9520],
        [0.0782],
        [0.6903],
        [0.7898],
        [0.0922],
        [0.3124],
        [0.7378],
        [0.7426],
        [0.2018]])
#使用“自动计算的view函数”
y.view(-1,5)

#输出为:5×3 → 3×5
tensor([[0.0960, 0.2431, 0.5571, 0.1512, 0.8189],
        [0.7945, 0.9520, 0.0782, 0.6903, 0.7898],
        [0.0922, 0.3124, 0.7378, 0.7426, 0.2018]])
#另外一个实例,与上面的一个例子无关

x = torch.randn(4, 4)
y = x.view(16)
z = x.view(-1, 8)  #  size -1 从其他维度推断
print(x.size(), y.size(), z.size())

#此例输出为:
torch.Size([4, 4]) torch.Size([16]) torch.Size([2, 8])
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于 Pytorch-RetinaFace 的代码讲解,我可以给您提供以下信息: 1. RetinaFace 模型介绍 RetinaFace 是一个用于人脸检测和人脸识别的深度学习模型,其核心思想是在多个尺度下进行特征提取,并利用类似于 Anchor 的方式进行边框预测。RetinaFace 模型的核心网络结构为 ResNet-50,通过 ResNet-50 提取特征,再分别在不同的特征图上进行预测,从而提高检测的准确率和速度。 2. Pytorch-RetinaFace 代码结构 Pytorch-RetinaFace 的代码结构主要包含以下几个文件: - data/ 目录:包含了数据集相关的代码和数据集文件; - models/ 目录:包含了 RetinaFace 模型的代码和模型文件; - layers/ 目录:包含了 RetinaFace 模型中用到的自定义层代码; - utils/ 目录:包含了一些工具类和函数- train.py:训练脚本; - test.py:测试脚本; - demo.py:演示脚本。 3. RetinaFace 模型训练 RetinaFace 模型的训练主要包含以下几个步骤: - 数据集准备:将数据集按照指定格式进行划分和预处理; - 模型构建:使用 Pytorch 搭建 RetinaFace 模型,并定义损失函数和优化器; - 模型训练:使用训练集对模型进行训练,并在验证集上进行验证和调参; - 模型保存:将训练好的模型保存到指定的路径。 4. RetinaFace 模型测试 RetinaFace 模型的测试主要包含以下几个步骤: - 加载模型:使用 Pytorch 加载训练好的模型; - 图像预处理:将待检测的图像进行预处理,包括大小调整和归一化等; - 特征提取:使用 ResNet-50 提取图像的特征; - 预测边框:在不同的特征图上进行边框预测,并进行 NMS 处理; - 绘制结果:将预测出的边框和置信度绘制在原图上。 以上就是关于 Pytorch-RetinaFace 代码的讲解,希望能够对您有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值