计算机视觉结合深度学习项目-智能停车场空车位实时识别_大厦智能停车场空余车位算法

    if make_copy:
        new_image = np.copy(image)
    #Step 1: 过滤部分直线
    cleaned = []
    for line in lines:
        for x1,y1,x2,y2 in line:
            if abs(y2-y1) <=1 and abs(x2-x1) >=25 and abs(x2-x1) <= 55:
                cleaned.append((x1,y1,x2,y2))

首先我们还是过滤掉一些直线。



import operator
list1 = sorted(cleaned, key=operator.itemgetter(0, 1))


对于这十二列,每一列的左上角的坐标点我们是可以得到x1-x12的我们要对这些列进行一次排序操作。让计算机识别出哪一列是第一列,哪一列是第十二列。



    clusters = {}
    dIndex = 0
    clus_dist = 10

    for i in range(len(list1) - 1):
        distance = abs(list1[i+1][0] - list1[i][0])
        if distance <= clus_dist:
            if not dIndex in clusters.keys(): clusters[dIndex] = []
            clusters[dIndex].append(list1[i])
            clusters[dIndex].append(list1[i + 1]) 

        else:
            dIndex += 1

这里就是做了一下对于所有排序好的直线进行了一个归类操作,把哪些直线归为一列。并且进行添加。直到把每一列都进行分出来。



    rects = {}
    i = 0
    for key in clusters:
        all_list = clusters[key]
        cleaned = list(set(all_list))#一列中的所有直线的坐标信息
        if len(cleaned) > 5:
            cleaned = sorted(cleaned, key=lambda tup: tup[1])#对直线进行排序
            avg_y1 = cleaned[0][1]#这个对于一列来说是固定的
            avg_y2 = cleaned[-1][1]#这个对于一列来说是固定的
            avg_x1 = 0
            avg_x2 = 0
            for tup in cleaned:
                avg_x1 += tup[0]
                avg_x2 += tup[2]
            avg_x1 = avg_x1/len(cleaned)
            avg_x2 = avg_x2/len(cleaned)
            rects[i] = (avg_x1, avg_y1, avg_x2, avg_y2)
            i += 1
    
    print("Num Parking Lanes: ", len(rects))

然后我们对每一列进行操作,把每一列的每一个车位的所有坐标信息提取出来。然后再通过得到的坐标及进行画出来这个矩形。



    buff = 7#微调数值
    for key in rects:
        tup_topLeft = (int(rects[key][0] - buff), int(rects[key][1]))
        tup_botRight = (int(rects[key][2] + buff), int(rects[key][3]))
        cv2.rectangle(new_image, tup_topLeft,tup_botRight,(0,255,0),3)
    return new_image, rects

![在这里插入图片描述](https://img-blog.csdnimg.cn/8e8
下面是一个简单的Opencv停车场空余车位检测的示例代码,仅供参考: ```python import cv2 # 读取停车场图像 img = cv2.imread('parking_lot.jpg') # 转换颜色空间为灰度 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 对图像进行高斯模糊 blur = cv2.GaussianBlur(gray, (5, 5), 0) # 进行Canny边缘检测 edges = cv2.Canny(blur, 50, 150) # 对边缘图像进行形态学操作,填充小孔洞 kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5)) closed = cv2.morphologyEx(edges, cv2.MORPH_CLOSE, kernel) # 查找轮廓 contours, hierarchy = cv2.findContours(closed, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) # 遍历所有轮廓,判断是否为空余车位 for contour in contours: # 计算轮廓面积 area = cv2.contourArea(contour) # 如果面积小于一定阈值,则认为是噪声 if area < 1000: continue # 计算轮廓周长 perimeter = cv2.arcLength(contour, True) # 计算轮廓近似多边形 approx = cv2.approxPolyDP(contour, 0.02 * perimeter, True) # 如果近似多边形有4个顶点,则认为是矩形车位 if len(approx) == 4: # 计算车位中心坐标 M = cv2.moments(contour) cx = int(M['m10'] / M['m00']) cy = int(M['m01'] / M['m00']) # 在图像上绘制车位中心点 cv2.circle(img, (cx, cy), 5, (0, 255, 0), -1) # 显示结果图像 cv2.imshow('Parking Lot', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 注意:这只是一个简单的示例代码,实际应用中需要根据具体场景进行调整和优化。同时,由于车位的颜色和形状可能会有很大差异,因此需要进行充分的测试和训练,以确保算法的准确性和稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值