YOLO V8 predict.py将命令行运行改为直接运行

文章讲述了如何在YOLOv8中通过命令行快速运行预测代码,提供必要的参数设置和代码示例,方便初学者调试。
摘要由CSDN通过智能技术生成

YOLOv8命令行运行代码为:yolo predict model=yolov8n.pt source='ultralytics/assets/bus.jpg'

在入门阶段进行调试时每次需在命令行运行较为麻烦,修改主函数参数的调用

主要修改的地方如下:

传入所需运行的参数模型   model

传入所需预测的图片地址  source

代码如下:

# Ultralytics YOLO 🚀, AGPL-3.0 license

import torch
import ultralytics
# from ultralytics import YOLO


from ultralytics.engine.predictor import BasePredictor
from ultralytics.engine.results import Results
from ultralytics.utils import DEFAULT_CFG, ROOT, ops


class DetectionPredictor(BasePredictor):

    def postprocess(self, preds, img, orig_imgs):
        """Postprocesses predictions and returns a list of Results objects."""
        preds = ops.non_max_suppression(preds,
                                        self.args.conf,
                                        self.args.iou,
                                        agnostic=self.args.agnostic_nms,
                                       max_det=self.args.max_det,
                                        classes=self.args.classes)

        results = []
        for i, pred in enumerate(preds):
            orig_img = orig_imgs[i] if isinstance(orig_imgs, list) else orig_imgs
            if not isinstance(orig_imgs, torch.Tensor):
                pred[:, :4] = ops.scale_boxes(img.shape[2:], pred[:, :4], orig_img.shape)
            path = self.batch[0]
            img_path = path[i] if isinstance(path, list) else path
            results.append(Results(orig_img=orig_img, path=img_path, names=self.model.names, boxes=pred))
        return results


def predict(model,source,cfg=DEFAULT_CFG, use_python=False):
    """Runs YOLO model inference on input image(s)."""
    # model = cfg.model or 'yolov8n.pt'
    #model =ultralytics.YOLO("../yolov8n.pt")
    # source = cfg.source if cfg.source is not None else ROOT / 'assets' if (ROOT / 'assets').exists() \
    #     else 'https://ultralytics.com/images/bus.jpg'
    model=model
    source=source

    args = dict(model=model, source=source)
    if use_python:
        from ultralytics import YOLO
        YOLO(model)(**args)
    else:
        predictor = DetectionPredictor(overrides=args)
        predictor.predict_cli()


if __name__ == '__main__':
    model='yolov8n.pt'
    source="D:/CVproject/ultralytics-main/ultralytics/assets/bus.jpg"
    source="D:/CVproject/yolov7-main/inference/images/test5.jpg"
    predict(model,source)

  • 11
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
安装YOLOv5的过程中,首先需要确保Python版本是3.7及以上。如果你的环境中有多个Python版本,需要检查环境变量中是否有Python3.7的路径。如果没有,你需要下载并安装Python3.7,并将其设置为环境变量路径。接下来,你可以参考相关博客来配置pytorch和opencv。在安装完成后,你可以验证安装是否成功,可以在终端中运行ultralytics-main\ultralytics\yolo\v8\detect\predict.py这个文件,并修改图片的路径来进行验证。如果你想在Pycharm中进行修改,可以将下载的yolov5压缩包解压并复制到Pycharm中,然后在Pycharm的yolov5文件夹中使用命令行安装所需的资源包。具体操作是进入yolov5文件夹,并使用命令"pip install -r requirements.txt"来安装所需的资源包。这样就完成了YOLOv5的安装过程。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [Python3.7安装YOLOV5(CPU运行)](https://blog.csdn.net/weixin_63326467/article/details/125367309)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [pyton\yolov8安装和基础使用,训练和预测](https://blog.csdn.net/weixin_65996583/article/details/129841252)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Yolov5-Python系列(一)—— 基础入门(yolov5安装、简单使用)](https://blog.csdn.net/weixin_51111267/article/details/129247651)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值