Python_OpenCV_TensorFlow微型仿真深度学习 Raspberry Pi 自动驾驶车

视觉OpenCV 配置

Raspberry Pi 配置 TensorFlow

OpenCV自主车道导航

import cv2
frame = cv2.imread('/home/pi/DeepCar/driver/data/road1_240x320.png')
hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)

请注意,我们使用的是 BGR 到 HSV 的转换,而不是 RBG 到 HSV 的转换。 这是因为 OpenCV 由于某些遗留原因,默认将图像读入 BGR(蓝/绿/红)色彩空间,而不是更常用的 RGB(红/绿/蓝)色彩空间。 它们本质上是等效的颜色空间,只是交换了颜色的顺序。

这是通过 OpenCV 提取蓝色并渲染蒙版图像的代码。

lower_blue = np.array([60, 40, 40])
upper_blue = np.array([150, 255, 255])
mask = cv2.inRange(hsv, lower_blue, upper_blue)

检测车道线的边缘

我们需要检测蓝色遮罩中的边缘,以便我们可以有几条不同的线来代表蓝色车道线。

Canny 边缘检测功能是一个功能强大的命令,可以检测图像中的边缘。 在下面的代码中,第一个参数是上一步中的蓝色遮罩。 第二个和第三个参数是边缘检测的下限和上限,OpenCV 建议为 (100, 200) 或 (200, 400),因此我们使用 (200, 400)。

edges = cv2.Canny(mask, 200, 400)

将上述命令放在一起,下面是隔离图像上的蓝色并提取所有蓝色区域边缘的函数。

def detect_edges(frame):
    # filter for blue lane lines
    hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)
    show_image("hsv", hsv)
    lower_blue = np.array([60, 40, 40])
    upper_blue = np.array([150, 255, 255])
    mask = cv2.inRange(hsv, lower_blue, upper_blue)
    show_image("blue mask", mask)

    # detect edges
    edges = cv2.Canny(mask, 200, 400)

    return edges

隔离感兴趣区域

深度学习自主车道导航

交通标志和行人检测

源代码

参阅 -亚图跨际
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值