ReID实战推荐——罗浩——常用的骨干网

2024-01-05 06:50

本文主要是介绍ReID实战推荐——罗浩——常用的骨干网,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

课程中常用的代码句

1. pid, _ = map(int, pattern.search(img_path).groups())#当后面的语句返回多个东西时,我只想要一个值,就可以用‘_’来不取
2. from IPython import embed#加断点,查询网络的进展情况embed() #可同时加多个embed,用exit退出到下一个embed 
3.in_size=x.size(0)#x会返回(b,c,w,h)这里返回第一个维度batch的大小
4.torch.cat(outputs,dim=1) #输出size[b,c,w,h],所以dim=1沿着第一个维度C拼接
5.input=torch.Tensor(input).view(1,1,5,5)#B*C*W*H压缩成4维f = x.view(x.size(0), -1)#将x变成2维,第一维大小为x.size(0)=batch,第二维(-1)自动压缩
6.x.shape#查看tensor的大小
7.conv_layer.weight.data = kernel.data #直接对某个层.weight.data赋值
8.self.base = nn.Sequential(*list(resnet50.children())[:-2])#不要restnet50的最后两行,自己添加下面两行
#用nn.Sequential来包裹model的两层参数,每次更新只更新这两层# optimizer = init_optim(args.optim, nn.Sequential([model.conv1,model.conv2])
9.调试代码时,可自己生成数据
只有torch.Tensor,torch.randn用来生成数据,torch.tensor(labels)是转化为tensor数据格式
imgs=torch.Tensor(32,3,256,128)#全0矩阵
x = torch.randn(32,2048)#均值为0的矩阵
labels=torch.Tensor(labels)#生成数据带点
labels=torch.tensor(labels)#生成数据不带点
10.assert len(x.size()) == 3#判断上面的输入是不是3维
11.调用要从最初的文件夹开始:from luohao_person_reid.AlignedReID_master.aligned.local_dist import *
12. # 保存网络训练最好的权重best_model_wts = copy.deepcopy(model.state_dict())best_acc = 0.0# 保存测试阶段,准确率最高的模型if phase == 'val' and epoch_acc > best_acc:best_acc = epoch_accbest_model_wts = copy.deepcopy(model.state_dict())model.load_state_dict(best_model_wts)# 最后网络导入最好的网络权重13.[model.state_dict()和model.parameters()两个方法的差异比较](https://blog.csdn.net/qq_33590958/article/details/103544175?biz_id=102&utm_term=model.state_dict%28%29%E5%92%8Ccnn.paramet&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-0-103544175&spm=1018.2118.3001.4187)14. a=torch.Size([32, 3, 128, 128]),a[0]=torch.Size([3, 128, 128])取出第一张图片的信息15. 两种save图片方式对比:数据类型不同,通道不同法1:image_PIL = transforms.ToPILImage()(image_tensor[0])#取出第一张图片image_tensor[0].shape=torch.Size([3, 128, 128]) image_PIL.save(os.path.join(config.result_path, 'img%d.png' % (i + 1)))type(image_PIL)=PIL.Image.Image   <PIL.Image.Image image mode=RGB size=128x128 at 0x205F779ACF8>2:cv2.imwrite(os.path.join(config.result_path, 'cam%d.png' % (i + 1)), result)#(128, 128, 3),result=numpy.ndarray
a=tensor a.numpy()变成numpy

罗浩github---------ReID课程教学

目录

  • 1. Reid简介
    • 难样本提取
    • rank+map计算
    • center loss
  • 2. 表征学习
  • 3. 度量学习
  • 4. 全局特征+局部特征
    • 1. 水平切块算法
      • Aligned ReID
      • PCB
      • ICNN
      • SCP NET
    • 2. 姿态信息
      • PIE
      • SPINDLE NET
      • PDC
      • GLAD
      • PABP
    • 3. 分割信息
    • 4. 网格特征
  • 5. 序列重识别
  • 6. 基于GAN
      • GAN+LSRO
      • Cycle Gan
      • PTGAN
      • PNGAN(生成8姿态)
  • 7. Ptorch应用
  • 8. 工程trick

1. Reid简介

在这里插入图片描述
在这里插入图片描述
数据集

一次投放5个样本,一个样本只检测出一次。

在这里插入图片描述
rank1+rank2+rank3+…=CMC
在这里插入图片描述
在这里插入图片描述

难样本提取

在这里插入图片描述

rank+map计算

在这里插入图片描述

center loss

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

2. 表征学习

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3. 度量学习

度量学习不需要表征学习的FC(用来分类),直接对比特征图就行
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
python实现距离矩阵,用于难样本的选择
在这里插入图片描述
在这里插入图片描述

import torch
inputs=torch.tensor([[1.,1.,2.],#这里注意tensor数据类型数字要加点,否则后面运算会出现错误RuntimeError: log_vml_cpu not implemented for 'Long'[1,0,1],[1,2,1],[1,3,2]])
dist = torch.pow(inputs, 2).sum(dim=1, keepdim=True).expand(4, 4)
dist = dist + dist.t()
dist.addmm_(1, -2, inputs, inputs.t())dist=dist.clamp(min=1e-12).sqrt()#裁剪防止有0存在,梯度会存在问题
print(dist)

在这里插入图片描述

4. 全局特征+局部特征

  1. 全局
    在这里插入图片描述
    在这里插入图片描述
  2. 局部
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

1. 水平切块算法

在这里插入图片描述

Aligned ReID

这种情况更适合真实的环境(不对齐现象),而用的数据集是经过手动处理过的。
在这里插入图片描述
在这里插入图片描述
实现
在这里插入图片描述
我认为DMLI只用用于解释才产生的这个名词,代码直接将32x128x8变成32x8x128用于local distance训练,并未体现DMLI
在这里插入图片描述
在这里插入图片描述

PCB

Aligned和PCB都是经过水平池化生成g
不同之处Aligned用vector_h 生成距离矩阵,用于hard triple loss
PCB将vector_h 的多个分支送到FC,用于ID交叉熵loss
在这里插入图片描述
PCB_github
在这里插入图片描述

ICNN

在这里插入图片描述

SCP NET

在这里插入图片描述

2. 姿态信息

在这里插入图片描述

PIE

在这里插入图片描述

SPINDLE NET

在这里插入图片描述

PDC

在这里插入图片描述

GLAD

在这里插入图片描述

PABP

前面几种是part级别,PABP是像素级别
在这里插入图片描述

3. 分割信息

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
SPReID
在这里插入图片描述

4. 网格特征

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5. 序列重识别

在这里插入图片描述
在这里插入图片描述

提取序列特征的方法
1.
在这里插入图片描述
2.
在这里插入图片描述

6. 基于GAN

在这里插入图片描述
不同GAN解决不同问题
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
应用于ReID

GAN+LSRO

在这里插入图片描述

Cycle Gan

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

PTGAN

在这里插入图片描述
在这里插入图片描述

PNGAN(生成8姿态)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

7. Ptorch应用

tensorflow静态图,只能看到是结点,但是不知道结点里是啥
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

8. 工程trick

在这里插入图片描述

这篇关于ReID实战推荐——罗浩——常用的骨干网的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/572017

相关文章

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

Java 枚举的常用技巧汇总

《Java枚举的常用技巧汇总》在Java中,枚举类型是一种特殊的数据类型,允许定义一组固定的常量,默认情况下,toString方法返回枚举常量的名称,本文提供了一个完整的代码示例,展示了如何在Jav... 目录一、枚举的基本概念1. 什么是枚举?2. 基本枚举示例3. 枚举的优势二、枚举的高级用法1. 枚举

Spring Boot 中整合 MyBatis-Plus详细步骤(最新推荐)

《SpringBoot中整合MyBatis-Plus详细步骤(最新推荐)》本文详细介绍了如何在SpringBoot项目中整合MyBatis-Plus,包括整合步骤、基本CRUD操作、分页查询、批... 目录一、整合步骤1. 创建 Spring Boot 项目2. 配置项目依赖3. 配置数据源4. 创建实体类

IDEA常用插件之代码扫描SonarLint详解

《IDEA常用插件之代码扫描SonarLint详解》SonarLint是一款用于代码扫描的插件,可以帮助查找隐藏的bug,下载并安装插件后,右键点击项目并选择“Analyze”、“Analyzewit... 目录SonajavascriptrLint 查找隐藏的bug下载安装插件扫描代码查看结果总结Sona

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系