- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有两条线段:X1,Y1,Z1 - X2,Y2,Z2 和 X3,Y3,Z3 - X4,Y4,Z4
我试图找到两个线段之间的最短距离。
几个小时以来,我一直在寻找解决方案,但所有这些解决方案似乎都适用于线而不是线段。
关于如何解决这个问题的任何想法,或任何 furmulae 的来源?
最佳答案
我会用 matlab 来回答这个问题,但也可以使用其他编程环境。我要补充一点,此解决方案可有效解决任意数量维度 (>= 3) 的问题。
假设我们在空间中有两条线段,PQ 和 RS。这里有一些随机的点集。
> P = randn(1,3)
P =
-0.43256 -1.6656 0.12533
> Q = randn(1,3)
Q =
0.28768 -1.1465 1.1909
> R = randn(1,3)
R =
1.1892 -0.037633 0.32729
> S = randn(1,3)
S =
0.17464 -0.18671 0.72579
无限直线 PQ(t) 很容易定义为
PQ(u) = P + u*(Q-P)
同样,我们有
RS(v) = R + v*(S-R)
看到对于每一行,当参数为 0 或 1 时,我们得到返回行上的原始端点之一。因此,我们知道 PQ(0) == P,PQ(1) == Q,RS(0) == R,RS(1) == S。
这种参数化定义直线的方式在许多情况下都非常有用。
接下来,假设我们沿着 PQ 线向下看。我们能找到从线段RS到无限直线PQ的距离最小的点吗?这最容易通过投影到线 PQ 的零空间来完成。
> N = null(P-Q)
N =
-0.37428 -0.76828
0.9078 -0.18927
-0.18927 0.61149
因此,null(P-Q) 是一对跨越与直线 PQ 正交的二维子空间的基向量。
> r = (R-P)*N
r =
0.83265 -1.4306
> s = (S-P)*N
s =
1.0016 -0.37923
本质上,我们所做的是将向量 RS 投影到与直线 PQ 正交的二维子空间(平面)中。通过减去 P(直线 PQ 上的一个点)得到 r 和 s,我们确保无限直线通过该投影平面中的原点。
实际上,我们已经将其简化为找到投影平面中从线 rs(v) 到原点 (0,0) 的最小距离。回想一下,rs(v) 行由参数 v 定义为:
rs(v) = r + v*(s-r)
线 rs(v) 的法向量将为我们提供我们所需要的。由于原始空间是 3 维的,因此我们已将其降低为 2 维,因此我们可以简单地做到这一点。否则,我只会再次使用 null。这个小技巧适用于二维:
> n = (s - r)*[0 -1;1 0];
> n = n/norm(n);
n 现在是一个具有单位长度的向量。无限直线rs(v)到原点的距离很简单。
> d = dot(n,r)
d =
1.0491
看到我也可以使用 s 来获得相同的距离。实际距离是 abs(d),但事实证明,这里的 d 无论如何都是正的。
> d = dot(n,s)
d =
1.0491
我们可以由此确定v吗?是的。回想一下,原点距离连接点 r 和 s 的直线有 d 个单位的距离。因此我们可以写 dn = r + v(s-r),对于标量 v 的某个值。用向量 (s-r) 形成这个等式每边的点积,并求解 v .
> v = dot(s-r,d*n-r)/dot(s-r,s-r)
v =
1.2024
这告诉我们,线段 rs 最接近原点的位置发生在线段端点之外。所以实际上 rs 上离原点最近的点是点 rs(1) = s。
从投影中退出,这告诉我们线段 RS 上离无限直线 PQ 最近的点是点 S。
分析中还有一步要走。线段 PQ 上最近的点是什么?这个点是落在线段内,还是落在端点之外?
我们将点 S 投影到直线 PQ 上。 (u 的这个表达式很容易从与我之前所做的类似逻辑中导出。请注意,这里我使用\来完成这项工作。)
> u = (Q-P)'\((S - (S*N)*N') - P)'
u =
0.95903
看到 u 位于区间 [0,1] 内。我们已经解决了这个问题。 PQ线上的点是
> P + u*(Q-P)
ans =
0.25817 -1.1677 1.1473
并且,两条线段上最近点之间的距离为
> norm(P + u*(Q-P) - S)
ans =
1.071
当然,所有这些都可以压缩成短短的几行代码。但它有助于将其全部扩展以了解其工作原理。
关于algorithm - 计算3D中两条线(线段)之间的最短距离,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/627563/
有没有办法将多个线段视为 1 条线? IE:我将鼠标悬停在其中一个上,两者都会突出显示,并且切换图例中的可见性将隐藏这两个部分。 http://jsfiddle.net/rayholland/HSvB
有没有办法将多条线段视为一条线? IE:我将鼠标悬停在一个上,两个都突出显示,切换图例中的可见性将隐藏两个部分。 http://jsfiddle.net/rayholland/HSvBj/2/ ser
我正在尝试解决有关使用箭头键绘制线条的练习。当按下任一箭头键时,该线从中心开始向东、西、北或南绘制。该代码仅在东或西方向有效,而在北或南方向无效,这是我的问题!! 有人可以给我关于这件事的想法吗?谢谢
给定每条线的起点和终点的 XYZ 坐标,如何确定两条 3D 线段是否相交?如果它们确实相交,在什么 XYZ 位置? 我只能找到 2D 的答案:How do you detect where two l
给定每条线的起点和终点的 XYZ 坐标,如何确定两条 3D 线段是否相交?如果它们确实相交,在什么 XYZ 位置? 我只能找到 2D 的答案:How do you detect where two l
我正在使用适用于 ios 的 google map sdk 来提供当前用户位置和结束位置之间的方向。到目前为止,我已经使用下面的代码在当前用户位置和结束位置之间绘制了一条 GMSPolyline,并且
我是 Qt 的新手,我想使用 Qt 使用 CGAL 制作交互式几何程序。我希望用户使用鼠标输入点、线段,然后按下按钮让 CGAL 算法处理输入。 我的环境是 CGAL 4.5、Qt 5.6 和 QtC
我有两条线段:X1,Y1,Z1 - X2,Y2,Z2 和 X3,Y3,Z3 - X4,Y4,Z4 我试图找到两个线段之间的最短距离。 几个小时以来,我一直在寻找解决方案,但所有这些解决方案似乎都适用于
我正在尝试在 WPF 中创建铁路轨道和带有边界和标签的街道等效果。如何向线段添加边框和沿线段的标签?我试过 Border 类,但它创建了一个矩形边框。 对于标签,我尝试了 Text on a path
我正在做一个小项目来显示基于路线段重叠的路线效率低下。 例如,我在这里放了一个 JSFIDDLE,显示 D 和 E 之间有一条粉红色和蓝色的线重叠。我如何确定这段路在它们的路线上有重叠? 路线将由用户
我想绘制三组数据。具体来说,我想显示单个数据点,包括三组的均值。这是我到目前为止所拥有的: library(ggplot2) df <- data.frame(group=rep(c("A", "B"
我想绘制三组数据。具体来说,我想显示单个数据点,包括三组的均值。这是我到目前为止所拥有的: library(ggplot2) df <- data.frame(group=rep(c("A", "B"
<line> 元素可以用来画线段 SVG 线段 <line> <line> 元素可以用来画线段 线段的起始坐标可以用 x1 和 y1 来定义 线段的终点坐标可
我正在我的游戏中编写 C++ 碰撞检测程序,并试图提出一种算法:我有一个由两个中心点(C1、C2)、长度和半径定义的胶囊。然后我有一条用两点(R1,R2)定义的射线。我已经知道它们相交了。我只需要找到
我正在创建一个包含多变量数据的 PCA 双图。 有没有办法在 ggbiplot 中指定线段的颜色/透明度/位置?此命令的所有参数均未提供此选项。 我知道 ggbiplot 是基于 ggplot - 它
最近学了下 python opencv,分享下使用 opencv 在图片上绘制常用图形的方法。 案例中实现了在图片中添加线段、圆形、矩形、椭圆形以及添加文字的方法,使用 opencv2 实现的
我在应用 rgl 3d 绘图包时遇到了一些问题。 我正在尝试绘制一些线段。我的数据被安排在一个名为“标记”的数据框中,它有六列,一列代表起始 x、y 和 z 值,一列代表结束 x、y 和 z 值。 s
我必须使用 matplotlib 库绘制多条“曲线”,每条曲线由水平线段(甚至点)组成。 我通过 NaNs 分隔片段达到了这个目标。这是我的示例(工作)代码: from pylab import ar
我是一名优秀的程序员,十分优秀!