- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有两条位于同一平面上的 3D 线。 line1
由一个点 (x1, y1, z1
) 及其方向 vector (a1, b1, c1
) 定义,而 line2
由一个点 (x2, y2, z2
) 及其方向 vector (a2, b2, c2
) 定义。那么两条直线的参数方程为
x = x1 + a1*t; x = x2 + a2*s;
y = y1 + b1*t; y = y2 + b2*s;
z = z1 + c1*t; z = z2 + c2*s;
如果两个方向 vector 都不为零,我们可以很容易地找到相交节点的位置,方法是使上面等式的右边相等并求解t
和s
来自三个中的两个。但是,a1 b1 c1 a2 b2 c2
可能并非全为非零,因此我无法以相同的方式求解这些方程。我目前的想法是逐案处理这个问题,比如
case1: a1 = 0, others are nonzero
case2: a2 = 0, others are nonzero
case3: b1 = 0, others are nonzero
...
但是这样一来案例太多了,实现起来会很乱。有什么好的方法可以解决这个问题吗?任何引用?非常感谢!
最佳答案
将其视为 vector 方程更为实用。点 .
是标量积,A,n,B,m
是描述直线的 vector 。点 A
位于方向 n
的第一条线上。方向已标准化:n.n=1
和 m.m=1
。交点 C
是这样的:
C=A+nt=B+ms
其中 t
和 s
是要计算的标量参数。
因此 (.n) :
A.n+ t=B.n+m.n s
t= (B-A).n+m.n s
和(.m):
A.m+n.m t=B.m+ s
A.m+n.m (B-A).n+(m.n)^2 s=B.m+ s
n.m(B-A).n+(A-B).m=(1-(m.n)^2).s
由于 n.n=m.m=1 并且 n 和 m 没有对齐,(m.n)^2<1 :
s=[n.m(B-A).n+(A-B).m]/[1-(m.n)^2]
t= (B-A).n+m.n s
关于c - 如何找出C中两条共面线的交点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22544492/
我创建了一个函数来计算两条线段的交点。 不幸的是,如果其中一个段是垂直的,下面的代码将不起作用 public static Point intersection(Segment s1, Seg
我有一个由中心 (x,y,z)、半径和方向矢量定义的圆,该矢量指定圆的朝向。我需要测试这样的圆是否与轴对齐的边界框相交。为了澄清,通过相交,我的意思是如果圆圈描述的区域内的任何点在边界框内,那么就构成
虽然我认为这是一个基本问题,但我似乎无法找到如何在 R 中计算: 2 个或多个正态分布(拟合在直方图上)的交点(我需要 x 值),例如具有以下参数: d=data.frame(mod=c(1,2),m
我看过几个关于找到两个 OBB 之间的交点的线程。我仍然不明白如何找到最小穿透轴。我需要找到最小穿透轴,我相信它在 David Eberly 的论文中也被称为最后一个分离轴,以确定我应该使用表格的哪一
我想使用 intersection()通过 key 或filter()在 Spark 。 但是我真的不知道怎么用intersection()按键。 所以我尝试使用filter() ,但它不起作用。 示
我正在画一个circle在canvas上。我想知道,给定 circle 的半径和原点 x/y ,在什么时候 circle与 canvas 相交(如果有的话)边缘。 这肯定是一个几何问题,但这部分似乎太
我正在尝试计算任意数量平面的最顶部交点,但没有任何乐趣!我正在使用 actionscript,但只需要找到一个我可以实现的算法。 问题: 考虑 3 个垂直轴。 用户为每个三角形/平面输入 3 个点,使
我是一名优秀的程序员,十分优秀!