当前位置: 首页 > news >正文

平面与平面相交算法杂谈

1.前言

空间平面方程:

空间两平面如果不平行,那么一定相交于一条空间直线,

空间平面求交有多种方法,本文进行相关讨论。

2.讨论 

可以联立方程组求解,共有3个变量,2个方程,而所求直线有1个变量,直线方程为,

2.1.方法一:联立方程求解

通过如下链接中方法可得到所交直线方程,

analytic geometry - How to calculate the intersection of two planes? - Mathematics Stack Exchangehttps://math.stackexchange.com/questions/475953/how-to-calculate-the-intersection-of-two-planes Planes intersection calculatorhttp://www.ambrnet.com/TrigoCalc/Plan3D/Plane3D_.htm

化为直线参数方程:

 这种方法有其局限性,上述公式的分母可能为0,就需要比较繁杂的处理,如令x=t,重新求解。斯坦福官网中的关于Plane类实现的资料中对于面面相交(plane intersect plane)也没有实现该情况的处理,

bool Plane::PlanePlaneIntersection(const Plane &P1, const Plane &P2, Line3D &L)
{float Denominator = P1.a * P2.b - P1.b * P2.a;if(Denominator == 0.0f){// this case should be handled by switching axes...return false;}L.P0 = Vec3f((P2.d * P1.b - P1.d * P2.b) / Denominator, (P1.d * P2.a - P2.d * P1.a) / Denominator, 0.0f);L.D = Vec3f::Cross(P1.Normal(), P2.Normal());if(L.D.Length() == 0.0f){return false;}L.D = Vec3f::Normalize(L.D);return true;
}

Plane.cpp

2.2.方法二:正交平面辅助求解

三维坐标系中三个正交平面为XOY、YOZ、ZOX平面,只要空间平面不与某正交平面(如XOY平面)平行,那么一定有交线,且线上有一点,其Z坐标为0(如果选用了XOY平面),这样将z=0带入平面方程组,求解,此方法和上述方法一本质上是一样的。在方法一中对应的方式是令z=t。

可参考如下实现,和方法一类似,同样需要一些特殊处理,

空间平面相交的直线的计算及其源码_平面的交线计算原理-CSDN博客

2.3.方法三:构造第三平面

两平面法向叉乘可得交线方向,过某点(如平面1上的点或平面2上的点)以其为法向构造第三平面,三平面交于一点(如果平面1和平面2不平行),求该点作为交线上的点。

可直接套用公式,

Plane-Plane Intersection -- from Wolfram MathWorld

Hessian Normal Form -- from Wolfram MathWorld

Intersects of 3 planes_intersectplanes(plane p1, plane p2, plane p3)-CSDN博客

注意构造的第三平面可以过特定点,这样得到的交线上的点距离该特定点最近。

2.4.方法四:几何法

  1. 求plane1上点到plane2的距离;
  2. 求2个plane的夹角;
  3. 根据夹角求asin得到disExpand;
  4. ptOnPlane1沿dirOffset偏移disExpand得到交线上点;

这种方法得到的点距离点ptOnPlane1最近。

此方法对于需要以距离特定点最近的点来表示直线的情况比较实用,毕竟如果直线上的点非常远时,由于浮点存储机制所带来的精度误差会带来负面影响。

3.精度

一般情况下,公式简洁有效,计算逻辑简单,精度就比较高,当然不是绝对的,也与所选参数的情况、运算过程的主动精度损失等有关系,需要根据具体情况进行精度的分析和测试。

相关文章:

平面与平面相交算法杂谈

1.前言 空间平面方程: 空间两平面如果不平行,那么一定相交于一条空间直线, 空间平面求交有多种方法,本文进行相关讨论。 2.讨论 可以联立方程组求解,共有3个变量,2个方程,而所求直线有1个变量…...

web集群(LVS-DR)

LVS是Linux Virtual Server的简称,也就是Linux虚拟服务器, 是一个由章文嵩博士发起的自由软件项 目,它的官方站点是 www.linuxvirtualserver.org。现在LVS已经是 Linux标准内核的一部分,在 Linux2.4内核以前,使用LVS时必须要重新编…...

更高效实用 vscode 的常用设置

VSCode 可以说是文本编辑神器, 不止程序员使用, 普通人用其作为文本编辑工具, 更是效率翻倍. 这里分享博主对于 VSCode 的好用设置, 让 VSCode 如虎添翼 进入设置 首先进入设置界面, 后续都在这里进行配置修改 具体设置 每项配置通过搜索关键字, 来快速定位配置项 自动保存…...

win11 终端乱码导致IDE 各种输出也乱码

因为 win11 终端乱码导致IDE 各种输出也乱码导致作者对此十分头大。所以研究了各种方法。 单独设置终端编码对 HKEY_CURRENT_USER\Console 注册表进行修改对 HKEY_LOCAL_MACHINE\Software\Microsoft\Command Processo 注册表进行修改使用命令[Console]::OutputEncoding [Syst…...

对于简单的HTML、CSS、JavaScript前端,我们可以通过几种方式连接后端

1. 使用Fetch API发送HTTP请求(最简单的方式): //home.html // 示例:提交表单数据到后端 const submitForm async (formData) > {try {const response await fetch(http://your-backend-url/api/submit, {method: POST,head…...

Flutter中 List列表中移除特定元素

在 Dart 语言里,若要从子列表中移除特定元素,可以使用以下几种方法,下面为你详细介绍: 方法一:使用 where 方法创建新列表 where 方法会根据指定的条件筛选元素,然后通过 toList 方法将筛选结果转换为新列…...

DeepSeek从入门到精通(清华大学)

​ DeepSeek是一款融合自然语言处理与深度学习技术的全能型AI助手,具备知识问答、数据分析、编程辅助、创意生成等多项核心能力。作为多模态智能系统,它不仅支持文本交互,还可处理文件、图像、代码等多种格式输入,其知识库更新至2…...

动态规划:解决复杂问题的高效策略

动态规划(Dynamic Programming,简称 DP)是一种在数学、管理科学、经济学、计算机科学等领域中广泛使用的算法设计技术。它通过将复杂问题分解为更简单的子问题,并通过存储子问题的解来避免重复计算,从而高效地解决问题…...

【kafka系列】Kafka事务的实现原理

目录 1. 事务核心组件 1.1 幂等性生产者(Idempotent Producer) 1.2 事务协调器(TransactionCoordinator) 1.3 事务日志(Transaction Log) 2. 事务执行流程 2.1 事务初始化 2.2 发送消息 2.3 事务提…...

网络将内网服务转换到公网上

当然,以下是根据您提供的描述,对内网端口在公网上转换过程的详细步骤,并附上具体例子进行说明: 内网端口在公网上的转换过程详细步骤 1. 内网服务配置 步骤说明: 在内网中的某台计算机(我们称之为“内网…...

c#自动更新-源码

软件维护与升级 修复漏洞和缺陷:软件在使用过程中可能会发现各种漏洞和缺陷,自动更新可以及时推送修复程序,增强软件的稳定性和安全性,避免因漏洞被利用而导致数据泄露、系统崩溃等问题。提升性能:通过自动更新&#x…...

爬虫实战:利用代理ip爬取推特网站数据

引言 亮数据-网络IP代理及全网数据一站式服务商屡获殊荣的代理网络、强大的数据挖掘工具和现成可用的数据集。亮数据:网络数据平台领航者https://www.bright.cn/?promoRESIYEAR50/?utm_sourcebrand&utm_campaignbrnd-mkt_cn_csdn_yingjie202502 在跨境电商、社…...

git使用,注意空格

第一节 安装完成后,找个目录用于存储,打开目录右击选择git bash here 命令1 姓名 回车 git config --global user.name "li" 命令2 邮箱 回车 git config --global user.email "888163.com" 命令3 初始化新仓库,下载克隆 回…...

138,【5】buuctf web [RootersCTF2019]I_<3_Flask

进入靶场 这段代码是利用 Python 的类继承和反射机制来尝试执行系统命令读取flag.txt文件内容 .__class__:空字符串对象调用__class__属性,得到str类,即字符串的类型。__class__.__base__:str类的__base__属性指向其基类&#xf…...

docker 运行 芋道微服务

创建文件夹 docker-ai 文件夹下放入需要jar包的文件夹及 docker-compose.yml 文件 docker-compose.yml 内容:我这里的是ai服务,所以将原先的文件内容做了变更,你们需要用到什么服务就在下面文件中进行更改即可 version: 3 services:yudao-g…...

C++ Primer 函数重载

欢迎阅读我的 【CPrimer】专栏 专栏简介:本专栏主要面向C初学者,解释C的一些基本概念和基础语言特性,涉及C标准库的用法,面向对象特性,泛型特性高级用法。通过使用标准库中定义的抽象设施,使你更加适应高级…...

【Rust中级教程】1.6. 内存 Pt.4:静态(static)内存与‘static生命周期标注

喜欢的话别忘了点赞、收藏加关注哦(加关注即可阅读全文),对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 1.6.1. 静态(static)内存 static内存实际上是一个统称,它指的是程序编译后的文…...

【设计模式】【行为型模式】解释器模式(Interpreter)

👋hi,我不是一名外包公司的员工,也不会偷吃茶水间的零食,我的梦想是能写高端CRUD 🔥 2025本人正在沉淀中… 博客更新速度 👍 欢迎点赞、收藏、关注,跟上我的更新节奏 🎵 当你的天空突…...

修改OnlyOffice编辑器默认字体

通过Docker修改OnlyOffice编辑器默认字体 问题描述详细方案1. 删除原生字体文件2. 创建字体目录3. 复制字体文件到容器中4. 执行字体更新脚本5. 重新启动容器 注意事项 问题描述 在OnlyOffice中,编辑器的默认字体可能不符合公司或个人的需求,通常会使用…...

React echarts柱状图点击某个柱子跳转页面

绘制echarts柱状图 在 ECharts 中,如果你想要在点击柱状图的某个柱子时进行页面跳转,你可以通过设置 series 中的 data 属性中的 itemStyle 或者使用 series 的 label 属性中的 emphasis 属性来实现。但是,直接在柱状图中实现点击跳转通常涉…...

5分钟快速上手:抖音无水印视频下载器完全指南

5分钟快速上手:抖音无水印视频下载器完全指南 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support. 抖音…...

AI工具全景导航:从文本到视频,构建高效工作流

1. 项目概述:一份AI工具全景导航图 如果你和我一样,在过去一两年里被AI领域层出不穷的新工具、新模型搞得眼花缭乱,那么你肯定能理解整理一份清晰导航图的价值。我最初接触这个名为“Awesome-AI”的项目时,它还是一个相对简单的列…...

AI Agent的记忆系统架构2026:四种记忆类型与工程实现完全指南

摘要 记忆系统是AI Agent实现持续学习和个性化服务的核心基础设施。本文系统梳理Agent记忆的四大类型——感官记忆、短期记忆、长期记忆与情节记忆,并提供完整的工程实现方案。## 一、为什么Agent需要记忆系统大语言模型本质上是无状态的:每次推理相互独…...

AI+水文水资源实战:攻克非平稳序列预测、CMIP6降尺度、SWAT/EFDC/VIC模型自动化率定、启发式强化学习多目标优化(NSGA/MOEA/D)难关

您是否遇到过以下场景:拿到一个水文时间序列,不知道怎么自动检测异常值、估计P-III曲线参数、计算重现期?想用随机森林、XGBoost、LSTM甚至图神经网络做预测,但调参、过拟合、可解释性问题让您望而却步?跑SWAT/EFDC/De…...

我们如何教AI听懂一首歌的“好”?——ICASSP 2026音乐美学评估竞赛方案解读

一、技术解读最近,AI生成音乐(如Suno, Udio)的爆发让我们惊叹于机器的创造力。但一个随之而来的问题是:我们如何客观地评价一首AI生成的歌是不是真的“好听”? 传统的音频指标对此无能为力。信噪比、频谱失真度这些数字…...

#81_闲谈语言的分类

机器语言是二进制指令,CPU可直接执行; 低级语言通常指机器语言和汇编语言,与硬件紧密相关; 高级语言则接近自然语言,独立于具体硬件,需编译/解释才能运行; 中级语言并非严格分类,有时…...

基于Claude AI的代码蓝图生成工具:从原理到实践的全方位解析

1. 项目概述与核心价值最近在开发者社区里,一个名为“claude-code-blueprint”的项目引起了我的注意。这个由faizkhairi创建的开源工具,本质上是一个基于Claude AI模型的代码生成与架构设计辅助系统。简单来说,它能够将自然语言描述的需求&am…...

告别臃肿UI!用QSkinny为你的Qt嵌入式项目(如汽车仪表盘)做一次性能瘦身

告别臃肿UI!用QSkinny为你的Qt嵌入式项目(如汽车仪表盘)做一次性能瘦身 在嵌入式开发领域,性能优化往往是一场与硬件资源的拉锯战。当你的汽车仪表盘在冷启动时需要3秒才能显示完整界面,或是工控HMI在长时间运行后出现…...

自动化测试系列(五) 微服务接口测试-WireMock与契约测试-CDC

微服务接口测试:WireMock与契约测试(CDC)上篇咱们用RestAssured搞定了单体应用的接口测试。但微服务架构下,你的服务依赖一堆下游服务,怎么测?今天聊WireMock模拟和契约测试,这是微服务测试的两…...

Windows控制台光标定位工具elocate:原理、部署与实战应用

1. 项目概述:Windows控制台光标定位工具在Windows命令行下干活,尤其是写一些需要动态更新屏幕内容的脚本时,光标位置的控制是个挺让人头疼的事儿。你没法像在图形界面里那样,直接用鼠标点一下,或者调用一个简单的API就…...