Möller-Trumbore算法

  • 一、概述
  • 二、准备知识
  • 三、Möller-Trumbore 算法推导
    • 推导过程
  • 四、代码实现

一、概述

Möller-Trumbore 射线三角相交算法是一种快速计算射线与三角形在三个维度上的交点的方法,通过向量与矩阵计算可以快速得出交点与重心坐标,而无需对包含三角形的平面方程进行预计算。另外,它还应用于计算机图形学中以实现涉及三角形网格的光线跟踪计算。算法名字是以发明者 TomasMöllerBen Trumbore 的名字来命名的。

二、准备知识

1、三阶方阵的行列式等于三个列向量的混合积

2、克莱姆法则(部分译克拉默法则)
如果一个线性方程组 A x = c \boldsymbol{Ax} = \boldsymbol{c} Ax=c, 其中 A \boldsymbol{A} A 是可逆方阵, x \boldsymbol{x} x, c \boldsymbol{c} c 都是列向量,那么方程有解,且 x \boldsymbol{x} x 的每一个解

其中 A i ​ A_i​ Ai​​ 是被列向量取代了第 i i i 列的矩阵。

三、Möller-Trumbore 算法推导

已知光线 R a y = O + t D \boldsymbol{Ray} = \boldsymbol{O} + t\boldsymbol{D} Ray=O+tD( O \boldsymbol{O} O 为起点, D \boldsymbol{D} D为射线方向, t t t 为时间), 三角形三个顶点 P 0 P_0 P0​, P 1 P_1 P1​, P 2 P_2 P2​​。 光线与三角形相交时,可得如下等式:

则可以解

参数定义:

推导过程

从这里开始

括号展开,移项可得

观察一下上面的括号以及等式左边的内容,都是已知的点,因此点的加减可以用向量来表示,令

得到

也即

这是一个形如 A x = c \boldsymbol{Ax} = \boldsymbol{c} Ax=c 的等式,所以可以用克拉莫法则

由向量混合积可以得出
分母部分:


​原式等于

分子部分:


​原式等于

因此

另外的两个参数 b 1 b_1 b1​, b 2 b_2 b2​可以同样推出来

四、代码实现

bool rayTriangleIntersect(const Vector3f& v0, const Vector3f& v1, const Vector3f& v2, const Vector3f& orig,const Vector3f& dir, float& tnear, float& u, float& v)
{bool isIn = false;Vector3f E1 = v1 - v0;Vector3f E2 = v2 - v0;Vector3f S = orig - v0;Vector3f S1 = crossProduct(dir, E2);Vector3f S2 = crossProduct(S, E1);float coeff = 1.0 / dotProduct(S1, E1); // 共同系数float t = coeff * dotProduct(S2, E2);float b1 = coeff * dotProduct(S1, S);float b2 = coeff * dotProduct(S2, dir);if (t >= 0 && b1 >= 0 && b2 >= 0 && (1 - b1 - b2) >= 0){isIn = true;tnear = t;u = b1;v = b2;}return isIn;
}

参考资料
[1] 直线与三角形相交Moller Trumbore算法推导:
https://www.blurredcode.com/2020/04/%E7%9B%B4%E7%BA%BF%E4%B8%8E%E4%B8%89%E8%A7%92%E5%BD%A2%E7%9B%B8%E4%BA%A4moller-trumbore%E7%AE%97%E6%B3%95%E6%8E%A8%E5%AF%BC/
[2] 克莱姆法则:https://zh.wikipedia.org/wiki/%E5%85%8B%E8%90%8A%E5%A7%86%E6%B3%95%E5%89%87
[3] Möller–Trumbore 算法:https://en.wikipedia.org/wiki/M%C3%B6ller%E2%80%93Trumbore_intersection_algorithm
[4] 行列式的几何意义:https://www.cnblogs.com/andyjee/p/3491487.html

欢迎关注个人公众号,实时推送最新博文!

Möller-Trumbore算法-射线三角形相交算法相关推荐

  1. 空间射线与三角形相交算法的两种实现

    文章目录 1. 概述 2. 常规算法 2.1. 理论推导 2.2. 具体实现 3. 优化算法 3.1. 理论推导 3.2. 具体实现 4. 参考 1. 概述 任何复杂的三维模型都可以视作空间三角面片的 ...

  2. 【收藏好文】一文读懂射线与三角形相交算法Moller-Trumbore算法

    编辑:OAK中国 首发:oakchina.cn 喜欢的话,请多多

  3. 图形学 射线相交算法_计算机图形学中的彩色阴极射线管

    图形学 射线相交算法 彩色阴极射线管 (Color Cathode Ray Tube) CRT i.e. Cathode Ray Tubes are used to produce Color dis ...

  4. 图形学 射线相交算法_计算机图形学中的阴极射线管

    图形学 射线相交算法 阴极射线管 (Cathode Ray Tube) Ferdinand Barun of Strasbourg developed the cathode ray tube in ...

  5. 图形学 射线相交算法_计算机图形学中的阴极射线管(CRT)

    图形学 射线相交算法 什么是阴极射线管(CRT)? (What is Cathode Ray Tube (CRT)?) CRT stands for "Cathode Ray Tube&qu ...

  6. 多边形之间相交求交点的算法_路径规划算法总结

    本文来自知乎网友@搬砖的旺财,地平线机器人算法工程师.作者根据自己本科和硕士阶段的学习经历,整理归纳了所接触过的规划算法. 1.自主机器人近距离操作运动规划体系 在研究自主运动规划问题之前,首先需建立 ...

  7. CT与DR双能X射线物质识别算法实现与应用(工业选煤、稀土分拣、毒爆检测、垃圾分类等)

    CT与DR双能X射线物质识别算法实现与应用(工业选煤.稀土分拣.毒爆检测.垃圾分类等)        算法涉及到的理论和模型,来自CNKI相关技术论文(不包括本人改进部分),如涉及版权问题,请联系本人 ...

  8. CT图像重建算法------射线驱动投影模型

    在模拟CT扫描过程中被测物体保持静止不动,射线源与探测器绕Z轴做逆时针旋转,每隔一定角度进行一次投影数据的计算,而计算方法则取决于采用什么样的投影算法.本文主要介绍了投影算法的分类,并详细描述了射线驱 ...

  9. 图形学基础笔记II:多边形光栅化算法和显卡三角形光栅算法

    为什么三角形就够了 实际对于 3D 来说肯定全是基于三角形的 geometry - OpenGL: Is it more efficient to use GL_QUADS or GL_TRIANGL ...

最新文章

  1. springMvc的执行流程(源码分析)
  2. 页面异常反dump 及 内存访问异常hook
  3. centos mysql 访问_centos下mysql开启远程访问
  4. python意外缩进引发逻辑错误_python – IndentationError:意外的缩进错误
  5. 感恩工作平台心得体会_珍惜工作,感恩企业,从而追求更美好的人生
  6. openfiledialog选择文件会占用文件_铁皮文件柜的尺寸规格如何选择?选购花都文件柜要注意的问题...
  7. [转载] 第一个Python CGI编程和配置
  8. Quartz简单理解
  9. 自定义Kettle数据库插件 1
  10. matlab动态仿真实例教程,MATLAB R2008控制系统动态仿真实例教程_IT教程网
  11. 计算机网络与通信之计算机网络体系结构
  12. 【SSD目标检测】1:图片、视频内的物体检测与定位
  13. kux格式 linux,怎么把1080P的kux视频转换成mp4呢
  14. 分析算法泛化性能的有效工具:偏差——方差分解
  15. Android APP微信第三方登录踩坑 - 微信开放平台修改应用包名后微信第三方登录失败
  16. matlab实现简单图形的识别二
  17. 通过命令行操作iOS模拟器
  18. 一梦江湖卡在服务器信息100,一梦江湖卡69、89、129到底有什么区别?这一篇讲的很清楚了...
  19. nao机器人拆解_两周年了 Pepper都经历了什么呢?
  20. 一起来设计“塔防游戏”吧

热门文章

  1. JVM主要组成部分及其作用
  2. DEBIAN10安装php-zbarcode,上传图片识别条形码
  3. 美国文理学院的计算机科学,康奈尔大学文理学院的cs专业怎么样?
  4. 停顿C语言,C++实现类似延时停顿的打字效果
  5. 零基础学习网页制作(五)
  6. 青龙快手极速版及定时任务时间解析
  7. vue手动实现输入框模糊查询
  8. 如何在VMware中使用CDR文件启动磁盘?(整机菜鸟来这里!)
  9. 联发科mt6735详细参数_MT6735详解:64位全网通 GPU太坑
  10. ubuntu虚拟机不能拷贝复制文件的解决办法