Python Sympy:优雅解决动态直线交点的实时追踪

最近在做一个数学的动画时,遇到一个需求。

简单来说,就是一个直线 l 1 l_1 l1在移动时,它与另一个直线 l 2 l_2 l2的交点如何定位?

制作动画的时候,当直线 l 1 l_1 l1移动时,需要不断重新计算它与 l 2 l_2 l2的新交点,然后在动画中渲染出来。

1. 问题描述

任意点 A A A和 B B B确定一条直线 l 1 l_1 l1,点 C C C和 D D D确定一条直线 l 2 l_2 l2。

两直线的交点 O O O。

当点 B B B移动时,动态绘制交点 O O O的变化。

2. 解决方法

解决的思路不难,首先计算交点 O O O的坐标,

1-1. 根据点 A ( x 1 , y 1 ) A(x_1, y_1) A(x1,y1)和点 B ( x 2 , y 2 ) B(x_2, y_2) B(x2,y2)可以计算出直线 l 1 l_1 l1的方程( y = k 1 x + b 1 y = k_1x+b_1 y=k1x+b1)

1-2. 根据点 C ( x 3 , y 3 ) C(x_3, y_3) C(x3,y3)和点 D ( x 4 , y 4 ) D(x_4, y_4) D(x4,y4)可以计算出直线 l 2 l_2 l2的方程( y = k 2 x + b 2 y = k_2x+b_2 y=k2x+b2)

1-3. 根据 l 1 l_1 l1的方程和 l 2 l_2 l2的方程可以计算出点 O O O的坐标

当点 B B B不断变化时:

2-1. 根据点 A A A和不断变化的点 B B B重新计算 l 1 l_1 l1的方程( y = k 1 x + b 1 y = k_1x+b_1 y=k1x+b1)

2-2. 根据 l 1 l_1 l1和 l 2 l_2 l2的方程不断重新计算点 O O O的坐标

这里麻烦的地方 在于需要推导出下面2个公式,然后用代码来实现:

  1. 根据两个点的坐标推导出直线方程中的斜率 k k k和截距 b b b
  2. 根据两条直线的方程推导出交点坐标

如果用Python Sympy库的话,那么一下就简单很多了。

2.1. 两点坐标求直线

根据两点坐标推导出直线斜率 k k k和截距 b b b:

python 复制代码
from sympy import Symbol, solve

def get_line(p1, p2):
    k = Symbol("k")
    b = Symbol("b")

    # 代入点p1坐标
    expr1 = p1[0] * k + b - p1[1]
    # 代入点p2坐标
    expr2 = p2[0] * k + b - p2[1]

    ret = solve((expr1, expr2), dict=True)
    return {"k": ret[0][k], "b": ret[0][b]}

2.2. 两条直线求交点

根据两条直线的斜率 k k k和截距 b b b推导交点的坐标:

python 复制代码
def cross_point(l1, l2):
    x = Symbol("x")
    y = Symbol("y")

    # 直线l1的方程
    expr1 = l1["k"] * x + l1["b"] - y
    # 直线l2的方程
    expr2 = l2["k"] * x + l2["b"] - y
    ret = solve((expr1, expr2), dict=True)

    return np.array((float(ret[0][x]), float(ret[0][y]), 0))

2.3. 实现效果

利用上面两个函数,可以很容易得到两条直线交点的坐标,渲染后的效果如下:

3. 总结

利用Sympy带来的最大便利 在于不需要推导公式,只要列出方程,交由Sympy去推导结果即可。

这样,我们在编写一些几何方面的运算时,并不需要了解多少数学的知识,也不用去记住那些求根公式等等。

同时,也可以大大简化代码,比如上面示例中封装的两个函数(get_linecross_point),

可以看出,不仅实现的代码很简短,可读性也提高很多,几乎不需要多少数学知识就能看懂。

相关推荐
aqi004 分钟前
15天学会AI应用开发(三)把历史对话作为提示词会怎样
人工智能·python·大模型·ai编程·ai应用
大数据魔法师4 分钟前
Streamlit(十八)- API 参考文档(十一)- 页面导航组件
python·web
weixin_4684668510 分钟前
数据高效处理实战:从痛点解决到价值落地
大数据·python·自动化·数据处理
hui函数29 分钟前
Python系列Bug修复|如何解决 pip install 报错 ModuleNotFoundError: No module named ‘pygame’ 问题
python·bug·pip
xcLeigh30 分钟前
Python入门:Python3 operator模块全面学习教程
开发语言·python·学习·教程·python3·operator
xcLeigh30 分钟前
Python小游戏实战:实现2048游戏小游戏附源码
python·游戏·教程·pygame·2048·python3
大叔带刺32 分钟前
使用python创建自己的专属星座签名APP:Name2Constell
开发语言·python·pygame
weixin_468466851 小时前
Markitdown 文档解析快速入门指南
开发语言·python·自动化·编程
我材不敲代码1 小时前
Python基础:注释的写法(单行、多行、文档注释)
服务器·python·microsoft