车辆重识别代码笔记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 异常表示结束。

相关推荐
yyyyy_abc2 小时前
ceph学习笔记
笔记·ceph·学习
晓梦林3 小时前
ximai靶场学习笔记
android·笔记·学习
IT19953 小时前
Dify笔记-创建自定义工具连接到自建的OpenAPI Schema服务
笔记
2301_803934613 小时前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
WL_Aurora3 小时前
Python爬虫实战(六):新发地蔬菜价格数据采集.
爬虫·python
盲敲代码的阿豪3 小时前
Python 入门基础教程(爬虫前置版)
开发语言·爬虫·python
一口吃俩胖子4 小时前
【脉宽调制DCDC功率变换学习笔记021】时域性能准则
笔记·学习
starvapour4 小时前
SSH笔记
笔记·ssh
明月醉窗台4 小时前
深度学习(17)YOLO训练中的超参数详解
人工智能·深度学习·yolo
weixin199701080164 小时前
[特殊字符] 智能数据采集:数字化转型的“数据石油勘探队”(附Python实战源码)
开发语言·python