yolov5 训练bdd100k踩坑记

两个都是好东西,不多说,说坑:

pycocotools装不上

到git上下载下来,进入setup.py,然后两行命令:

D:\pyenv\yolo5\Scripts\python.exe setup.py build_ext --inplace
D:\pyenv\yolo5\Scripts\python.exe setup.py build_ext install

数据格式转化

bdd的标注是这样的:在这里插入图片描述
yolo的是这样的:
在这里插入图片描述
奉上转化代码:

class Bdd2yolo:
    def __init__(self):
        self.bdd_lab = "../BDD100k/labels_bdd/train"
        self.yolo_lab = "../BDD100k/labels/train"
        os.makedirs(self.bdd_lab,exist_ok=True)
        os.makedirs(self.yolo_lab,exist_ok=True)
        self.used_names=["person", "rider", "car", "bus", "truck", "bike", "motor", "train"]
    
    @property
    def all_names(self):
        return ["person", "rider", "car", "bus", "truck", "bike", "motor", "traffic light", "traffic sign",
                "train"]
    
    def bdd2yolo5(self,categorys, file):
        strs = ""
        name=file.replace(".json","")
        readpath=f"{self.bdd_lab}/{file}"
        writepath=f"{self.yolo_lab}/{name}.txt"
        print (readpath,writepath)
        f = open(readpath)
        info = json.load(f)
        # print(len(info))
        # print(info["name"])
        write = open(writepath, 'w')
        for obj in info["frames"]:
            # print(obj["objects"])
            for objects in obj["objects"]:
                # print(objects)
                if objects["category"] in categorys:
                    dw = 1.0 / 1280
                    dh = 1.0 / 720
                    strs += str(categorys.index(objects["category"]))
                    strs += " "
                    strs += str(((objects["box2d"]["x1"] + objects["box2d"]["x2"]) / 2.0) * dw)[0:8]
                    strs += " "
                    strs += str(((objects["box2d"]["y1"] + objects["box2d"]["y2"]) / 2.0) * dh)[0:8]
                    strs += " "
                    strs += str(((objects["box2d"]["x2"] - objects["box2d"]["x1"])) * dw)[0:8]
                    strs += " "
                    strs += str(((objects["box2d"]["y2"] - objects["box2d"]["y1"])) * dh)[0:8]
                    strs += "\n"
            write.writelines(strs)
            write.close()
            print("%s has been dealt!" % info["name"])


if __name__ == "__main__":
    b=Bdd2yolo()
    fileList = os.listdir(b.bdd_lab)
    for file in fileList:
        # 自己需要从BDD数据集里提取的目标类别
        b.bdd2yolo5(b.used_names, file)

yaml文件改

这个网络上有,改两个data和models下的,其中models下主要是识别类别数量变了。

计算机性能

这个数据集比较大,市场爆出内存不足错误,一般的电脑,我看还是算了,动辄以周月计算。

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值