当前位置: 首页 > news >正文

商业网站开发教程佛山网站建设邓先生

商业网站开发教程,佛山网站建设邓先生,吉林省吉林市邮编,国内免费域名申请0 前言 #x1f525; 优质竞赛项目系列#xff0c;今天要分享的是 #x1f6a9; 深度学习 机器视觉 车位识别车道线检测 该项目较为新颖#xff0c;适合作为竞赛课题方向#xff0c;学长非常推荐#xff01; #x1f947;学长这里给一个题目综合评分(每项满分5分) …0 前言 优质竞赛项目系列今天要分享的是 深度学习 机器视觉 车位识别车道线检测 该项目较为新颖适合作为竞赛课题方向学长非常推荐 学长这里给一个题目综合评分(每项满分5分) 难度系数3分工作量3分创新点4分 更多资料, 项目分享 https://gitee.com/dancheng-senior/postgraduate 简介 你是不是经常在停车场周围转来转去寻找停车位。如果你的车辆能准确地告诉你最近的停车位在哪里那是不是很爽事实证明基于深度学习和OpenCV解决这个问题相对容易只需获取停车场的实时视频即可。 检测效果 废话不多说 先上效果图 注意车辆移动后空车位被标记上 车辆移动到其他车位 实现方式 整体思路 这个流程的第一步就是检测一帧视频中所有可能的停车位。显然在我们能够检测哪个是没有被占用的停车位之前我们需要知道图像中的哪些部分是停车位。 第二步就是检测每帧视频中的所有车辆。这样我们可以逐帧跟踪每辆车的运动。 第三步就是确定哪些车位目前是被占用的哪些没有。这需要结合前两步的结果。 最后一步就是出现新车位时通知我。这需要基于视频中两帧之间车辆位置的变化。 这里的每一步我们都可以使用多种技术用很多种方式实现。构建这个流程并没有唯一正确或者错误的方式但不同的方法会有优劣之分。 使用要使用到两个视觉识别技术 识别空车位停车线识别车辆 检测空车位 车位探测系统的第一步是识别停车位。有一些技巧可以做到这一点。例如通过在一个地点定位停车线来识别停车位。这可以使用OpenCV提供的边缘检测器来完成。但是如果没有停车线呢 我们可以使用的另一种方法是假设长时间不移动的汽车停在停车位上。换句话说有效的停车位就是那些停着不动的车的地方。但是这似乎也不可靠。它可能会导致假阳性和真阴性。 那么当自动化系统看起来不可靠时我们应该怎么做呢?我们可以手动操作。与基于空间的方法需要对每个不同的停车位进行标签和训练不同我们只需标记一次停车场边界和周围道路区域即可为新的停车位配置我们的系统。 在这里我们将从停车位的视频流中截取一帧并标记停车区域。Python库matplotlib 提供了称为PolygonSelector的功能。它提供了选择多边形区域的功能。 我制作了一个简单的python脚本来标记输入视频的初始帧之一上的多边形区域。它以视频路径作为参数并将选定多边形区域的坐标保存在pickle文件中作为输出。 ​ import os import numpy as np import cv2 import pickle import argparse import matplotlib.pyplot as plt from matplotlib.patches import Polygon from matplotlib.widgets import PolygonSelector from matplotlib.collections import PatchCollection from shapely.geometry import box from shapely.geometry import Polygon as shapely_polypoints [] prev_points [] patches [] total_points [] breaker Falseclass SelectFromCollection(object):def __init__(self, ax):self.canvas ax.figure.canvasself.poly PolygonSelector(ax, self.onselect)self.ind []def onselect(self, verts):global pointspoints vertsself.canvas.draw_idle()def disconnect(self):self.poly.disconnect_events()self.canvas.draw_idle()def break_loop(event):global breakerglobal globSelectglobal savePathif event.key b:globSelect.disconnect()if os.path.exists(savePath):os.remove(savePath)print(data saved in savePath file) with open(savePath, wb) as f:pickle.dump(total_points, f, protocolpickle.HIGHEST_PROTOCOL)exit()def onkeypress(event):global points, prev_points, total_pointsif event.key n: pts np.array(points, dtypenp.int32) if points ! prev_points and len(set(points)) 4:print(Points : str(pts))patches.append(Polygon(pts))total_points.append(pts)prev_points pointsif __name__ __main__:parser argparse.ArgumentParser()parser.add_argument(video_path, helpPath of video file)parser.add_argument(--out_file, helpName of the output file, defaultregions.p)args parser.parse_args()global globSelectglobal savePathsavePath args.out_file if args.out_file.endswith(.p) else args.out_file.pprint(\n Select a region in the figure by enclosing them within a quadrilateral.)print( Press the f key to go full screen.)print( Press the esc key to discard current quadrilateral.)print( Try holding the shift key to move all of the vertices.)print( Try holding the ctrl key to move a single vertex.)print( After marking a quadrilateral press n to save current quadrilateral and then press q to start marking a new quadrilateral)print( When you are done press b to Exit the program\n)video_capture cv2.VideoCapture(args.video_path)cnt0rgb_image Nonewhile video_capture.isOpened():success, frame video_capture.read()if not success:breakif cnt 5:rgb_image frame[:, :, ::-1]cnt 1video_capture.release()while True:fig, ax plt.subplots()image rgb_imageax.imshow(image)p PatchCollection(patches, alpha0.7)p.set_array(10*np.ones(len(patches)))ax.add_collection(p)globSelect SelectFromCollection(ax)bbox plt.connect(key_press_event, onkeypress)break_event plt.connect(key_press_event, break_loop)plt.show()globSelect.disconnect()车辆识别 要检测视频中的汽车我使用Mask- RCNN。它是一个卷积神经网络对来自几个数据集包括COCO数据集的数百万个图像和视频进行了训练以检测各种对象及其边界。 Mask- RCNN建立在Faster-RCNN对象检测模型的基础上。 除了每个检测到的对象的类标签和边界框坐标外Mask RCNN还将返回图像中每个检测到的对象的像pixel-wise mask。这种pixel-wise masking称为“ 实例分割”。我们在计算机视觉领域所看到的一些最新进展包括自动驾驶汽车、机器人等都是由实例分割技术推动的。 M-RCNN将用于视频的每一帧它将返回一个字典其中包含边界框坐标、检测对象的masks、每个预测的置信度和检测对象的class_id。现在使用class_ids过滤掉汽车卡车和公共汽车的边界框。然后我们将在下一步中使用这些框来计算IoU。 由于Mask-RCNN比较复杂这里篇幅有限需要mask-RCNN的同学联系博主获取 下面仅展示效果 最后 更多资料, 项目分享 https://gitee.com/dancheng-senior/postgraduate
http://www.zqtcl.cn/news/364856/

相关文章:

  • 建设商业网站学校建设门户网站的好处
  • 男女朋友在一起做那个的网站公司建设网站
  • 营销型网站的类型有哪些相册网站怎么做
  • 河南建设监理协会网站电话erp管理系统官网
  • 视频网站seo实战做企业网站一般用什么服务器
  • icp备案 网站负责人免费直播sdk
  • 网站制作和如何推广动画专业学什么
  • 北京一家专门做会所的网站基于ssh框架的网站开发流程
  • 可以在自己的电脑上做网站吗陕西商城网站建设
  • 深圳网站建设工作室郴州有什么好玩的地方
  • 用dw做的网站怎么发到网上竹妃怎么在公众号里做网站
  • 杭州网站优化搜索黑龙江公共资源交易网官网
  • 动易网站 首页模板修改平台网站是什么
  • 营销网站更受用户欢迎的原因是英文网站的建设意义
  • 学网站建设基础河北省建设网站的网站首页
  • 铜仁市住房和城乡建设部网站延边有没有做网站的
  • 如何做ppt的模板下载网站移动端网站的优点
  • 网站域名没有实名认证微信平台开发技术
  • 自己用电脑做虚拟机怎么建网站个人网站 icp 代理
  • 嘉兴网站建设999 999中国建设招标网是私人网站吗
  • 网站程序设置主页面零基础学wordpress pdf下载
  • 网站代码优化有哪些专做立体化的网站
  • 单县网站定制培训机构专业
  • 网站防红链接怎么做网站建设中提示页面
  • 网站开发和游戏开发的区别互联网服务平台投诉
  • 杭州定制网站公司出名的设计网站
  • 网站查询访问注册电气工程师考试
  • 北京企业网站推广哪家公司好电商平台代运营
  • 北京快速建站模板信息管理系统网站开发
  • 做网站后台需要写代码吗做网站收多少钱