三维异面直线的距离和垂足求解

在论文中遇到了求解三维异面直线的距离和垂足的问题,网上资源参差不齐,遂把它记录下来,万一你也用得上呢

本文参考自:求3维度空间异面直线的垂足点

在此基础上做了更详细的论述、扩展和python实现

题设:假设有两条直线 L1,L2 ,以及两条直线的方向向量V1,V2,求其最短距离及其垂足。

直接求距离

对于最短距离,也即两异面直线公垂线的长度,有一个方便快捷的求解方法,选择L1上任意一点P1连接L2上任意一点P2,则线段P1P2在L1,L2的公垂线上的投影即是长度,共垂线可以通过方向向量叉乘得到(注意两直线平行时,该方法无法得到距离),下面为python求解代码:

def distace_3d(p1, p2, q1, q2):
    # 叉乘方法计算三维异面直线距离
    
    # p1,p2为L1上的两个节点,q1,q2为L2上的两个节点
    v1 = np.array([p2[i] - p1[i] for i in range(len(p1))])
    v2 = np.array([q2[i] - q1[i] for i in range(len(q1))])
    
    # 叉乘公式:(a1,a2,a3) X (b1,b2,b3)=(a2b3-a3b2,a3b1-a1b3,a1b2-a2b1)
    chacheng = np.array([v1[1]*v2[2]-v1[2]*v2[1],v1[2]*v2[0]-v1[0]*v2[2],v1[0]*v2[1]-v1[1]*v2[0]])
    segment = np.array([p1[i] - q1[i] for i in range(len(p1))])
    dis = abs(sum(chacheng*segment)) / math.sqrt(sum([chacheng[i]**2 for i in range(len(chacheng))]))
    return dis
求垂足加距离

异面直线共垂线的垂足点求解,就没有上面那么容易了,基本思路如下:

因为直线的定义可以给出如下直线方程
L ( t ) = P + t ∗ V L(t) = P + t*V L(t)=P+tV

则在L1和L2上分别选择任意的p1,p2,以及对应的t1,t2,得到的 L 1 ( t 1 ) , L 2 ( t 2 ) L1(t1),L2(t2) L1(t1),L2(t2),有如下等式
L 1 ( t 1 ) = P 1 + t 1 ∗ V 1 − − − − − − − − − − − − − − − − − − − − − − − − − − ( 1 ) L1(t1) = P1 + t1*V1--------------------------(1) L1(t1)=P1+t1V1

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

海晨威

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值