道路区域提取方法(全色图像)

1 介绍

1、区域生长使用欧式距离判断像素差异

2、区分树叶使用GLI(gli = (2 * g - r - b) / (2 * g + r + b))

3、区分阴影使用亮度值

4、如果周围像素小于1个是叶子或阴影,只要周围有4个像素都属于区域,那么这个像素也属于区域

5、如果有5个像素都属于区域,那么这个像素也属于区域

2 源代码

https://github.com/zouxlin3/RoadExtract

3 使用方法

3.1 导入图片

from RoadRegionGrow import RoadImg  # 从源代码下载RoadRegionGrow.py和Point.py
import matplotlib.pyplot as plt
import numpy as np
roadimg = RoadImg('test_pic.png')  # 输入图片路径
plt.imshow(roadimg.img)

image

图片来源(http://www.zhongkezhihang.com/html/news/579.html#lg=1&slide=2)

3.2 选取种子点

选取种子点[400, 600]和[300,1000](x、y值和图片上是相反的)

seeds = [[400, 600], [300,1000]]
roadimg.add_seeds(seeds)

3.3 确定区分树木和阴影的阈值

1、绘制gli的直方图

roadimg.gli_hist()

image

选取gli阈值为0.01


2、绘制亮度值的直方图

roadimg.lightness_hist()

image

选取亮度值阈值为140.0

3.4 区域生长

label = [255, 0, 0]
em_threshold = 9  # 阈值可以根据多次试验确定,不同的图片不一样
g_thershold = 0.01
l_thershold = 140.0
transparency = 0.5
roadimg.region_grow(label, em_threshold, g_thershold, l_thershold)
plt.imshow(roadimg.add_mask(transparency))

image

plt.imshow(np.uint8(roadimg.region))

image

for i in range(6):  # 进行多次遗漏检测
    roadimg.leak_detect(label, g_thershold, l_thershold)
plt.imshow(roadimg.add_mask(transparency))

image

plt.imshow(np.uint8(roadimg.region))

image

4 本文最新版本

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酒桶在你野区

感谢支持!????

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值