计算点云每个点的梯度(附open3d python代码)

计算每个点的梯度
通过查找曲面上的法向量和点来开始查找点的梯度
点和周围点的最佳拟合平面。对法向量进行归一化,然后计算指定方向的斜率


如果“axisxyz”输入为“z”,则检查法线的z坐标。如果值为负值,则整个
法向量乘以-1,使z坐标为正。然后通过以下公式计算坡度:
斜率=sqrt(x**2+y**2)
如果“axisxyz”输入为“x”,则检查法线的x坐标。如果值为负值,则整个
法向量乘以-1,使x坐标为正。然后通过以下公式计算坡度:
斜率=sqrt(y**2+z**2)
如果“axisxyz”输入为“y”,则检查法线的y坐标。如果值为负值,则整个
法向量乘以-1,使y坐标为正。然后通过以下公式计算坡度:
斜率=sqrt(x**2+z**2)
如果“axisxyz”未输入为“x”、“y”或“z”,则函数将引发异常“axisxyz must be x,y,or z”。


# coding:utf-8
import open3d as o3d
import numpy as np
from numpy.linalg import norm
from numpy.linalg import svd


def planeFit(points):
    """
    p, n = planeFit(points)

    Given an array, points, of shape (d,...)
    representing points in d-dimensional space,
    fit an d-dimensional plane to the points.
    Return a point, p, on the plane (the 
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

点云-激光雷达-Slam-三维牙齿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值