码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 两个三位电云获取旋转矩阵


    计算的python代码如下
    
    def rigid_transform_3D(A, B, scale=False):
        assert A.shape == B.shape
    
        num_rows, num_cols = A.shape
        if num_rows != 3:
            A = A.transpose()
            num_rows, num_cols = A.shape
            if num_rows != 3:
                raise Exception(f"matrix A is not 3xN, it is {num_rows}x{num_cols}")
    
        num_rows, num_cols = B.shape
        if num_rows != 3:
            B = B.transpose()
            num_rows, num_cols = B.shape
            if num_rows != 3:
                raise Exception(f"matrix B is not 3xN, it is {num_rows}x{num_cols}")
    
    
        centroid_A = np.mean(A, axis=1)
        centroid_B = np.mean(B, axis=1)
        centroid_A = centroid_A.reshape(-1, 1)
        centroid_B = centroid_B.reshape(-1, 1)
        # subtract mean
        Am = A.copy() - centroid_A
        Bm = B.copy() - centroid_B
    
        if scale:
            scale = np.std(Bm) / np.std(Am)
            A = A * scale
        else:
            scale = -1
    
        # find mean column wise
        centroid_A = np.mean(A, axis=1)
        centroid_B = np.mean(B, axis=1)
    
        # import pdb
        # pdb.set_trace()
    
        # ensure centroids are 3x1
        centroid_A = centroid_A.reshape(-1, 1)
        centroid_B = centroid_B.reshape(-1, 1)
    
        # subtract mean
        Am = A - centroid_A
        Bm = B - centroid_B
    
        H = Am @ np.transpose(Bm)
    
        # sanity check
        #if linalg.matrix_rank(H) < 3:
        #    raise ValueError("rank of H = {}, expecting 3".format(linalg.matrix_rank(H)))
    
        # find rotation
        U, S, Vt = np.linalg.svd(H)
        R = Vt.T @ U.T
    
        # special reflection case
        if np.linalg.det(R) < 0:
            print("det(R) < R, reflection detected!, correcting for it ...")
            Vt[2,:] *= -1
            R = Vt.T @ U.T
    
        t = -R @ centroid_A + centroid_B
    
        if scale > 0:
            return R, t, scale
        else:
            return R, t
    

  • 相关阅读:
    解决 viteprees 中 vp-doc 内置样式影响组件预
    IDEA中创建Java Web项目方法2
    JAVA 相关书籍推荐(全)
    手动部署LNMP环境(Ubuntu 20)
    使用docker安装本地pdf工具集合Stirling-PDF
    针孔相机模型原理&坐标系辨析&内参标定流程&内参变换
    前端飞机大战小游戏
    嵌入式人工智能入门:深度学习模型的部署与优化
    【Qt】QGroundControl入门3:源码初探
    一、PostgreSQL软件安装
  • 原文地址:https://blog.csdn.net/chenguowen21/article/details/126367809
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号