OpenCV自学笔记29. lsd直线检测算法(未完)

2024-05-14 15:58

本文主要是介绍OpenCV自学笔记29. lsd直线检测算法(未完),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

lsd直线检测算法

LSD是一种直线检测分割算法,它能在线性的时间内得出亚像素级精度的检测结果。该算法被设计成可以在任何数字图像上都无需参数调节。

参考:http://blog.csdn.net/lien0906/article/details/38417191

1、lsd算法的步骤(未完)

LSD算法的步骤如下:

  • 1、图像缩放
  • 2、梯度计算
  • 3、梯度排序
  • 4、阈值检测
  • 5、区域增长
  • 6、矩形近似

下面分别介绍每一个步骤:

1、图像缩放

2、梯度计算

3、梯度排序

4、阈值检测

5、区域增长

计算每个像素点8-邻域内level-line的角度,如果某个像素点的level-line角度与区域内平均的level-line角度相近(小于22.5°),则将该像素点加入到区域中,并重新计算区域内的平均level-line角度。

如下图所示:LSD算法将线段看做一小段图像区域,在这个区域中,图像的灰度发生剧烈变化,灰度变化的方向为梯度方向(Gradient),与梯度方向垂直的方向为线段方向(Level-Line)。

这里写图片描述

6、矩形近似
使用矩形覆盖区域,区域的质心就是矩形的中心。

2、lsd源码分析

3、实例

这个Demo用到的测试图像是:

这里写图片描述

下面的代码,部分参考自:OpenCV官网

lsd_lines.cpp

#include <opencv2/opencv.hpp>
#include <iostream>using namespace cv;
using namespace std;int main() 
{string path = "images/test3.jpg";Mat image = imread(path, IMREAD_GRAYSCALE);blur(image, image, Size(3,3)); // 使用3x3内核来降噪Canny(image, image, 50, 200, 3); // Apply canny edge// Create and LSD detector with standard/*LSD_REFINE_NONE,没有改良的方式;LSD_REFINE_STD,标准改良方式,将带弧度的线(拱线)拆成多个可以逼近原线段的直线度;LSD_REFINE_ADV,进一步改良方式,计算出错误警告数量,通过增加精度,减少尺寸进一步精确直线。*/Ptr<LineSegmentDetector> ls = createLineSegmentDetector(LSD_REFINE_STD);double start = double(getTickCount());vector<Vec4f> lines_std;// Detect the linesls->detect(image, lines_std);// Show found linesMat drawnLines(image);ls->drawSegments(drawnLines, lines_std);Mat only_lines(image.size(), image.type());ls->drawSegments(only_lines, lines_std);imshow("【lsd直线检测】", drawnLines);imshow("【仅仅是直线】", only_lines);waitKey(0);return 0;
}

结果图分析

程序首先对源图像滤波降噪,然后使用canny边缘检测算法,提取图像中的边缘。接着创建LineSegmentDetector对象的智能指针并初始化,用于直线检测。
最后,将检测到的直线绘制出来。


createLineSegmentDetector的函数说明如下:


这里写图片描述

这里写图片描述

这篇关于OpenCV自学笔记29. lsd直线检测算法(未完)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/989188

相关文章

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee

Python如何将OpenCV摄像头视频流通过浏览器播放

《Python如何将OpenCV摄像头视频流通过浏览器播放》:本文主要介绍Python如何将OpenCV摄像头视频流通过浏览器播放的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完... 目录方法1:使用Flask + MJPEG流实现代码使用方法优点缺点方法2:使用WebSocket传输视