MATLAB爱好者论坛-LabFans.com

MATLAB爱好者论坛-LabFans.com (https://www.labfans.com/bbs/index.php)
-   资料存档 (https://www.labfans.com/bbs/forumdisplay.php?f=72)
-   -   根据点和法线识别边缘 (https://www.labfans.com/bbs/showthread.php?t=23789)

poster 2019-12-10 20:48

根据点和法线识别边缘
 
我在基于相对法线对点进行分类时遇到了一些问题。我想做的是使用下面获得的信息将简化的多边形拟合到这些点,并在一定程度上偏向90度角。

我对每个点都有粗略的(虽然不是很准确)法线,但是我不确定如何根据点的接近度和法线的接近度来分离数据库。我计划在将每个面的点分块后进行线性回归,因为法线有时与实际面不太吻合(尽管每个面彼此接近)

[B]示例:[/B] [URL="http://a.imageshack.us/img842/8439/ptnormals.png"]替代文字http://a.imageshack.us/img842/8439/ptnormals.png[/URL]

理想情况下,我希望能够在此数据周围安装一个矩形。但是,多边形不必是凸面的,也不必与轴对齐。

关于如何实现这样的目标的任何提示都会很棒。

提前致谢



[B]回答:[/B]

我会尝试以下
[LIST=1][*]根据接近度和相似角度对点进行聚类。我将使用单链接层次聚类(在Matlab中为[URL="http://www.mathworks.com/access/helpdesk/help/toolbox/stats/linkage.html"]LINKAGE[/URL] ),因为您不知道[I]先验[/I]会有多少条边。单连接有利于线性结构,这正是您要寻找的。作为两点之间的距离标准,您可以使用点坐标之间的欧几里得距离乘以角度的函数,只要角度相差超过20度或30度,该角度就会急剧增加。[*]对数据进行(稳健)线性回归。使用法线可能有帮助,也可能没有帮助。我的猜测是他们不会提供太多帮助。为简单起见,您可能最初想忽略法线。[*]找到线之间的交点。[*]如有必要,您始终可以尝试提高拟合度,例如通过将相反的线约束为平行。[/LIST]如果失败,您可以尝试在[URL="http://portal.acm.org/citation.cfm?id=279014"]THIS PAPER中[/URL]实施该方法,该方法允许一次拟合多条直线。



[url=https://stackoverflow.com/questions/3489452]更多&回答...[/url]


所有时间均为北京时间。现在的时间是 01:09

Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.