【计算机视觉】基于OpenCV的直线检测

直线检测原理

霍夫变换是图像处理必然接触到的一个算法,它通过一种投票算法检测具有特定形状的物体,该过程在一个参数空间中通过计算累计结果的局部最大值得到一个符合该特定形状的集合作为霍夫变换结果,该方法可以进行圆,直线,椭圆等形状的检测。在车道线检测中,当初考虑的一个方案便是采用霍夫变换检测直线进行车道线提取。

x,y坐标系中直线上的一个点对应到ρ,θ坐标系中是一条曲线。

x,y坐标系中直线上的所有点在ρ,θ坐标系中对应的所有曲线交汇到一个点上。

ρ,θ坐标系中的一个点对应x,y坐标系中的一条直线。

使用opencv进行直线检测

在使用霍夫变换侦测直线前,须先利用边缘检测算法来减少图像的数据量、剔掉不相关的信息,保留图像中重要的结构特征。

2.1 图像灰度化

python 复制代码
gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

原始图像与灰度化的图像如下:

2.2 边缘检测

利用边缘检测算法(Canny、Sobel、Laplacian等)来检测物体边缘,代码如下:

python 复制代码
canny = cv2.Canny(gray_img, 30, 150)

2.3 霍夫变换

使用霍夫变换来得出直线检测结果,代码如下:

python 复制代码
# 使用HoughLinesP检测线段
lines = cv2.HoughLinesP(canny, 1, np.pi / 180, 180, minLineLength=100, maxLineGap=10)

# 检查是否检测到线段
if lines is not None:
    for line in lines:
        x1, y1, x2, y2 = line[0]
        cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2)

cv2.imshow('original', img)

2.4 完整代码

python 复制代码
import cv2
import numpy as np

img = cv2.imread("Resources/img_1.png")

cv2.imshow("Output",img)
cv2.waitKey(0)

gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
cv2.imshow('gray', gray_img)
cv2.waitKey(0)

canny = cv2.Canny(gray_img, 30, 150)
cv2.imshow('canny', canny)
cv2.waitKey(0)

# 使用HoughLinesP检测线段
lines = cv2.HoughLinesP(canny, 1, np.pi / 180, 180, minLineLength=100, maxLineGap=10)

# 检查是否检测到线段
if lines is not None:
    for line in lines:
        x1, y1, x2, y2 = line[0]
        cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2)

cv2.imshow('original', img)

cv2.waitKey(0)
相关推荐
三块可乐两块冰3 分钟前
【第二十六周】机器学习笔记二十五
人工智能·笔记·机器学习
一招定胜负6 分钟前
opencv图片处理常见操作
人工智能·opencv·计算机视觉
byzh_rc6 分钟前
[机器学习-从入门到入土] 特征选择
人工智能·机器学习
Hcoco_me7 分钟前
大模型面试题41:RoPE改进的核心目标与常见方法
开发语言·人工智能·深度学习·自然语言处理·transformer·word2vec
Toky丶8 分钟前
【文献阅读】Half-Quadratic Quantization of Large Machine Learning Models
人工智能·机器学习
海棠AI实验室9 分钟前
海光DCU部署全攻略:开箱、配置到AI训练的最佳实践|2026工程化版本
人工智能·dcu·海光
LDG_AGI10 分钟前
【推荐系统】深度学习训练框架(二十三):TorchRec端到端超大规模模型分布式训练+推理实战
人工智能·分布式·深度学习·机器学习·数据挖掘·推荐算法
沛沛老爹13 分钟前
Web开发者快速上手AI Agent:基于Function Calling的提示词应用优化实战
java·人工智能·llm·agent·web·企业开发·function
张彦峰ZYF14 分钟前
提示词工程(Prompt Engineering):核心技巧进阶与工程化流程
人工智能·prompt·提示词工程·用清晰明确的话语表达任务意图·在可能情况下用示例去阐明输出·根据任务类型灵活选择提示策略·提示设计视作迭代工程非单次输入
AI浩15 分钟前
ARConv:用于遥感全色锐化的自适应矩形卷积
人工智能·目标跟踪