您当前的位置: 首页 >  pytorch
  • 1浏览

    0关注

    417博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

行人重识别02-07:fast-reid(BoT)-pytorch编程规范(fast-reid为例)4-迭代器构建,数据加载-2

江南才尽,年少无知! 发布时间:2020-08-18 09:36:14 ,浏览量:1

以下链接是个人关于fast-reid(BoT行人重识别) 所有见解,如有错误欢迎大家指出,我会第一时间纠正。有兴趣的朋友可以加微信:17575010159 相互讨论技术。若是帮助到了你什么,一定要记得点赞!因为这是对我最大的鼓励。 文末附带 \color{blue}{文末附带} 文末附带 公众号 − \color{blue}{公众号 -} 公众号− 海量资源。 \color{blue}{ 海量资源}。 海量资源。

行人重识别02-00:fast-reid(BoT)-目录-史上最新无死角讲解

极度推荐的商业级项目: \color{red}{极度推荐的商业级项目:} 极度推荐的商业级项目:这是本人落地的行为分析项目,主要包含(1.行人检测,2.行人追踪,3.行为识别三大模块):行为分析(商用级别)00-目录-史上最新无死角讲解

前言

在上篇博客中,我们留下了一个疑问,那就是在fastreid\data\build.py文件

def build_reid_train_loader(cfg):
	......
    for d in cfg.DATASETS.NAMES:
        # 根据数据集名称,创建对应数据集迭代的类,本人调试为类 fastreid.data.datasets.market1501.Market1501对象
        dataset = DATASET_REGISTRY.get(d)(root=_root, combineall=cfg.DATASETS.COMBINEALL)
        train_items.extend(dataset.train)

中的 dataset.train 是如何获得的。在这篇博客中,我会为打大家解答这个疑问。

Market1501

首先,我们已经知道 dataset 为 fastreid.data.datasets.market1501.Market150 创建的对象,那么我们就找到这个Market150类:

@DATASET_REGISTRY.register()
class Market1501(ImageDataset):
    """Market1501.

    Reference:
        Zheng et al. Scalable Person Re-identification: A Benchmark. ICCV 2015.

    URL: ``_

    Dataset statistics:
        - identities: 1501 (+1 for background).
        - images: 12936 (train) + 3368 (query) + 15913 (gallery).
    """
    _junk_pids = [0, -1]
    dataset_dir = '' # 数据集目录,默认为空
    dataset_url = 'http://188.138.127.15:81/Datasets/Market-1501-v15.09.15.zip' # 数据集现在地址
    dataset_name = "market1501" # 数据集名称

    def __init__(self, root='datasets', market1501_500k=False, **kwargs):
        # self.root = osp.abspath(osp.expanduser(root))
        # 数据集根目录
        self.root = root
        # 拼接数据集路径
        self.dataset_dir = osp.join(self.root, self.dataset_dir)

        # allow alternative directory structure  # 允许替换目录结构
        self.data_dir = self.dataset_dir

        # 获得数据集目录
        data_dir = osp.join(self.data_dir, 'Market-1501-v15.09.15')
        # 判断是否为一个目录。如果是则复制给self.data_dir
        if osp.isdir(data_dir):
            self.data_dir = data_dir
        # 否则给出警告
        else:
            warnings.warn('The current data structure is deprecated. Please '
                          'put data folders such as "bounding_box_train" under '
                          '"Market-1501-v15.09.15".')

        # 训练数据的目录,“bounding_box_train”——用于训练集的 751 人,包含 12,936 张图像
        self.train_dir = osp.join(self.data_dir, 'bounding_box_train')

        # 为 750 人在每个摄像头中随机选择一张图像作为query,因此一个人的query最多有 6 个,共有 3,368 张图像
        self.query_dir = osp.join(self.data_dir, 'query')

        #“bounding_box_test”——用于测试集的 750 人,包含 19,732 张图像,前缀为 0000 表示在提取这 750 人的过程中DPM检测错的图
        # (可能与query是同一个人),-1 表示检测出来其他人的图(不在这 750 人中)
        self.gallery_dir = osp.join(self.data_dir, 'bounding_box_test')

        # 额外画廊的数据,可以理解为为bounding_box_test添加额外的数据
        self.extra_gallery_dir = osp.join(self.data_dir, 'images')

        # 设置self.market1501_500k标志,设置了该标志位,这表示为 self.gallery_dir 添加额外的 self.extra_gallery_dir数据
        self.market1501_500k = market1501_500k

        # 需要的文件目录
        required_files = [
            self.data_dir,
            self.train_dir,
            self.query_dir,
            self.gallery_dir,
        ]
        # 如果设置了 market1501_500k=Ture,则添加 extra_gallery_dir 到 required_files 之中
        if self.market1501_500k:
            required_files.append(self.extra_gallery_dir)

        # 在运行之前对 required_files 进行检查
        self.check_before_run(required_files)

        # 对训练目录进行处理
        train = self.process_dir(self.train_dir)
        # 对 query 目录数据进行处理
        query = self.process_dir(self.query_dir, is_train=False)
        # 对 gallery 目录进行处理
        gallery = self.process_dir(self.gallery_dir, is_train=False)

        # 如果设置market1501_500k=Ture,则对extra_gallery_dir进行处理,并且添加到gallery之中
        if self.market1501_500k:
            gallery += self.process_dir(self.extra_gallery_dir, is_train=False)

        # 调用父类的初始化函数
        super(Market1501, self).__init__(train, query, gallery, **kwargs)

    def process_dir(self, dir_path, is_train=True):
        # 获得目录下的所有jpg图片名称
        img_paths = glob.glob(osp.join(dir_path, '*.jpg'))
        # 用于正则表达式
        pattern = re.compile(r'([-\d]+)_c(\d)')

        data = []
        # 对每一张图片进行处理
        # 以 0001_c1s1_000151_01.jpg 为例
        # 1) 0001 表示每个人的标签编号,从0001到1501;
        # 2) c1 表示第一个摄像头(camera1),共有6个摄像头;
        # 3) s1 表示第一个录像片段(sequece1),每个摄像机都有数个录像段;
        # 4) 000151 表示 c1s1 的第000151帧图片,视频帧率25fps;
        # 5) 01 表示 c1s1_001051 这一帧上的第1个检测框,由于采用DPM检测器,对于每一帧上的行人可能会框出好几个bbox。00 表示手工标注框
        for img_path in img_paths:
            # 获得图片对应的pid(身份ID)以及摄像头编号
            pid, camid = map(int, pattern.search(img_path).groups())
            # -1表示身份不在1051中,则忽略不进行处理
            if pid == -1:
                continue  # junk images are just ignored
            # 检测id是否正确,不正确则报错
            assert 0             
关注
打赏
1592542134
查看更多评论
0.0384s