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)