Python实现YOLOv8车道线与车辆检测

liftword16小时前技术文章4

以下是一个基于YOLOv8和OpenCV实现车道线与车辆检测的Python示例代码,结合了深度学习目标检测和传统图像处理技术:

python

import cv2

import numpy as np

from ultralytics import YOLO


def load_yolo_model():

# 加载预训练的YOLOv8模型

model = YOLO('yolov8n.pt') # 使用nano版本

return model


def detect_vehicles(frame, model):

# 使用YOLOv8进行车辆检测

results = model(frame, verbose=False)


# 解析检测结果

for result in results:

boxes = result.boxes.data.cpu().numpy()

for box in boxes:

x1, y1, x2, y2, conf, cls_id = box

if conf > 0.5 and cls_id in [2, 3, 5, 7]: # 车辆类别

cv2.rectangle(frame, (int(x1), int(y1)), (int(x2), int(y2)), (0, 255, 0), 2)

return frame


def detect_lanes(frame):

# 转换为灰度图像

gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)


# 高斯模糊降噪

blur = cv2.GaussianBlur(gray, (5, 5), 0)


# Canny边缘检测

edges = cv2.Canny(blur, 50, 150)


# 定义ROI区域(梯形区域)

height, width = edges.shape

mask = np.zeros_like(edges)

vertices = np.array([[

(width*0.1, height),

(width*0.45, height*0.6),

(width*0.55, height*0.6),

(width*0.9, height)

]], dtype=np.int32)

cv2.fillPoly(mask, vertices, 255)

masked_edges = cv2.bitwise_and(edges, mask)


# 霍夫变换检测直线

lines = cv2.HoughLinesP(masked_edges, 1, np.pi/180, 50,

minLineLength=50, maxLineGap=100)


# 过滤并绘制车道线

if lines is not None:

left_lines = []

right_lines = []


for line in lines:

x1, y1, x2, y2 = line[0]

slope = (y2 - y1) / (x2 - x1 + 1e-5)


if abs(slope) < 0.5: # 过滤水平线

continue


if slope < 0:

left_lines.append(line[0])

else:

right_lines.append(line[0])


# 平均车道线

def average_lines(lines):

if not lines:

return None

lines = np.array(lines)

return np.mean(lines, axis=0, dtype=np.int32)


avg_left = average_lines(left_lines)

avg_right = average_lines(right_lines)


# 绘制车道线

def draw_line(img, line, color=(0, 0, 255), thickness=10):

if line is not None:

x1, y1, x2, y2 = line

cv2.line(img, (x1, y1), (x2, y2), color, thickness)


draw_line(frame, avg_left)

draw_line(frame, avg_right)


return frame


def main():

# 初始化模型

model = load_yolo_model()


# 打开视频文件或摄像头

cap = cv2.VideoCapture('test_video.mp4') # 替换为你的视频路径


while cap.isOpened():

ret, frame = cap.read()

if not ret:

break


# 车辆检测

vehicle_frame = detect_vehicles(frame.copy(), model)


# 车道线检测

lane_frame = detect_lanes(frame)


# 合并结果

combined = cv2.addWeighted(vehicle_frame, 0.8, lane_frame, 1, 0)


cv2.imshow('Lane and Vehicle Detection', combined)


if cv2.waitKey(1) & 0xFF == ord('q'):

break


cap.release()

cv2.destroyAllWindows()


if __name__ == "__main__":

main()

实现说明:

  1. 车辆检测部分

O 使用YOLOv8的预训练模型进行目标检测

O 筛选车辆类别(包括汽车、卡车、公交车等)

O 在检测到车辆周围绘制边界框

  1. 车道线检测部分
  2. 使用传统图像处理流程:
  3. 灰度转换
  4. 高斯模糊降噪
  5. Canny边缘检测
  6. ROI区域裁剪
  7. 霍夫变换检测直线

O 对检测到的直线进行过滤和平均处理

O 最终绘制稳定的左右车道线

  1. 性能优化建议

O 调整ROI区域顶点坐标以适应不同视角

O 修改Canny和霍夫变换参数优化检测效果

O 使用GPU加速YOLO推理(安装CUDA版PyTorch)

O 降低视频处理分辨率提升速度

使用步骤:

  1. 安装依赖:

bash

pip install ultralytics opencv-python numpy

  1. 下载YOLOv8预训练模型(自动下载)或替换为自定义模型
  2. 准备测试视频(或将视频路径改为0使用摄像头)
  3. 运行脚本即可看到实时检测效果

参数调整建议:

  • 车道线检测

O 修改vertices数组调整ROI区域

O 调整Canny阈值(50, 150)

O 修改霍夫变换参数(阈值、最小线长等)

  • 车辆检测

O 调整置信度阈值(0.5)

O 修改绘制的边界框颜色和粗细

该方案结合了深度学习的高精度目标检测和传统图像处理的高效特性,能够实时处理道路场景中的关键信息。用户可以根据实际场景需求调整参数以获得最佳效果。

相关文章

Pytest 入门与进阶:全面掌握 Python 自动化测试

**Pytest** 是 Python 中非常流行的一个测试框架,它提供了一种简单而高效的方式来编写和执行测试,广泛应用于单元测试、功能测试和集成测试。Pytest 以其简洁的语法和丰富的功能,成为...

从零入门Python测试神器pytest!高效测试,代码质量飙升10倍

引言:为什么测试是开发者的"金钟罩"?在编程江湖中,未经测试的代码如同没有铠甲的战士。今天要介绍的pytest,正是Python领域测试覆盖率排名第一的利器(2023年PyPI官方数据...

Python单元测试最佳实践指南:编写高效测试的7个核心技巧

作为Python开发者,编写单元测试是最值得培养(并不断提升)的优秀习惯之一。它能帮助您及早发现错误、简化调试过程,并让您有信心进行代码修改而不破坏现有功能。但并非所有测试都具有同等价值!如果测试代码...

python四个性能检测工具,包括函数的运行内存、时间等等...

这里总结了五个比较好的python性能检测工具,包括内存使用、运行时间、执行次数等方面。首先,来编写一个基础的python函数用于在后面的各种性能测试。def base_func(): for...

Python进阶-day19: 测试与调试

一、课程目标理解测试的重要性:掌握软件测试的基本概念,了解单元测试在提高代码质量和可维护性中的作用。学习测试框架:熟悉Python中两种主流测试框架unittest和pytest的使用方法,理解它们的...