2

我正在尝试从共享相同来源的 3d 空间中的许多段创建二叉树。合并两个线段时,我希望线与子节点之间有一个特定的角度。下图说明了我的问题。C 显示父节点的位置,A 和 B 显示子节点的位置。N 是从 C 到 A 和 C 到 B 的向量的平均向量。

三角形

给定角度,如何确定点 P?谢谢你的帮助

4

2 回答 2

3
P = C + t * ((A + B)/2 - C)    t is unknown parameter
PA = A - P                     PA vector 
PB = B - P                     PB vector
Tan(Fi) = (PA x PB) / (PA * PB)    (cross product in the nominator, scalar product in the denominator)
Tan(Fi) * (PA.x*PB.x + PA.y*PB.y) = (PA.x*PB.y - PA.y*PB.x)

这是 t 的二次方程,求解后我们将得到 P 点的两个(对于非退化情况)可能的位置(第二个位于 AB 线的另一侧)

添加:

Let's ax = A.x  - A point X-coordinate and so on,
abcx = (ax+bx)/2-cx, abcy = (ay+by)/2-cy
pax = ax-cx - t*abcx, pay = ay-cy - t*abcy
pbx = bx-cx - t*abcx, pby = by-cy - t*abcy
ff = Tan(Fi) , then
ff*(pax*pbx+pay*pby)-pax*pby+pay*pbx=0
ff*((ax-cx - t*abcx)*(bx-cx - t*abcx)+(ay-cy - t*abcy)*(by-cy - t*abcy)) -
 - (ax-cx - t*abcx)*(by-cy - t*abcy) + (ay-cy - t*abcy)*(bx-cx - t*abcx) = 

 t^2 *(ff*(abcx^2+abcy^2)) + 
 t *  (-2*ff*(abcx^2+abcy^2) + abcx*(by-ay) + abcy*(ax-bx) ) +
      (ff*((ax-cx)*(bx-cx)+(ay-cy)*(by-cy)) - (ax-cx)*(by-cy)+(bx-cx)*(ay-cy)) =0     

AA*t^2 + BB*t + CC = 0 这是具有系数的二次方程

AA = ff*(abcx^2+abcy^2)
BB = -2*ff*(abcx^2+abcy^2) + abcx*(by-ay) + abcy*(ax-bx)
CC = ff*((ax-cx)*(bx-cx)+(ay-cy)*(by-cy)) - (ax-cx)*(by-cy)+(bx-cx)*(ay-cy) 

PS我的答案是2d案例!

对于 3d:仅使用标量积可能更简单(使用向量长度)

Cos(Fi) = (PA * PB) / (|PA| * |PB|)
于 2013-09-18T15:19:41.427 回答
2

另一种解决方案是对向量N使用二进制搜索P是否接近C则角度会更小,P是否远离C则角度会更大,适合二进制搜索。

于 2013-09-19T07:00:26.820 回答