2011-02-18 13:58:08 +00:00
|
|
|
/*
|
2009-11-09 22:42:41 +00:00
|
|
|
* ***** BEGIN GPL LICENSE BLOCK *****
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software Foundation,
|
2010-02-12 13:34:04 +00:00
|
|
|
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2009-11-09 22:42:41 +00:00
|
|
|
*
|
|
|
|
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* The Original Code is: some of this file.
|
|
|
|
*
|
|
|
|
* ***** END GPL LICENSE BLOCK *****
|
|
|
|
* */
|
|
|
|
|
2012-02-17 18:59:41 +00:00
|
|
|
#ifndef __BLI_MATH_GEOM_H__
|
|
|
|
#define __BLI_MATH_GEOM_H__
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2011-02-18 13:58:08 +00:00
|
|
|
/** \file BLI_math_geom.h
|
|
|
|
* \ingroup bli
|
|
|
|
*/
|
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2013-09-01 15:01:15 +00:00
|
|
|
#include "BLI_compiler_attrs.h"
|
2010-04-15 10:28:32 +00:00
|
|
|
#include "BLI_math_inline.h"
|
|
|
|
|
2013-03-13 15:41:14 +00:00
|
|
|
#ifdef BLI_MATH_GCC_WARN_PRAGMA
|
2013-03-11 20:27:38 +00:00
|
|
|
# pragma GCC diagnostic push
|
|
|
|
# pragma GCC diagnostic ignored "-Wredundant-decls"
|
|
|
|
#endif
|
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
/********************************** Polygons *********************************/
|
|
|
|
|
2011-04-20 06:47:16 +00:00
|
|
|
void cent_tri_v3(float r[3], const float a[3], const float b[3], const float c[3]);
|
|
|
|
void cent_quad_v3(float r[3], const float a[3], const float b[3], const float c[3], const float d[3]);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2009-12-27 01:32:58 +00:00
|
|
|
float normal_tri_v3(float r[3], const float a[3], const float b[3], const float c[3]);
|
|
|
|
float normal_quad_v3(float r[3], const float a[3], const float b[3], const float c[3], const float d[3]);
|
2014-04-16 00:27:35 +10:00
|
|
|
float normal_poly_v3(float r[3], const float verts[][3], unsigned int nr);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2013-11-30 15:57:16 +11:00
|
|
|
MINLINE float area_tri_v2(const float a[2], const float b[2], const float c[2]);
|
2015-01-13 19:01:40 +11:00
|
|
|
MINLINE float area_squared_tri_v2(const float a[2], const float b[2], const float c[2]);
|
2013-11-30 15:57:16 +11:00
|
|
|
MINLINE float area_tri_signed_v2(const float v1[2], const float v2[2], const float v3[2]);
|
2009-12-27 01:32:58 +00:00
|
|
|
float area_tri_v3(const float a[3], const float b[3], const float c[3]);
|
2015-01-13 19:01:40 +11:00
|
|
|
float area_squared_tri_v3(const float a[3], const float b[3], const float c[3]);
|
2013-02-14 17:35:46 +00:00
|
|
|
float area_tri_signed_v3(const float v1[3], const float v2[3], const float v3[3], const float normal[3]);
|
2009-12-27 01:32:58 +00:00
|
|
|
float area_quad_v3(const float a[3], const float b[3], const float c[3], const float d[3]);
|
2015-01-13 19:01:40 +11:00
|
|
|
float area_squared_quad_v3(const float a[3], const float b[3], const float c[3], const float d[3]);
|
2014-04-16 00:27:35 +10:00
|
|
|
float area_poly_v3(const float verts[][3], unsigned int nr);
|
2014-03-27 07:31:21 +11:00
|
|
|
float area_poly_v2(const float verts[][2], unsigned int nr);
|
2015-01-13 19:01:40 +11:00
|
|
|
float area_squared_poly_v3(const float verts[][3], unsigned int nr);
|
|
|
|
float area_squared_poly_v2(const float verts[][2], unsigned int nr);
|
|
|
|
float area_poly_signed_v2(const float verts[][2], unsigned int nr);
|
2014-03-30 11:08:33 +11:00
|
|
|
float cotangent_tri_weight_v3(const float v1[3], const float v2[3], const float v3[3]);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2014-12-27 16:47:42 +11:00
|
|
|
void cross_tri_v3(float n[3], const float v1[3], const float v2[3], const float v3[3]);
|
2013-11-30 15:57:16 +11:00
|
|
|
MINLINE float cross_tri_v2(const float v1[2], const float v2[2], const float v3[2]);
|
2015-01-13 19:01:40 +11:00
|
|
|
void cross_poly_v3(float n[3], const float verts[][3], unsigned int nr);
|
2014-03-27 07:31:21 +11:00
|
|
|
float cross_poly_v2(const float verts[][2], unsigned int nr);
|
2013-11-30 15:57:16 +11:00
|
|
|
|
2013-08-22 15:30:24 +00:00
|
|
|
/********************************* Planes **********************************/
|
|
|
|
|
|
|
|
void plane_from_point_normal_v3(float r_plane[4], const float plane_co[3], const float plane_no[3]);
|
2015-03-04 20:08:16 +11:00
|
|
|
void plane_to_point_vector_v3(const float plane[4], float r_plane_co[3], float r_plane_no[3]);
|
|
|
|
void plane_to_point_vector_v3_normalized(const float plane[4], float r_plane_co[3], float r_plane_no[3]);
|
|
|
|
|
2013-08-22 15:30:24 +00:00
|
|
|
MINLINE float plane_point_side_v3(const float plane[4], const float co[3]);
|
|
|
|
|
|
|
|
/********************************* Volume **********************************/
|
|
|
|
|
2013-04-21 13:24:45 +00:00
|
|
|
float volume_tetrahedron_v3(const float v1[3], const float v2[3], const float v3[3], const float v4[3]);
|
2014-07-11 12:06:13 +02:00
|
|
|
float volume_tetrahedron_signed_v3(const float v1[3], const float v2[3], const float v3[3], const float v4[3]);
|
2013-04-21 13:24:45 +00:00
|
|
|
|
2014-03-29 22:23:27 +11:00
|
|
|
bool is_quad_convex_v3(const float v1[3], const float v2[3], const float v3[3], const float v4[3]);
|
|
|
|
bool is_quad_convex_v2(const float v1[2], const float v2[2], const float v3[2], const float v4[2]);
|
|
|
|
bool is_poly_convex_v2(const float verts[][2], unsigned int nr);
|
2014-12-17 11:31:33 +01:00
|
|
|
int is_quad_flip_v3(const float v1[3], const float v2[3], const float v3[3], const float v4[3]);
|
2012-01-20 02:24:01 +00:00
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
/********************************* Distance **********************************/
|
|
|
|
|
2013-12-28 17:17:55 +11:00
|
|
|
float dist_squared_to_line_v2(const float p[2], const float l1[2], const float l2[2]);
|
|
|
|
float dist_to_line_v2(const float p[2], const float l1[2], const float l2[2]);
|
2012-07-14 18:42:59 +00:00
|
|
|
float dist_squared_to_line_segment_v2(const float p[2], const float l1[2], const float l2[2]);
|
|
|
|
float dist_to_line_segment_v2(const float p[2], const float l1[2], const float l2[2]);
|
2014-03-16 03:24:05 +11:00
|
|
|
void closest_to_line_segment_v2(float r_close[2], const float p[2], const float l1[2], const float l2[2]);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2014-08-13 14:34:58 +10:00
|
|
|
float dist_signed_squared_to_plane_v3(const float p[3], const float plane[4]);
|
|
|
|
float dist_squared_to_plane_v3(const float p[3], const float plane[4]);
|
|
|
|
float dist_signed_to_plane_v3(const float p[3], const float plane[4]);
|
|
|
|
float dist_to_plane_v3(const float p[3], const float plane[4]);
|
|
|
|
|
2015-06-24 07:14:33 +10:00
|
|
|
/* plane3 versions */
|
|
|
|
float dist_signed_squared_to_plane3_v3(const float p[3], const float plane[4]);
|
|
|
|
float dist_squared_to_plane3_v3(const float p[3], const float plane[4]);
|
|
|
|
float dist_signed_to_plane3_v3(const float p[3], const float plane[4]);
|
|
|
|
float dist_to_plane3_v3(const float p[3], const float plane[4]);
|
|
|
|
|
2013-07-12 00:18:27 +00:00
|
|
|
float dist_squared_to_line_segment_v3(const float p[3], const float l1[3], const float l2[3]);
|
|
|
|
float dist_to_line_segment_v3(const float p[3], const float l1[3], const float l2[3]);
|
2013-12-28 17:17:55 +11:00
|
|
|
float dist_squared_to_line_v3(const float p[3], const float l1[3], const float l2[3]);
|
|
|
|
float dist_to_line_v3(const float p[3], const float l1[3], const float l2[3]);
|
2015-02-16 18:47:15 +11:00
|
|
|
float dist_signed_squared_to_corner_v3v3v3(
|
|
|
|
const float p[3],
|
|
|
|
const float v1[3], const float v2[3], const float v3[3],
|
2015-03-02 23:49:52 +11:00
|
|
|
const float axis_ref[3]);
|
2011-01-06 09:32:25 +00:00
|
|
|
float closest_to_line_v3(float r[3], const float p[3], const float l1[3], const float l2[3]);
|
|
|
|
float closest_to_line_v2(float r[2], const float p[2], const float l1[2], const float l2[2]);
|
2014-03-16 03:24:05 +11:00
|
|
|
void closest_to_line_segment_v3(float r_close[3], const float p[3], const float l1[3], const float l2[3]);
|
2015-08-31 20:05:49 +10:00
|
|
|
void closest_to_plane_normalized_v3(float r_close[3], const float plane[4], const float pt[3]);
|
2014-03-16 03:24:05 +11:00
|
|
|
void closest_to_plane_v3(float r_close[3], const float plane[4], const float pt[3]);
|
2015-08-31 20:05:49 +10:00
|
|
|
void closest_to_plane3_normalized_v3(float r_close[3], const float plane[3], const float pt[3]);
|
|
|
|
void closest_to_plane3_v3(float r_close[3], const float plane[3], const float pt[3]);
|
2011-12-14 21:08:08 +00:00
|
|
|
|
2012-12-30 18:23:03 +00:00
|
|
|
/* Set 'r' to the point in triangle (t1, t2, t3) closest to point 'p' */
|
|
|
|
void closest_on_tri_to_point_v3(float r[3], const float p[3], const float t1[3], const float t2[3], const float t3[3]);
|
|
|
|
|
2015-08-31 22:15:27 +10:00
|
|
|
float line_point_factor_v3_ex(
|
|
|
|
const float p[3], const float l1[3], const float l2[3],
|
|
|
|
const float epsilon, const float fallback);
|
|
|
|
float line_point_factor_v3(
|
|
|
|
const float p[3], const float l1[3], const float l2[3]);
|
|
|
|
|
|
|
|
float line_point_factor_v2_ex(
|
|
|
|
const float p[2], const float l1[2], const float l2[2],
|
|
|
|
const float epsilon, const float fallback);
|
|
|
|
float line_point_factor_v2(
|
|
|
|
const float p[2], const float l1[2], const float l2[2]);
|
2013-08-31 02:06:23 +00:00
|
|
|
|
|
|
|
float line_plane_factor_v3(const float plane_co[3], const float plane_no[3],
|
|
|
|
const float l1[3], const float l2[3]);
|
|
|
|
|
2012-05-12 20:39:39 +00:00
|
|
|
void limit_dist_v3(float v1[3], float v2[3], const float dist);
|
2011-06-26 08:07:09 +00:00
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
/******************************* Intersection ********************************/
|
|
|
|
|
|
|
|
/* TODO int return value consistency */
|
|
|
|
|
|
|
|
/* line-line */
|
2012-05-12 20:39:39 +00:00
|
|
|
#define ISECT_LINE_LINE_COLINEAR -1
|
|
|
|
#define ISECT_LINE_LINE_NONE 0
|
|
|
|
#define ISECT_LINE_LINE_EXACT 1
|
|
|
|
#define ISECT_LINE_LINE_CROSS 2
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2015-07-21 21:33:57 +10:00
|
|
|
int isect_line_line_v2_point(const float v0[2], const float v1[2], const float v2[2], const float v3[2], float r_vi[2]);
|
2010-12-12 01:36:10 +00:00
|
|
|
int isect_line_line_v2(const float a1[2], const float a2[2], const float b1[2], const float b2[2]);
|
2011-05-12 16:47:36 +00:00
|
|
|
int isect_line_line_v2_int(const int a1[2], const int a2[2], const int b1[2], const int b2[2]);
|
2011-06-26 08:07:09 +00:00
|
|
|
int isect_line_sphere_v3(const float l1[3], const float l2[3], const float sp[3], const float r, float r_p1[3], float r_p2[3]);
|
2011-06-26 11:08:12 +00:00
|
|
|
int isect_line_sphere_v2(const float l1[2], const float l2[2], const float sp[2], const float r, float r_p1[2], float r_p2[2]);
|
2015-06-23 20:28:32 +10:00
|
|
|
int isect_seg_seg_v2_point(const float v0[2], const float v1[2], const float v2[2], const float v3[2], float vi[2]);
|
2014-03-29 22:23:27 +11:00
|
|
|
bool isect_seg_seg_v2(const float v1[2], const float v2[2], const float v3[2], const float v4[2]);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2014-08-16 15:13:11 +10:00
|
|
|
int isect_line_line_epsilon_v3(
|
|
|
|
const float v1[3], const float v2[3],
|
|
|
|
const float v3[3], const float v4[3], float i1[3], float i2[3],
|
|
|
|
const float epsilon);
|
|
|
|
int isect_line_line_v3(
|
|
|
|
const float v1[3], const float v2[3],
|
|
|
|
const float v3[3], const float v4[3],
|
|
|
|
float i1[3], float i2[3]);
|
2013-06-09 21:25:27 +00:00
|
|
|
bool isect_line_line_strict_v3(const float v1[3], const float v2[3],
|
|
|
|
const float v3[3], const float v4[3],
|
|
|
|
float vi[3], float *r_lambda);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2015-08-20 12:36:21 +10:00
|
|
|
bool isect_ray_plane_v3(
|
|
|
|
const float p1[3], const float d[3],
|
|
|
|
const float v0[3], const float v1[3], const float v2[3],
|
|
|
|
float *r_lambda, const bool clip);
|
2011-05-01 21:39:13 +00:00
|
|
|
|
2013-08-22 15:30:24 +00:00
|
|
|
bool isect_point_planes_v3(float (*planes)[4], int totplane, const float p[3]);
|
2013-06-09 21:25:27 +00:00
|
|
|
bool isect_line_plane_v3(float out[3], const float l1[3], const float l2[3],
|
2013-12-29 12:51:27 +11:00
|
|
|
const float plane_co[3], const float plane_no[3]) ATTR_WARN_UNUSED_RESULT;
|
2011-05-19 03:49:57 +00:00
|
|
|
|
2015-09-04 22:04:54 +10:00
|
|
|
bool isect_plane_plane_plane_v3(
|
|
|
|
const float plane_a[4], const float plane_b[4], const float plane_c[4],
|
|
|
|
float r_isect_co[3]) ATTR_WARN_UNUSED_RESULT;
|
|
|
|
bool isect_plane_plane_v3(
|
|
|
|
const float plane_a[4], const float plane_b[4],
|
|
|
|
float r_isect_co[3], float r_isect_no[3]) ATTR_WARN_UNUSED_RESULT;
|
2011-11-13 16:28:52 +00:00
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
/* line/ray triangle */
|
2015-08-20 12:36:21 +10:00
|
|
|
bool isect_line_tri_v3(
|
|
|
|
const float p1[3], const float p2[3],
|
|
|
|
const float v0[3], const float v1[3], const float v2[3],
|
|
|
|
float *r_lambda, float r_uv[2]);
|
|
|
|
bool isect_line_tri_epsilon_v3(
|
|
|
|
const float p1[3], const float p2[3],
|
|
|
|
const float v0[3], const float v1[3], const float v2[3],
|
|
|
|
float *r_lambda, float r_uv[2], const float epsilon);
|
|
|
|
bool isect_ray_tri_v3(
|
|
|
|
const float p1[3], const float d[3],
|
|
|
|
const float v0[3], const float v1[3], const float v2[3],
|
|
|
|
float *r_lambda, float r_uv[2]);
|
|
|
|
bool isect_ray_tri_threshold_v3(
|
|
|
|
const float p1[3], const float d[3],
|
|
|
|
const float v0[3], const float v1[3], const float v2[3],
|
|
|
|
float *r_lambda, float r_uv[2], const float threshold);
|
|
|
|
bool isect_ray_tri_epsilon_v3(
|
|
|
|
const float p1[3], const float d[3],
|
|
|
|
const float v0[3], const float v1[3], const float v2[3],
|
|
|
|
float *r_lambda, float r_uv[2], const float epsilon);
|
2015-07-29 17:48:38 +10:00
|
|
|
bool isect_tri_tri_epsilon_v3(
|
|
|
|
const float t_a0[3], const float t_a1[3], const float t_a2[3],
|
|
|
|
const float t_b0[3], const float t_b1[3], const float t_b2[3],
|
|
|
|
float r_i1[3], float r_i2[3],
|
|
|
|
const float epsilon);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2015-08-21 17:45:04 +10:00
|
|
|
/* water-tight raycast (requires pre-calculation) */
|
|
|
|
struct IsectRayPrecalc {
|
|
|
|
/* Maximal dimension kz, and orthogonal dimensions. */
|
|
|
|
int kx, ky, kz;
|
|
|
|
|
|
|
|
/* Shear constants. */
|
|
|
|
float sx, sy, sz;
|
|
|
|
};
|
|
|
|
|
|
|
|
void isect_ray_tri_watertight_v3_precalc(
|
|
|
|
struct IsectRayPrecalc *isect_precalc, const float dir[3]);
|
|
|
|
bool isect_ray_tri_watertight_v3(
|
|
|
|
const float P[3], const struct IsectRayPrecalc *isect_precalc,
|
|
|
|
const float v0[3], const float v1[3], const float v2[3],
|
|
|
|
float *r_dist, float r_uv[2]);
|
|
|
|
/* slower version which calculates IsectRayPrecalc each time */
|
|
|
|
bool isect_ray_tri_watertight_v3_simple(
|
|
|
|
const float P[3], const float dir[3],
|
|
|
|
const float v0[3], const float v1[3], const float v2[3],
|
|
|
|
float *r_lambda, float r_uv[2]);
|
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
/* point in polygon */
|
2013-10-05 12:36:35 +00:00
|
|
|
bool isect_point_poly_v2(const float pt[2], const float verts[][2], const unsigned int nr, const bool use_holes);
|
|
|
|
bool isect_point_poly_v2_int(const int pt[2], const int verts[][2], const unsigned int nr, const bool use_holes);
|
2013-03-14 21:44:16 +00:00
|
|
|
|
2011-04-20 06:47:16 +00:00
|
|
|
int isect_point_quad_v2(const float p[2], const float a[2], const float b[2], const float c[2], const float d[2]);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2014-03-29 22:23:27 +11:00
|
|
|
int isect_point_tri_v2(const float pt[2], const float v1[2], const float v2[2], const float v3[2]);
|
|
|
|
bool isect_point_tri_v2_cw(const float pt[2], const float v1[2], const float v2[2], const float v3[2]);
|
|
|
|
int isect_point_tri_v2_int(const int x1, const int y1, const int x2, const int y2, const int a, const int b);
|
2013-06-09 21:25:27 +00:00
|
|
|
bool isect_point_tri_prism_v3(const float p[3], const float v1[3], const float v2[3], const float v3[3]);
|
2014-07-21 16:58:17 +10:00
|
|
|
bool isect_point_tri_v3(const float p[3], const float v1[3], const float v2[3], const float v3[3],
|
|
|
|
float r_vi[3]);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2012-07-05 03:55:55 +00:00
|
|
|
/* axis-aligned bounding box */
|
2013-06-09 21:25:27 +00:00
|
|
|
bool isect_aabb_aabb_v3(const float min1[3], const float max1[3], const float min2[3], const float max2[3]);
|
2012-07-05 03:55:55 +00:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
float ray_start[3];
|
|
|
|
float ray_inv_dir[3];
|
|
|
|
int sign[3];
|
|
|
|
} IsectRayAABBData;
|
|
|
|
|
|
|
|
void isect_ray_aabb_initialize(IsectRayAABBData *data, const float ray_start[3], const float ray_direction[3]);
|
2013-06-09 21:25:27 +00:00
|
|
|
bool isect_ray_aabb(const IsectRayAABBData *data, const float bb_min[3], const float bb_max[3], float *tmin);
|
2012-07-05 03:55:55 +00:00
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
/* other */
|
2013-06-09 21:25:27 +00:00
|
|
|
bool isect_sweeping_sphere_tri_v3(const float p1[3], const float p2[3], const float radius,
|
|
|
|
const float v0[3], const float v1[3], const float v2[3], float *r_lambda, float ipoint[3]);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2013-06-09 21:25:27 +00:00
|
|
|
bool isect_axial_line_tri_v3(const int axis, const float co1[3], const float co2[3],
|
|
|
|
const float v0[3], const float v1[3], const float v2[3], float *r_lambda);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2013-04-22 19:39:10 +00:00
|
|
|
bool clip_segment_v3_plane(float p1[3], float p2[3], const float plane[4]);
|
|
|
|
bool clip_segment_v3_plane_n(float p1[3], float p2[3], float plane_array[][4], const int plane_tot);
|
2010-01-05 14:26:38 +00:00
|
|
|
|
2013-03-20 23:14:18 +00:00
|
|
|
void plot_line_v2v2i(const int p1[2], const int p2[2], bool (*callback)(int, int, void *), void *userData);
|
2013-10-04 15:02:05 +00:00
|
|
|
void fill_poly_v2i_n(
|
|
|
|
const int xmin, const int ymin, const int xmax, const int ymax,
|
|
|
|
const int polyXY[][2], const int polyCorners,
|
|
|
|
void (*callback)(int, int, void *), void *userData);
|
2009-11-09 22:42:41 +00:00
|
|
|
/****************************** Interpolation ********************************/
|
|
|
|
|
|
|
|
/* tri or quad, d can be NULL */
|
|
|
|
void interp_weights_face_v3(float w[4],
|
2012-05-12 20:39:39 +00:00
|
|
|
const float a[3], const float b[3], const float c[3], const float d[3], const float p[3]);
|
2012-07-16 10:36:40 +00:00
|
|
|
void interp_weights_poly_v3(float w[], float v[][3], const int n, const float co[3]);
|
|
|
|
void interp_weights_poly_v2(float w[], float v[][2], const int n, const float co[2]);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
|
|
|
void interp_cubic_v3(float x[3], float v[3],
|
2012-05-12 20:39:39 +00:00
|
|
|
const float x1[3], const float v1[3], const float x2[3], const float v2[3], const float t);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2011-04-20 06:47:16 +00:00
|
|
|
int interp_sparse_array(float *array, const int list_size, const float invalid);
|
2010-01-01 15:57:17 +00:00
|
|
|
|
2014-08-13 14:55:45 +10:00
|
|
|
void transform_point_by_tri_v3(
|
|
|
|
float pt_tar[3], float const pt_src[3],
|
|
|
|
const float tri_tar_p1[3], const float tri_tar_p2[3], const float tri_tar_p3[3],
|
|
|
|
const float tri_src_p1[3], const float tri_src_p2[3], const float tri_src_p3[3]);
|
|
|
|
void transform_point_by_seg_v3(
|
|
|
|
float p_dst[3], const float p_src[3],
|
|
|
|
const float l_dst_p1[3], const float l_dst_p2[3],
|
|
|
|
const float l_src_p1[3], const float l_src_p2[3]);
|
2009-12-27 01:32:58 +00:00
|
|
|
|
|
|
|
void barycentric_weights_v2(const float v1[2], const float v2[2], const float v3[2],
|
2012-05-12 20:39:39 +00:00
|
|
|
const float co[2], float w[3]);
|
2014-04-23 02:09:50 +10:00
|
|
|
void barycentric_weights_v2_persp(const float v1[4], const float v2[4], const float v3[4],
|
|
|
|
const float co[2], float w[3]);
|
2012-07-13 09:19:05 +00:00
|
|
|
void barycentric_weights_v2_quad(const float v1[2], const float v2[2], const float v3[2], const float v4[2],
|
|
|
|
const float co[2], float w[4]);
|
2009-12-27 01:32:58 +00:00
|
|
|
|
2013-08-01 17:15:11 +00:00
|
|
|
bool barycentric_coords_v2(const float v1[2], const float v2[2], const float v3[2], const float co[2], float w[3]);
|
2012-05-31 11:57:09 +00:00
|
|
|
int barycentric_inside_triangle_v2(const float w[3]);
|
|
|
|
|
2014-03-26 11:15:21 +11:00
|
|
|
void resolve_tri_uv_v2(float r_uv[2], const float st[2], const float st0[2], const float st1[2], const float st2[2]);
|
2014-03-25 21:57:34 -03:00
|
|
|
void resolve_tri_uv_v3(float r_uv[2], const float st[3], const float st0[3], const float st1[3], const float st2[3]);
|
2014-03-26 11:15:21 +11:00
|
|
|
void resolve_quad_uv_v2(float r_uv[2], const float st[2], const float st0[2], const float st1[2], const float st2[2], const float st3[2]);
|
|
|
|
void resolve_quad_uv_v2_deriv(float r_uv[2], float r_deriv[2][2],
|
|
|
|
const float st[2], const float st0[2], const float st1[2], const float st2[2], const float st3[2]);
|
2015-05-13 18:04:46 +10:00
|
|
|
float resolve_quad_u_v2(const float st[2], const float st0[2], const float st1[2], const float st2[2], const float st3[2]);
|
2011-06-05 20:54:04 +00:00
|
|
|
|
2012-11-15 13:24:14 +00:00
|
|
|
/* use to find the point of a UV on a face */
|
|
|
|
void interp_bilinear_quad_v3(float data[4][3], float u, float v, float res[3]);
|
|
|
|
void interp_barycentric_tri_v3(float data[3][3], float u, float v, float res[3]);
|
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
/***************************** View & Projection *****************************/
|
|
|
|
|
|
|
|
void lookat_m4(float mat[4][4], float vx, float vy,
|
2012-05-12 20:39:39 +00:00
|
|
|
float vz, float px, float py, float pz, float twist);
|
2009-11-09 22:42:41 +00:00
|
|
|
void polarview_m4(float mat[4][4], float dist, float azimuth,
|
2012-05-12 20:39:39 +00:00
|
|
|
float incidence, float twist);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2011-04-20 06:47:16 +00:00
|
|
|
void perspective_m4(float mat[4][4], const float left, const float right,
|
2012-05-12 20:39:39 +00:00
|
|
|
const float bottom, const float top, const float nearClip, const float farClip);
|
2011-04-20 06:47:16 +00:00
|
|
|
void orthographic_m4(float mat[4][4], const float left, const float right,
|
2012-05-12 20:39:39 +00:00
|
|
|
const float bottom, const float top, const float nearClip, const float farClip);
|
2012-12-11 14:29:01 +00:00
|
|
|
void window_translate_m4(float winmat[4][4], float perspmat[4][4],
|
2012-05-12 20:39:39 +00:00
|
|
|
const float x, const float y);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2015-01-03 12:05:16 +01:00
|
|
|
void planes_from_projmat(float mat[4][4], float left[4], float right[4], float top[4], float bottom[4],
|
|
|
|
float front[4], float back[4]);
|
|
|
|
|
2010-01-22 11:10:24 +00:00
|
|
|
int box_clip_bounds_m4(float boundbox[2][3],
|
2012-05-12 20:39:39 +00:00
|
|
|
const float bounds[4], float winmat[4][4]);
|
2010-04-15 10:28:32 +00:00
|
|
|
void box_minmax_bounds_m4(float min[3], float max[3],
|
2012-05-12 20:39:39 +00:00
|
|
|
float boundbox[2][3], float mat[4][4]);
|
2010-01-22 11:10:24 +00:00
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
/********************************** Mapping **********************************/
|
|
|
|
|
2012-02-28 14:05:00 +00:00
|
|
|
void map_to_tube(float *r_u, float *r_v, const float x, const float y, const float z);
|
|
|
|
void map_to_sphere(float *r_u, float *r_v, const float x, const float y, const float z);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2011-03-20 13:35:35 +00:00
|
|
|
/********************************** Normals **********************************/
|
|
|
|
|
2015-07-17 03:36:03 +10:00
|
|
|
void accumulate_vertex_normals_tri(
|
|
|
|
float n1[3], float n2[3], float n3[3],
|
|
|
|
const float f_no[3],
|
|
|
|
const float co1[3], const float co2[3], const float co3[3]);
|
|
|
|
|
2014-10-09 22:39:59 +02:00
|
|
|
void accumulate_vertex_normals(
|
|
|
|
float n1[3], float n2[3], float n3[3], float n4[3],
|
|
|
|
const float f_no[3],
|
|
|
|
const float co1[3], const float co2[3], const float co3[3], const float co4[3]);
|
2011-03-20 13:35:35 +00:00
|
|
|
|
2014-10-09 22:39:59 +02:00
|
|
|
void accumulate_vertex_normals_poly(
|
|
|
|
float **vertnos, const float polyno[3],
|
|
|
|
const float **vertcos, float vdiffs[][3], const int nverts);
|
2012-01-20 02:24:01 +00:00
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
/********************************* Tangents **********************************/
|
|
|
|
|
2014-10-09 22:39:59 +02:00
|
|
|
void tangent_from_uv(
|
|
|
|
const float uv1[2], const float uv2[2], const float uv3[2],
|
|
|
|
const float co1[3], const float co2[3], const float co3[3],
|
|
|
|
const float n[3],
|
|
|
|
float r_tang[3]);
|
2009-11-09 22:42:41 +00:00
|
|
|
|
2010-04-15 10:28:32 +00:00
|
|
|
/******************************** Vector Clouds ******************************/
|
|
|
|
|
|
|
|
void vcloud_estimate_transform(int list_size, float (*pos)[3], float *weight,
|
2012-05-12 20:39:39 +00:00
|
|
|
float (*rpos)[3], float *rweight,
|
|
|
|
float lloc[3], float rloc[3], float lrot[3][3], float lscale[3][3]);
|
2010-04-15 10:28:32 +00:00
|
|
|
|
|
|
|
/****************************** Spherical Harmonics *************************/
|
|
|
|
|
|
|
|
/* Uses 2nd order SH => 9 coefficients, stored in this order:
|
2012-04-29 15:47:02 +00:00
|
|
|
* 0 = (0, 0),
|
|
|
|
* 1 = (1, -1), 2 = (1, 0), 3 = (1, 1),
|
|
|
|
* 4 = (2, -2), 5 = (2, -1), 6 = (2, 0), 7 = (2, 1), 8 = (2, 2) */
|
2010-04-15 10:28:32 +00:00
|
|
|
|
|
|
|
MINLINE void zero_sh(float r[9]);
|
2011-04-20 06:47:16 +00:00
|
|
|
MINLINE void copy_sh_sh(float r[9], const float a[9]);
|
|
|
|
MINLINE void mul_sh_fl(float r[9], const float f);
|
|
|
|
MINLINE void add_sh_shsh(float r[9], const float a[9], const float b[9]);
|
2013-12-06 03:46:27 +11:00
|
|
|
MINLINE float dot_shsh(const float a[9], const float b[9]);
|
2011-04-20 06:47:16 +00:00
|
|
|
|
|
|
|
MINLINE float eval_shv3(float r[9], const float v[3]);
|
|
|
|
MINLINE float diffuse_shv3(float r[9], const float v[3]);
|
|
|
|
MINLINE void vec_fac_to_sh(float r[9], const float v[3], const float f);
|
|
|
|
MINLINE void madd_sh_shfl(float r[9], const float sh[3], const float f);
|
2009-11-25 23:54:21 +00:00
|
|
|
|
2010-04-15 10:28:32 +00:00
|
|
|
/********************************* Form Factor *******************************/
|
2009-11-25 23:54:21 +00:00
|
|
|
|
2013-03-03 05:07:58 +00:00
|
|
|
float form_factor_quad(const float p[3], const float n[3],
|
|
|
|
const float q0[3], const float q1[3], const float q2[3], const float q3[3]);
|
2013-08-01 17:15:11 +00:00
|
|
|
bool form_factor_visible_quad(const float p[3], const float n[3],
|
|
|
|
const float v0[3], const float v1[3], const float v2[3],
|
|
|
|
float q0[3], float q1[3], float q2[3], float q3[3]);
|
2010-04-15 10:28:32 +00:00
|
|
|
float form_factor_hemi_poly(float p[3], float n[3],
|
2012-05-12 20:39:39 +00:00
|
|
|
float v1[3], float v2[3], float v3[3], float v4[3]);
|
2009-11-25 23:54:21 +00:00
|
|
|
|
2015-07-14 22:09:14 +10:00
|
|
|
void axis_dominant_v3_to_m3_negate(float r_mat[3][3], const float normal[3]);
|
2014-04-16 21:04:17 +10:00
|
|
|
void axis_dominant_v3_to_m3(float r_mat[3][3], const float normal[3]);
|
2014-03-16 16:31:19 +01:00
|
|
|
|
|
|
|
MINLINE void axis_dominant_v3(int *r_axis_a, int *r_axis_b, const float axis[3]);
|
|
|
|
MINLINE float axis_dominant_v3_max(int *r_axis_a, int *r_axis_b, const float axis[3]) ATTR_WARN_UNUSED_RESULT;
|
|
|
|
MINLINE int axis_dominant_v3_single(const float vec[3]);
|
2011-12-02 22:14:20 +00:00
|
|
|
|
2012-10-24 02:25:00 +00:00
|
|
|
MINLINE int max_axis_v3(const float vec[3]);
|
|
|
|
MINLINE int min_axis_v3(const float vec[3]);
|
2012-10-23 16:32:39 +00:00
|
|
|
|
2012-12-27 03:51:45 +00:00
|
|
|
MINLINE int poly_to_tri_count(const int poly_count, const int corner_count);
|
|
|
|
|
2014-04-19 22:12:50 +10:00
|
|
|
MINLINE float shell_angle_to_dist(const float angle);
|
|
|
|
MINLINE float shell_v3v3_normalized_to_dist(const float a[3], const float b[3]);
|
|
|
|
MINLINE float shell_v2v2_normalized_to_dist(const float a[2], const float b[2]);
|
2014-04-23 04:23:54 +10:00
|
|
|
MINLINE float shell_v3v3_mid_normalized_to_dist(const float a[3], const float b[3]);
|
|
|
|
MINLINE float shell_v2v2_mid_normalized_to_dist(const float a[2], const float b[2]);
|
2014-04-19 22:12:50 +10:00
|
|
|
|
2014-03-20 10:08:19 +01:00
|
|
|
/**************************** Inline Definitions ******************************/
|
|
|
|
|
|
|
|
#if BLI_MATH_DO_INLINE
|
|
|
|
#include "intern/math_geom_inline.c"
|
|
|
|
#endif
|
|
|
|
|
2013-03-13 15:41:14 +00:00
|
|
|
#ifdef BLI_MATH_GCC_WARN_PRAGMA
|
2013-03-11 20:27:38 +00:00
|
|
|
# pragma GCC diagnostic pop
|
|
|
|
#endif
|
|
|
|
|
2009-11-09 22:42:41 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2012-02-17 18:59:41 +00:00
|
|
|
#endif /* __BLI_MATH_GEOM_H__ */
|
2009-11-09 22:42:41 +00:00
|
|
|
|