python交通信号灯检测yolov5交通信号灯识别,红绿灯检测,左转右转识别

2023-11-02

python交通信号灯检测yolov5交通信号灯识别,红绿灯检测,左转右转识别

交通信号灯的检测与识别是无人驾驶与辅助驾驶必不可少的一部分,其识别精度直接关乎智能驾驶的安全。一般而言,在实际的道路场景中采集的交通信号灯图像具有复杂的背景,且感兴趣的信号灯区域只占很少的一部分,如下图所示。针对这些难点,国内外的众多研究者提出了相应的解决方案。

import argparse

from models import *  # set ONNX_EXPORT in models.py
from utils.datasets import *
from utils.utils import *


def detect(save_img=False):
    imgsz = (320, 192) if ONNX_EXPORT else opt.img_size  # (320, 192) or (416, 256) or (608, 352) for (height, width)
    out, source, weights, half, view_img, save_txt = opt.output, opt.source, opt.weights, opt.half, opt.view_img, opt.save_txt
    webcam = source == '0' or source.startswith('rtsp') or source.startswith('http') or source.endswith('.txt')

    # Initialize
    device = torch_utils.select_device(device='cpu' if ONNX_EXPORT else opt.device)
    # if os.path.exists(out):
    #     shutil.rmtree(out)  # delete output folder
    os.makedirs(out, exist_ok=True)  # make new output folder

    # Initialize model
    model = Darknet(opt.cfg, imgsz)

    # Load weights
    attempt_download(weights)
    if weights.endswith('.pt'):  # pytorch format
        model.load_state_dict(torch.load(weights, map_location=device)['model'])
    else:  # darknet format
        load_darknet_weights(model, weights)

    # Second-stage classifier
    classify = False
    if classify:
        modelc = torch_utils.load_classifier(name='resnet101', n=2)  # initialize
        modelc.load_state_dict(torch.load('weights/resnet101.pt', map_location=device)['model'])  # load weights
        modelc.to(device).eval()

    # Eval mode
    model.to(device).eval()

    # Fuse Conv2d + BatchNorm2d layers
    # model.fuse()

    # Export mode
    if ONNX_EXPORT:
        model.fuse()
        img = torch.zeros((1, 3) + imgsz)  # (1, 3, 320, 192)
        f = opt.weights.replace(opt.weights.split('.')[-1], 'onnx')  # *.onnx filename
        torch.onnx.export(model, img, f, verbose=False, opset_version=11,
                          input_names=['images'], output_names=['classes', 'boxes'])

        # Validate exported model
        import onnx
        model = onnx.load(f)  # Load the ONNX model
        onnx.checker.check_model(model)  # Check that the IR is well formed
        print(onnx.helper.printable_graph(model.graph))  # Print a human readable representation of the graph
        return

    # Half precision
    half = half and device.type != 'cpu'  # half precision only supported on CUDA
    if half:
        model.half()

    # Set Dataloader
    vid_path, vid_writer = None, None
    if webcam:
        view_img = True
        torch.backends.cudnn.benchmark = True  # set True to speed up constant image size inference
        dataset = LoadStreams(source, img_size=imgsz)
    else:
        save_img = True
        dataset = LoadImages(source, img_size=imgsz)

    # Get names and colors
    names = load_classes(opt.names)
    # colors = [[random.randint(0, 255) for _ in range(3)] for _ in range(len(names))]
    colors = [(0, 255, 0), (0, 0, 255), (0, 0, 155), (0, 200, 200), (29, 118, 255), (0 , 118, 255)]

    # Run inference
    t0 = time.time()
    img = torch.zeros((1, 3, imgsz, imgsz), device=device)  # init img
    _ = model(img.half() if half else img.float()) if device.type != 'cpu' else None  # run once
    for path, img, im0s, vid_cap, frame, nframes in dataset:
        img = torch.from_numpy(img).to(device)
        img = img.half() if half else img.float()  # uint8 to fp16/32
        img /= 255.0  # 0 - 255 to 0.0 - 1.0
        if img.ndimension() == 3:
            img = img.unsqueeze(0)

        # Inference
        t1 = torch_utils.time_synchronized()
        pred = model(img, augment=opt.augment)[0]
        t2 = torch_utils.time_synchronized()

        # to float
        if half:
            pred = pred.float()

        # Apply NMS
        pred = non_max_suppression(pred, opt.conf_thres, opt.iou_thres,
                                   multi_label=False, classes=opt.classes, agnostic=opt.agnostic_nms)

        # Apply Classifier
        if classify:
            pred = apply_classifier(pred, modelc, img, im0s)

        # Process detections
        for i, det in enumerate(pred):  # detections for image i
            if webcam:  # batch_size >= 1
                p, s, im0 = path[i], '%g: ' % i, im0s[i].copy()
            else:
                p, s, im0 = path, '', im0s

            save_path = str(Path(out) / Path(p).name)
            print(save_path)
            s += '%gx%g ' % img.shape[2:]  # print string
            gn = torch.tensor(im0.shape)[[1, 0, 1, 0]]  #  normalization gain whwh
            if det is not None and len(det):
                # Rescale boxes from imgsz to im0 size
                det[:, :4] = scale_coords(img.shape[2:], det[:, :4], im0.shape).round()

                # Print results
                for c in det[:, -1].unique():
                    n = (det[:, -1] == c).sum()  # detections per class
                    s += '%g %ss, ' % (n, names[int(c)])  # add to string

                # Write results
                for *xyxy, conf, cls in det:
                    if save_txt:  # Write to file
                        xywh = (xyxy2xywh(torch.tensor(xyxy).view(1, 4)) / gn).view(-1).tolist()  # normalized xywh
                        with open(save_path[:save_path.rfind('.')] + '.txt', 'a') as file:
                            file.write(('%g ' * 5 + '\n') % (cls, *xywh))  # label format

                    if save_img or view_img:  # Add bbox to image
                        # label = '%s %.2f' % (names[int(cls)], conf)
                        label = '%s' % (names[int(cls)])
                        plot_one_box(xyxy, im0, label=label, color=colors[int(cls)])

            # Print time (inference + NMS)
            print('%sDone. (%.3fs)' % (s, t2 - t1))

python交通信号灯检测yolov5交通信号灯识别,红绿灯检测,左转右转识别

python交通信号灯检测yolov5交通信号灯识别,红绿灯检测,左转右转识别-深度学习文档类资源-CSDN下载

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

python交通信号灯检测yolov5交通信号灯识别,红绿灯检测,左转右转识别 的相关文章

  • Python:在列表理解本身中引用列表理解?

    这个想法刚刚出现在我的脑海中 假设您出于某种原因想要通过 Python 中的列表理解来获取列表的唯一元素 i if i in created comprehension else 0 for i in 1 2 1 2 3 1 2 0 0 3
  • 为 Anaconda Python 安装 psycopg2

    我有 Anaconda Python 3 4 但是每当我运行旧代码时 我都会通过输入 source activate python2 切换到 Anaconda Python 2 7 我的问题是我为 Anaconda Python 3 4 安
  • 使用 on_bad_lines 将 pandas.read_csv 中的无效行写入文件

    我有一个 CSV 文件 我正在使用 Python 来解析该文件 我发现文件中的某些行具有不同的列数 001 Snow Jon 19801201 002 Crom Jake 19920103 003 Wise Frank 19880303 l
  • 是否可以忽略一行的pyright检查?

    我需要忽略一行的pyright 检查 有什么特别的评论吗 def create slog group SLogGroup data Optional dict None SLog insert one SLog group group da
  • 测试 python Counter 是否包含在另一个 Counter 中

    如何测试是否是pythonCounter https docs python org 2 library collections html collections Counter is 包含在另一个中使用以下定义 柜台a包含在计数器中b当且
  • Spark KMeans 无法处理大数据吗?

    KMeans 有几个参数training http spark apache org docs latest api python pyspark mllib html highlight kmeans pyspark mllib clus
  • 使用 Tkinter 显示 numpy 数组中的图像

    我对 Python 缺乏经验 第一次使用 Tkinter 制作一个 UI 显示我的数字分类程序与 mnist 数据集的结果 当图像来自 numpy 数组而不是我的 PC 上的文件路径时 我有一个关于在 Tkinter 中显示图像的问题 我为
  • OpenCV 无法从 MacBook Pro iSight 捕获

    几天后 我无法再从 opencv 应用程序内部打开我的 iSight 相机 cap cv2 VideoCapture 0 返回 并且cap isOpened 回报true 然而 cap grab 刚刚返回false 有任何想法吗 示例代码
  • 如何加速Python中的N维区间树?

    考虑以下问题 给定一组n间隔和一组m浮点数 对于每个浮点数 确定包含该浮点数的区间子集 这个问题已经通过构建一个解决区间树 https en wikipedia org wiki Interval tree 或称为范围树或线段树 已经针对一
  • AWS EMR Spark Python 日志记录

    我正在 AWS EMR 上运行一个非常简单的 Spark 作业 但似乎无法从我的脚本中获取任何日志输出 我尝试过打印到 stderr from pyspark import SparkContext import sys if name m
  • Flask如何获取请求的HTTP_ORIGIN

    我想用我自己设置的 Access Control Allow Origin 标头做出响应 而弄清楚请求中的 HTTP ORIGIN 参数在哪里似乎很混乱 我在用着烧瓶 0 10 1 以及HTTP ORIGIN似乎是这个的特点之一object
  • 如何使用Python创建历史时间线

    So I ve seen a few answers on here that helped a bit but my dataset is larger than the ones that have been answered prev
  • IO 密集型任务中的 Python 多线程

    建议仅在 IO 密集型任务中使用 Python 多线程 因为 Python 有一个全局解释器锁 GIL 只允许一个线程持有 Python 解释器的控制权 然而 多线程对于 IO 密集型操作有意义吗 https stackoverflow c
  • 在f字符串中转义字符[重复]

    这个问题在这里已经有答案了 我遇到了以下问题f string gt gt gt a hello how to print hello gt gt gt f a a gt gt gt f a File
  • 使用 \r 并打印一些文本后如何清除控制台中的一行?

    对于我当前的项目 有一些代码很慢并且我无法使其更快 为了获得一些关于已完成 必须完成多少的反馈 我创建了一个进度片段 您可以在下面看到 当你看到最后一行时 sys stdout write r100 80 n I use 80覆盖最终剩余的
  • Pandas:merge_asof() 对多行求和/不重复

    我正在处理两个数据集 每个数据集具有不同的关联日期 我想合并它们 但因为日期不完全匹配 我相信merge asof 是最好的方法 然而 有两件事发生merge asof 不理想的 数字重复 数字丢失 以下代码是一个示例 df a pd Da
  • Fabric env.roledefs 未按预期运行

    On the 面料网站 http docs fabfile org en 1 10 usage execution html 给出这个例子 from fabric api import env env roledefs web hosts
  • Python:如何将列表列表的元素转换为无向图?

    我有一个程序 可以检索 PubMed 出版物列表 并希望构建一个共同作者图 这意味着对于每篇文章 我想将每个作者 如果尚未存在 添加为顶点 并添加无向边 或增加每个合著者之间的权重 我设法编写了第一个程序 该程序检索每个出版物的作者列表 并
  • 从列表指向字典变量

    假设你有一个清单 a 3 4 1 我想用这些信息来指向字典 b 3 4 1 现在 我需要的是一个常规 看到该值后 在 b 的位置内读写一个值 我不喜欢复制变量 我想直接改变变量b的内容 假设b是一个嵌套字典 你可以这样做 reduce di
  • NotImplementedError:无法将符号张量 (lstm_2/strided_slice:0) 转换为 numpy 数组。时间

    张量流版本 2 3 1 numpy 版本 1 20 在代码下面 define model model Sequential model add LSTM 50 activation relu input shape n steps n fe

随机推荐

  • 6打印文件

    原题链接 满分 华为OD机试真题2023 JAVA 打印文件 若博豆的博客 CSDN博客 本来以为需要用map 还复习了一下语法 原来不需要 用vector存三元数组 两个pair嵌套就可以 include
  • 李建忠老师-设计模式

    前言 1 课程目标 理解松耦合设计思想 掌握面向对象设计原则 掌握重构技法改善设计 掌握GOF核心设计 补充 GOF Gong of Gour 就是四人帮的全称 下面这本书的作者 Design Patterns Elements of Re
  • 解决webstom failed to change read-only files

    我百思不得其解的是 为何我的文件不让我更改 变成了只读模式 后来我仔细回忆了一下 原来是因为我使用了root权限 来安装thinkjs之后 webstom没有root权限 所以我使用root 在终端敲下如下命令 即可解决问题 chown R
  • 2021-07-02

    TOC第一章概述 本章最重要的内容 1 互联网的边缘部分和核心部分的作用 其中包含分组交换的概念 答案 边缘部分由所有连接在互联网上的主机组成 这部分是用户直接使用的 用来进行通信 传送数据 音频或视频 和资源共享 核心部分有大量的网络和连
  • Windows连接虚拟机Centos7的ssh被拒绝

    1 ssh connect to host centos py port 22 Connection refused 2 启动ssh服务报错 service sshd start Job for ssh service failed bec
  • 浅蓝不惑:在线或用API生成二维码——为什么不让你的二维码有更多选择和样式?

    引言 山中何事 松花酿酒 春水煎茶 勿埋我心 什么是二维码 二维码也称为二维条码 是指在一维条码的基础上扩展出另一维具有可读性的条码 使用黑白矩形图案表示二进制数据 被设备扫描后可获取其中所包含的信息 一维条码的宽度记载着数据 而其长度没有
  • Spring Cloud 学习笔记三:搭建微服务工程之Ribbon 自定义负载均衡策略

    目录 Ribbon 自定义负载均衡策略 Ribbon 自定义负载均衡策略 通过实现 IRule 接口可以自定义负载策略 主要的选择服务逻辑在 choose 方法中 下面自定义负载策略 直接返回服务列表中第一个服务 代码如下所示 public
  • aptos中文版白皮书-前Facebook团队打造明星公链,三个优势:Move语言、Move虚拟机、合约可升级

    摘要 区块链作为一种新的互联网基础设施的崛起 导致开发者以快速增长的速度部署了数万个去中心化的应用程序 不幸的是 由于频繁的中断 高成本 低吞吐量限制和许多安全问题 区块链的使用还不普遍 为了在web3时代实现大规模采用 区块链基础设施需要
  • 春秋云境:CVE-2022-29464(WSO2文件上传漏洞)

    目录 一 题目 二 burp改包 一 题目 进入题目 是一个登录页面 这题确实没什么思路 所以看了官方POC 因为这个漏洞已经被国家cnnvd收入了 二 burp改包 burp抓包 不需要登录 刷新即可 发送到重放器 根据官方POC更改即可
  • Linux虚拟机安装Ubuntu

    一 在电脑上安装VMware workstation和Ubuntu映像文件 二 安装虚拟机 1 双击VMware workstation的exe文件 即第一张图 用管理员身份运行 一直下一步 到 更改目标文件夹 在文件夹名称处选择软件的文件
  • mysql 里面的isnull()和ifnull() is null 和 is not null

    usergrade表 2 找到里面username是null的行 SELECT FROM usergrade WHERE ISNULL USERNAME SELECT FROM usergrade WHERE USERNAME IS NUL
  • 可重入锁(ReentrantLock和synchronized原理及区别)+锁升级

    目录 1 Synchronized底层原理 ReentrantLock实现的原理及使用 Java中synchronized 和 ReentrantLock 有什么不同 追问3 synchronized锁升级的过程说一下 追问4 synchr
  • Ubuntu下无法看到共享文件夹的解决办法

    参考 Ubuntu下无法看到共享文件夹的解决办法 作者 一只青木呀 发布时间 2020 08 07 10 09 04 网址 https blog csdn net weixin 45309916 article details 107856
  • 爆款小程序是如何诞生的?

    欢迎大家前往腾讯云 社区 获取更多腾讯海量技术实践干货哦 本文首发在云 社区 未经许可 不得转载 作者 黄荣奎 腾讯云微信小程序解决方案负责人 今年可以说是小程序的元年 各类游戏 店商 旅游类的小程序如雨后春笋般涌现 我想在座的朋友大家或多
  • 使用公网访问内网IIS网站服务器【无需公网IP】

    使用公网访问内网IIS网站服务器 无需公网IP 文章目录 使用公网访问内网IIS网站服务器 无需公网IP 前言 1 注册并安装cpolar 2 创建隧道映射 3 获取公网地址 前言 这里介绍通过内网穿透 实现公网访问内网IIS网站服务器 都
  • C++ 时间函数整理详解

    一 时间概念 格林威治时间 GMT Greenwich Mean Time 格林威治皇家天文台为了海上霸权的扩张计划 在十七世纪就开始进行天体观测 为了天文观测 选择了穿过英国伦敦格林威治天文台子午仪中心的一条经线作为零度参考线 这条线 简
  • java连接mysql数据库测试用例

    文章目录 java连接mysql数据库测试用例超详细 1 新建一个 java project 2 在项目下新建一个lib文件夹 3 然后复制 mysql connector java jar 包到lib包下 4 在jar包上右键选择Buil
  • Xshell连接centOS7与CentOS7联网——一步到位

    参照 CSDN 这篇文章一看就明白了 就像引出 3 4 重构那样 我们也可以直接将配置前与配置后的对比状态列举出来 这样更省事 0 对于如下配置的宿主机 此处即为windows主机 1 编辑 虚拟网络编辑器 配置完毕后的状态如下 注 1 其
  • 【FPGA】一、FPGA简介

    文章目录 一 FPGA 简介 相关名词解释 FPGA基本构造 FPGA开发流程 硬件资源介绍 二 开发工具介绍 VScode Quartus II Vivado ModelSim Visio 总结 一 FPGA 简介 FPGA是Field
  • python交通信号灯检测yolov5交通信号灯识别,红绿灯检测,左转右转识别

    python交通信号灯检测yolov5交通信号灯识别 红绿灯检测 左转右转识别 交通信号灯的检测与识别是无人驾驶与辅助驾驶必不可少的一部分 其识别精度直接关乎智能驾驶的安全 一般而言 在实际的道路场景中采集的交通信号灯图像具有复杂的背景 且