车辆重识别代码笔记12.17

1、argparse.ArgumentParser()用法解析

参考如下:argparse.ArgumentParser()用法解析 - 知乎 (zhihu.com)

2、CfgNode用法解析

参考如下:[Python] CfgNode-CSDN博客

3、 DataLoader

dataloader为数据提供一个迭代器,把数据分批输入网络的进行训练。

**工作机制:**在dataloader按照batch进行取数据的时候, 是取出大小等同于batch size的index列表,然后将列表列表中的index输入到dataset的getitem()函数中,取出该index对应的数据,最后, 对每个index对应的数据进行堆叠,就形成了一个batch的数据。

4、collate_fn函数

参考如下:python tips003 ------DataLoader的collate_fn参数使用详解 - 知乎 (zhihu.com)

5、sampler函数

sampler 是从dataset中取数据的策略,如果DataLoader不指定sampler的话,它就会按顺序依次喂入数据。

参考如下:Pytorch中的sampler_pytorch sampler-CSDN博客

6、enumerate()函数

enumerate() 是 Python 的一个内置函数,用于在 遍历可迭代对象(如列表、元组、字符串等) 时,同时获取元素及其对应的索引(位置)。

实际操作过程

  1. 遍历可迭代对象enumerate() 逐个取出元素。

  2. 自动生成索引 :默认从 0 开始,每次索引值加 1(或根据 start 参数设置)。

  3. 返回索引和值 :以 (index, value) 形式返回当前索引和值。

7、使用 iter()next() 的特点

  • 可以逐个获取元素

    • iter() 将可迭代对象转换为迭代器后,可以通过 next() 获取每个元素。

    • 每调用一次 next(),迭代器会返回下一个元素,直到没有元素时抛出 StopIteration 异常。

  • 迭代器是一次性的

    • 一旦迭代器遍历完所有元素,不能重置或重新遍历。如果你希望再次遍历,可以重新生成一个新的迭代器。

还可以通过自定义类来创建迭代器对象,只要该类实现了 __iter__()__next__() 方法:

  • __iter__() 返回迭代器对象本身(通常是类的实例)。

  • __next__() 返回下一个元素,直到抛出 StopIteration 异常表示结束。

相关推荐
寻星探路15 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
聆风吟º17 小时前
CANN runtime 全链路拆解:AI 异构计算运行时的任务管理与功能适配技术路径
人工智能·深度学习·神经网络·cann
User_芊芊君子17 小时前
CANN大模型推理加速引擎ascend-transformer-boost深度解析:毫秒级响应的Transformer优化方案
人工智能·深度学习·transformer
ValhallaCoder17 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
wdfk_prog17 小时前
[Linux]学习笔记系列 -- [drivers][input]input
linux·笔记·学习
ouliten18 小时前
cuda编程笔记(36)-- 应用Tensor Core加速矩阵乘法
笔记·cuda
智驱力人工智能18 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
人工不智能57718 小时前
拆解 BERT:Output 中的 Hidden States 到底藏了什么秘密?
人工智能·深度学习·bert
猫头虎18 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
h64648564h18 小时前
CANN 性能剖析与调优全指南:从 Profiling 到 Kernel 级优化
人工智能·深度学习