Triangle/Ray Intersection

Fast vectorized triangle/ray intersection algorithm
6,1K téléchargements
Mise à jour 18 mai 2018

Afficher la licence

Ray/triangle intersection using the algorithm proposed by Möller and
Trumbore (1997), implemented as highly vectorized MATLAB code.
The algorithm can work with one and two sided surfaces, as well as, with
infinite lines, rays (lines bounded on one side) and segments (lines bounded on
both sides).
Input (all arrays in in Nx3, where N is number of vertices or rays):
orig : ray's origin
dir : ray's direction
vert0, vert1, vert2: vertices of the triangle
Intersect - boolean array of length N
t - distance from the ray origin to the intersection point in |dir|
u,v - barycentric coordinates of the intersection point units
xcoor - carthesian coordinates of the intersection point
In addition PointInsideVolume is 3D equivalent to 2D inpolygon function and can test if
array of points is inside or outside any volume defined by the surface grid.

Citation pour cette source

Jaroslaw Tuszynski (2024). Triangle/Ray Intersection (, MATLAB Central File Exchange. Récupéré le .

Compatibilité avec les versions de MATLAB
Créé avec R2017b
Compatible avec toutes les versions
Plateformes compatibles
Windows macOS Linux
En savoir plus sur Surface and Mesh Plots dans Help Center et MATLAB Answers

Inspiré par : Ray/Triangle Intersection

A inspiré : in_polyhedron,

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!
Version Publié le Notes de version

small corrections to the interface

Minimal changes suggested by Igor in Comments and Ratings

correct description: no symbolic toolbox is needed
Major rewrite of the function with additional options and output variables. Also provided PointInsideVolume function

documentation improvements and typo correction

correct treatment of 3x3 arrays as suggested by Andreas Weber

Improvements to border handling