博客
关于我
基于OpenCV的透视图转化为不同平面
阅读量:329 次
发布时间:2019-03-04

本文共 2850 字,大约阅读时间需要 9 分钟。

??????????????????????????????????????????????????????????????????????????????????????????????????

???????????????????????????????????????????????????????????????

??????????????????????????????????????????????????????2D???????????????????????????

?????????3D???????????????????????????????????????????????????????????????????????????

????????????????3D???????2D????????????3D????3x4????????????2D???

?????3x4???????3D???????x?y?z????2D??????????u?v??????????2D???????3D??????????????z=0??

????

  • ???????

    ????????z????????????????????z??????3x4???????3x3????????????????????????????????????

  • ??????

    ??????????????????????????????????????????????????????????u?v????????????x?y???OpenCV??????cv2.findHomography??????????

  • ????

    import cv2import numpy as npdef get_inverse_perspective(perspective_matrix: np.array) -> np.array:    """ This method calculates the inverse of perspective matrix by homography. """    # Take 5 homogeneous points on the floor plane (Unit is in Meters)    pts_dst = np.array([[0, 0, 0, 1],                        [0, 1, 0, 1],                        [1, 0, 0, 1],                        [1, 1, 0, 1],                        [0, 0, 0, 1]])        # Obtain respective homogeneous points on the image plane    pts_src = (perspective_matrix @ pts_dst.T).T    # Convert homogeneous coordinates to Cartesian coordinates    pts_src_cart = np.array([[x/w, y/w] for x, y, w in pts_src])    pts_dst_cart = np.array([[x/w, y/w] for x, y, z, w in pts_dst])        # Find the 3x3 Homography Matrix for transforming image plane to floorplane    H, status = cv2.findHomography(pts_src_cart, pts_dst_cart)    return Hdef project_to_floor(image_coordinates: List[int], H: np.array) -> List[int]:    """ This method takes the Homography matrix and the 2D image Cartesian coordinates.     It returns the (x, y) Cartesian coordinates in 3D world coordinates on floorplane (z=0). """    # Adding 1 for homogeneous coordinate system    x, y, w = H @ np.array([[*image_coordinates, 1]]).T    return [x/w, y/w]# Example usagep = np.random.rand(3, 4)H = get_inverse_perspective(p)src_point = (5, 10)dst_point = project_to_floor(src_point, H)

    ????

  • ?????????

    ???????z=0???????z??????3x4???????3x3???????????

  • ????

    ???????????????????????????????4?????

  • OpenCV??

    ?OpenCV??????cv2.findHomography??????????

  • ????????????2D????????????3D????????????

    ????

  • OpenCV-Contrib?????????

    ???????????????????????????????????OpenCV???????????????????SFM????????????????????????????????

  • Python??????52?

    ????????????????Python???????????????????????????????????????????????????????????????????31????????????????????

  • OpenCV????20?

    ????????????????OpenCV????20?????????20???OpenCV????????????OpenCV???

  • ??????????????????SLAM??????????????????????????????????GAN???????????????????????????+??/??+???????????? ???? ??SLAM????????????????????????????????????????????????????????????~

    转载地址:http://yyaq.baihongyu.com/

    你可能感兴趣的文章
    NO.23 ZenTaoPHP目录结构
    查看>>
    NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
    查看>>
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>
    Node-RED中使用node-random节点来实现随机数在折线图中显示
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node.js 8 中的 util.promisify的详解
    查看>>
    Node.js 函数是什么样的?
    查看>>
    Node.js 历史
    查看>>
    Node.js 在个推的微服务实践:基于容器的一站式命令行工具链
    查看>>
    Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
    查看>>
    node.js 怎么新建一个站点端口
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>
    Node.js 的事件循环(Event Loop)详解
    查看>>
    node.js 简易聊天室
    查看>>