![]() |
根据点和法线识别边缘
我在基于相对法线对点进行分类时遇到了一些问题。我想做的是使用下面获得的信息将简化的多边形拟合到这些点,并在一定程度上偏向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.