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

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Java常用注解扩展对比举例详解

《Java常用注解扩展对比举例详解》:本文主要介绍Java常用注解扩展对比的相关资料,提供了丰富的代码示例,并总结了最佳实践建议,帮助开发者更好地理解和应用这些注解,需要的朋友可以参考下... 目录一、@Controller 与 @RestController 对比二、使用 @Data 与 不使用 @Dat

Mysql中深分页的五种常用方法整理

《Mysql中深分页的五种常用方法整理》在数据量非常大的情况下,深分页查询则变得很常见,这篇文章为大家整理了5个常用的方法,文中的示例代码讲解详细,大家可以根据自己的需求进行选择... 目录方案一:延迟关联 (Deferred Join)方案二:有序唯一键分页 (Cursor-based Paginatio

Python实现常用文本内容提取

《Python实现常用文本内容提取》在日常工作和学习中,我们经常需要从PDF、Word文档中提取文本,本文将介绍如何使用Python编写一个文本内容提取工具,有需要的小伙伴可以参考下... 目录一、引言二、文本内容提取的原理三、文本内容提取的设计四、文本内容提取的实现五、完整代码示例一、引言在日常工作和学

Python实战之屏幕录制功能的实现

《Python实战之屏幕录制功能的实现》屏幕录制,即屏幕捕获,是指将计算机屏幕上的活动记录下来,生成视频文件,本文主要为大家介绍了如何使用Python实现这一功能,希望对大家有所帮助... 目录屏幕录制原理图像捕获音频捕获编码压缩输出保存完整的屏幕录制工具高级功能实时预览增加水印多平台支持屏幕录制原理屏幕

Redis中的常用的五种数据类型详解

《Redis中的常用的五种数据类型详解》:本文主要介绍Redis中的常用的五种数据类型详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Redis常用的五种数据类型一、字符串(String)简介常用命令应用场景二、哈希(Hash)简介常用命令应用场景三、列表(L

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES