Blender V4.3
math_vector.c File Reference
#include "BLI_math_vector.h"
#include "BLI_math_base_safe.h"
#include "BLI_math_geom.h"
#include "BLI_math_rotation.h"
#include "BLI_strict_flags.h"

Go to the source code of this file.

Macros

#define SWAP_AXIS(a, b)
 

Functions

Interpolation
void interp_v2_v2v2 (float r[2], const float a[2], const float b[2], const float t)
 
void interp_v2_v2v2v2 (float r[2], const float a[2], const float b[2], const float c[2], const float t[3])
 
void interp_v3_v3v3 (float r[3], const float a[3], const float b[3], const float t)
 
void interp_v4_v4v4 (float r[4], const float a[4], const float b[4], const float t)
 
bool interp_v3_v3v3_slerp (float target[3], const float a[3], const float b[3], const float t)
 
bool interp_v2_v2v2_slerp (float target[2], const float a[2], const float b[2], const float t)
 
void interp_v3_v3v3_slerp_safe (float target[3], const float a[3], const float b[3], const float t)
 
void interp_v2_v2v2_slerp_safe (float target[2], const float a[2], const float b[2], const float t)
 
void interp_v2_v2v2v2v2_cubic (float p[2], const float v1[2], const float v2[2], const float v3[2], const float v4[2], const float u)
 
void interp_v3_v3v3v3 (float p[3], const float v1[3], const float v2[3], const float v3[3], const float w[3])
 
void interp_v3_v3v3v3v3 (float p[3], const float v1[3], const float v2[3], const float v3[3], const float v4[3], const float w[4])
 
void interp_v4_v4v4v4 (float p[4], const float v1[4], const float v2[4], const float v3[4], const float w[3])
 
void interp_v4_v4v4v4v4 (float p[4], const float v1[4], const float v2[4], const float v3[4], const float v4[4], const float w[4])
 
void interp_v3_v3v3v3_uv (float p[3], const float v1[3], const float v2[3], const float v3[3], const float uv[2])
 
void interp_v3_v3v3_uchar (uchar target[3], const uchar a[3], const uchar b[3], const float t)
 
void interp_v3_v3v3_char (char target[3], const char a[3], const char b[3], const float t)
 
void interp_v4_v4v4_uchar (uchar target[4], const uchar a[4], const uchar b[4], const float t)
 
void interp_v4_v4v4_char (char target[4], const char a[4], const char b[4], const float t)
 
void mid_v3_v3v3 (float r[3], const float a[3], const float b[3])
 
void mid_v2_v2v2 (float r[2], const float a[2], const float b[2])
 
void mid_v2_v2v2v2 (float v[2], const float v1[2], const float v2[2], const float v3[2])
 
void mid_v3_v3v3v3 (float v[3], const float v1[3], const float v2[3], const float v3[3])
 
void mid_v3_v3v3v3v3 (float v[3], const float v1[3], const float v2[3], const float v3[3], const float v4[3])
 
void mid_v3_v3_array (float r[3], const float(*vec_arr)[3], const uint vec_arr_num)
 
void mid_v3_v3v3_angle_weighted (float r[3], const float a[3], const float b[3])
 
void mid_v3_angle_weighted (float r[3])
 
void flip_v4_v4v4 (float v[4], const float v1[4], const float v2[4])
 
void flip_v3_v3v3 (float v[3], const float v1[3], const float v2[3])
 
void flip_v2_v2v2 (float v[2], const float v1[2], const float v2[2])
 
Comparison
bool is_finite_v2 (const float v[2])
 
bool is_finite_v3 (const float v[3])
 
bool is_finite_v4 (const float v[4])
 
Angles
float angle_v3v3v3 (const float a[3], const float b[3], const float c[3])
 
float cos_v3v3v3 (const float p1[3], const float p2[3], const float p3[3])
 
float angle_v3v3 (const float a[3], const float b[3])
 
float angle_v2v2v2 (const float a[2], const float b[2], const float c[2])
 
float cos_v2v2v2 (const float p1[2], const float p2[2], const float p3[2])
 
float angle_v2v2 (const float a[2], const float b[2])
 
float angle_signed_v2v2 (const float v1[2], const float v2[2])
 
float angle_normalized_v3v3 (const float v1[3], const float v2[3])
 
float angle_normalized_v2v2 (const float a[2], const float b[2])
 
float angle_on_axis_v3v3_v3 (const float v1[3], const float v2[3], const float axis[3])
 
float angle_signed_on_axis_v3v3_v3 (const float v1[3], const float v2[3], const float axis[3])
 
float angle_on_axis_v3v3v3_v3 (const float v1[3], const float v2[3], const float v3[3], const float axis[3])
 
float angle_signed_on_axis_v3v3v3_v3 (const float v1[3], const float v2[3], const float v3[3], const float axis[3])
 
void angle_tri_v3 (float angles[3], const float v1[3], const float v2[3], const float v3[3])
 
void angle_quad_v3 (float angles[4], const float v1[3], const float v2[3], const float v3[3], const float v4[3])
 
void angle_poly_v3 (float *angles, const float *verts[3], int len)
 
Geometry
void project_v2_v2v2 (float out[2], const float p[2], const float v_proj[2])
 
void project_v3_v3v3 (float out[3], const float p[3], const float v_proj[3])
 
void project_v3_v3v3_db (double out[3], const double p[3], const double v_proj[3])
 
void project_v2_v2v2_normalized (float out[2], const float p[2], const float v_proj[2])
 
void project_v3_v3v3_normalized (float out[3], const float p[3], const float v_proj[3])
 
void project_plane_v3_v3v3 (float out[3], const float p[3], const float v_plane[3])
 
void project_plane_v2_v2v2 (float out[2], const float p[2], const float v_plane[2])
 
void project_plane_normalized_v3_v3v3 (float out[3], const float p[3], const float v_plane[3])
 
void project_plane_normalized_v2_v2v2 (float out[2], const float p[2], const float v_plane[2])
 
void project_v3_plane (float out[3], const float plane_no[3], const float plane_co[3])
 
void bisect_v3_v3v3v3 (float r[3], const float a[3], const float b[3], const float c[3])
 
void reflect_v3_v3v3 (float out[3], const float v[3], const float normal[3])
 
void reflect_v3_v3v3_db (double out[3], const double v[3], const double normal[3])
 
void ortho_basis_v3v3_v3 (float r_n1[3], float r_n2[3], const float n[3])
 
void ortho_v3_v3 (float out[3], const float v[3])
 
void ortho_v2_v2 (float out[2], const float v[2])
 
void rotate_v2_v2fl (float r[2], const float p[2], const float angle)
 
void rotate_normalized_v3_v3v3fl (float out[3], const float p[3], const float axis[3], const float angle)
 
void rotate_v3_v3v3fl (float r[3], const float p[3], const float axis[3], const float angle)
 
Other
void print_v2 (const char *str, const float v[2])
 
void print_v3 (const char *str, const float v[3])
 
void print_v4 (const char *str, const float v[4])
 
void print_vn (const char *str, const float v[], const int n)
 
void minmax_v4v4_v4 (float min[4], float max[4], const float vec[4])
 
void minmax_v3v3_v3 (float min[3], float max[3], const float vec[3])
 
void minmax_v2v2_v2 (float min[2], float max[2], const float vec[2])
 
void dist_ensure_v3_v3fl (float v1[3], const float v2[3], const float dist)
 
void dist_ensure_v2_v2fl (float v1[2], const float v2[2], const float dist)
 
void axis_sort_v3 (const float axis_values[3], int r_axis_order[3])
 
Array Functions
MINLINE double sqr_db (double f)
 
double dot_vn_vn (const float *array_src_a, const float *array_src_b, const int size)
 
double len_squared_vn (const float *array, const int size)
 
float normalize_vn_vn (float *array_tar, const float *array_src, const int size)
 
float normalize_vn (float *array_tar, const int size)
 
void range_vn_i (int *array_tar, const int size, const int start)
 
void range_vn_u (uint *array_tar, const int size, const uint start)
 
void range_vn_fl (float *array_tar, const int size, const float start, const float step)
 
void negate_vn (float *array_tar, const int size)
 
void negate_vn_vn (float *array_tar, const float *array_src, const int size)
 
void mul_vn_vn (float *array_tar, const float *array_src, const int size)
 
void mul_vn_vnvn (float *array_tar, const float *array_src_a, const float *array_src_b, const int size)
 
void mul_vn_fl (float *array_tar, const int size, const float f)
 
void mul_vn_vn_fl (float *array_tar, const float *array_src, const int size, const float f)
 
void add_vn_vn (float *array_tar, const float *array_src, const int size)
 
void add_vn_vnvn (float *array_tar, const float *array_src_a, const float *array_src_b, const int size)
 
void madd_vn_vn (float *array_tar, const float *array_src, const float f, const int size)
 
void madd_vn_vnvn (float *array_tar, const float *array_src_a, const float *array_src_b, const float f, const int size)
 
void sub_vn_vn (float *array_tar, const float *array_src, const int size)
 
void sub_vn_vnvn (float *array_tar, const float *array_src_a, const float *array_src_b, const int size)
 
void msub_vn_vn (float *array_tar, const float *array_src, const float f, const int size)
 
void msub_vn_vnvn (float *array_tar, const float *array_src_a, const float *array_src_b, const float f, const int size)
 
void interp_vn_vn (float *array_tar, const float *array_src, const float t, const int size)
 
void copy_vn_i (int *array_tar, const int size, const int val)
 
void copy_vn_short (short *array_tar, const int size, const short val)
 
void copy_vn_ushort (ushort *array_tar, const int size, const ushort val)
 
void copy_vn_uchar (uchar *array_tar, const int size, const uchar val)
 
void copy_vn_fl (float *array_tar, const int size, const float val)
 
Double precision versions 'db'.
void add_vn_vn_d (double *array_tar, const double *array_src, const int size)
 
void add_vn_vnvn_d (double *array_tar, const double *array_src_a, const double *array_src_b, const int size)
 
void mul_vn_db (double *array_tar, const int size, const double f)
 
void interp_v3_v3v3_db (double target[3], const double a[3], const double b[3], const double t)
 
void interp_v2_v2v2_db (double target[2], const double a[2], const double b[2], const double t)
 

Macro Definition Documentation

◆ SWAP_AXIS

#define SWAP_AXIS ( a,
b )
Value:
{ \
SWAP(float, v[a], v[b]); \
SWAP(int, r_axis_order[a], r_axis_order[b]); \
} \
(void)0
ATTR_WARN_UNUSED_RESULT const BMVert * v
local_group_size(16, 16) .push_constant(Type b

Referenced by axis_sort_v3().

Function Documentation

◆ add_vn_vn()

void add_vn_vn ( float * array_tar,
const float * array_src,
const int size )

Definition at line 1123 of file math_vector.c.

References size().

Referenced by Color_iadd(), and Vector_iadd().

◆ add_vn_vn_d()

void add_vn_vn_d ( double * array_tar,
const double * array_src,
const int size )

Definition at line 1285 of file math_vector.c.

References size().

Referenced by BLI_quadric_add_qu_qu().

◆ add_vn_vnvn()

void add_vn_vnvn ( float * array_tar,
const float * array_src_a,
const float * array_src_b,
const int size )

Definition at line 1133 of file math_vector.c.

References size().

Referenced by Color_add(), Matrix_add(), and Vector_add().

◆ add_vn_vnvn_d()

void add_vn_vnvn_d ( double * array_tar,
const double * array_src_a,
const double * array_src_b,
const int size )

Definition at line 1295 of file math_vector.c.

References size().

Referenced by BLI_quadric_add_qu_ququ().

◆ angle_normalized_v2v2()

◆ angle_normalized_v3v3()

float angle_normalized_v3v3 ( const float v1[3],
const float v2[3] )

Definition at line 454 of file math_vector.c.

References BLI_ASSERT_UNIT_V3, dot_v3v3(), len_v3v3(), M_PI, negate_v3_v3(), safe_asinf(), and v2.

Referenced by blender::nodes::node_fn_align_euler_to_vector_cc::align_rotations_auto_pivot(), blender::nodes::node_fn_align_rotation_to_vector_cc::align_rotations_auto_pivot(), angle_poly_v3(), angle_quad_v3(), angle_tri_v3(), angle_v3v3(), angle_v3v3v3(), bevel_list_flip_tangents(), bevel_list_smooth(), BM_edge_calc_face_angle_ex(), BM_edge_calc_face_angle_signed_ex(), BM_edge_calc_face_angle_with_imat3_ex(), bm_edge_calc_rotate_beauty__angle(), bm_edge_is_delimit(), bm_edgering_pair_interpolate(), bm_interior_face_group_calc_cost(), build_emats_stack(), calc_solidify_normals(), blender::bke::curves::poly::calculate_next_normal(), computeBindWeights(), connection_node_mat(), curve_nurb_select_similar_type(), DRW_text_edit_mesh_measure_stats(), edbm_dupli_extrude_cursor_invoke(), edge_face_angle(), blender::draw::edituv_get_edituv_stretch_angle(), blender::bke::mesh::face_angles_calc(), blender::nodes::node_geo_input_mesh_edge_angle_cc::AngleFieldInput::get_varray_for_context(), blender::nodes::node_geo_input_mesh_edge_angle_cc::SignedAngleFieldInput::get_varray_for_context(), gizmo_ruler_draw(), knifetool_draw_angle(), make_bevel_list_3D_minimum_twist(), map_to_plane_v2_v3v3(), mball_select_similar_type(), mesh_calc_hq_normal(), minimum_twist_between_two_points(), MOD_solidify_extrude_modifyMesh(), offset_meet_edge(), pipe_test(), point_between_edges(), quad_calc_error(), rotation_between_vecs_to_quat(), similar_edge_select_exec(), similar_face_select_exec(), similar_vert_select_exec(), blender::draw::statvis_calc_distort(), blender::draw::statvis_calc_overhang(), blender::draw::statvis_calc_sharp(), viewrotate_apply(), and viewrotate_apply_snap().

◆ angle_on_axis_v3v3_v3()

float angle_on_axis_v3v3_v3 ( const float v1[3],
const float v2[3],
const float axis[3] )

Angle between 2 vectors, about an axis (axis can be considered a plane).

Definition at line 486 of file math_vector.c.

References angle_v3v3(), project_plane_normalized_v3_v3v3(), and v2.

Referenced by angle_on_axis_v3v3v3_v3(), and blender::write_weights_for_drawing().

◆ angle_on_axis_v3v3v3_v3()

float angle_on_axis_v3v3v3_v3 ( const float v1[3],
const float v2[3],
const float v3[3],
const float axis[3] )

Angle between 2 vectors defined by 3 coords, about an axis (axis can be considered a plane).

Definition at line 517 of file math_vector.c.

References angle_on_axis_v3v3_v3(), sub_v3_v3v3(), and v2.

Referenced by BM_mesh_wireframe().

◆ angle_poly_v3()

void angle_poly_v3 ( float * angles,
const float * verts[3],
int len )

Definition at line 582 of file math_vector.c.

References angle_normalized_v3v3(), float, len, M_PI, normalize_v3(), sub_v3_v3v3(), and verts.

Referenced by solidify_add_thickness().

◆ angle_quad_v3()

void angle_quad_v3 ( float angles[4],
const float v1[3],
const float v2[3],
const float v3[3],
const float v4[3] )

Definition at line 561 of file math_vector.c.

References angle_normalized_v3v3(), float, M_PI, normalize_v3(), sub_v3_v3v3(), and v2.

◆ angle_signed_on_axis_v3v3_v3()

◆ angle_signed_on_axis_v3v3v3_v3()

float angle_signed_on_axis_v3v3v3_v3 ( const float v1[3],
const float v2[3],
const float v3[3],
const float axis[3] )

◆ angle_signed_v2v2()

◆ angle_tri_v3()

void angle_tri_v3 ( float angles[3],
const float v1[3],
const float v2[3],
const float v3[3] )

Definition at line 543 of file math_vector.c.

References angle_normalized_v3v3(), float, M_PI, normalize_v3(), sub_v3_v3v3(), and v2.

◆ angle_v2v2()

float angle_v2v2 ( const float a[2],
const float b[2] )

Return the shortest angle in radians between the 2 vectors.

Definition at line 432 of file math_vector.c.

References angle_normalized_v2v2(), b, and normalize_v2().

Referenced by bezt_edge_handle_angle(), BKE_mask_spline_project_co(), bm_loop_calc_uv_angle_from_dir(), get_updated_data_for_edge(), and uv_rip_pairs_calc_uv_angle().

◆ angle_v2v2v2()

float angle_v2v2v2 ( const float a[2],
const float b[2],
const float c[2] )

◆ angle_v3v3()

◆ angle_v3v3v3()

float angle_v3v3v3 ( const float a[3],
const float b[3],
const float c[3] )

Return the angle in radians between vecs 1-2 and 2-3 in radians If v1 is a shoulder, v2 is the elbow and v3 is the hand, this would return the angle at the elbow.

note that when v1/v2/v3 represent 3 points along a straight line that the angle returned will be pi (180deg), rather than 0.0.

Definition at line 370 of file math_vector.c.

References angle_normalized_v3v3(), b, normalize_v3(), and sub_v3_v3v3().

Referenced by BM_loop_calc_face_angle(), BM_vert_calc_edge_angle_ex(), DRW_text_edit_mesh_measure_stats(), edbm_fill_grid_vert_tag_angle(), geometry_collide_offset(), knifetool_draw_visible_angles(), laplacian_triangle_area(), mesh_customdatacorrect_init_vert(), MOD_solidify_nonmanifold_modifyMesh(), blender::geometry::p_edge_boundary_angle(), blender::geometry::p_triangle_angles(), ruler_item_as_string(), square_out_adj_vmesh(), and VoronoiVertexWeight::VoronoiVertexWeight().

◆ axis_sort_v3()

void axis_sort_v3 ( const float axis_values[3],
int r_axis_order[3] )

Definition at line 946 of file math_vector.c.

References copy_v3_v3(), SWAP_AXIS, and v.

Referenced by bm_vert_tri_find_unique_edge(), draw_view_axis(), and splineik_evaluate_bone().

◆ bisect_v3_v3v3v3()

void bisect_v3_v3v3v3 ( float r[3],
const float a[3],
const float b[3],
const float c[3] )

Returns a vector bisecting the angle at b formed by a, b and c.

Definition at line 693 of file math_vector.c.

References add_v3_v3v3(), b, normalize_v3(), and sub_v3_v3v3().

Referenced by bevel_list_calc_bisect(), bm_edgering_pair_interpolate(), and make_bevel_list_2D().

◆ copy_vn_fl()

◆ copy_vn_i()

◆ copy_vn_short()

void copy_vn_short ( short * array_tar,
const int size,
const short val )

Definition at line 1243 of file math_vector.c.

References size().

Referenced by initNumInput().

◆ copy_vn_uchar()

void copy_vn_uchar ( uchar * array_tar,
const int size,
const uchar val )

Definition at line 1261 of file math_vector.c.

References size().

◆ copy_vn_ushort()

void copy_vn_ushort ( ushort * array_tar,
const int size,
const ushort val )

Definition at line 1252 of file math_vector.c.

References size().

◆ cos_v2v2v2()

float cos_v2v2v2 ( const float p1[2],
const float p2[2],
const float p3[2] )

Quicker than full angle computation.

Definition at line 420 of file math_vector.c.

References dot_v2v2(), normalize_v2(), and sub_v2_v2v2().

Referenced by get_updated_data_for_edge(), and scanfill().

◆ cos_v3v3v3()

float cos_v3v3v3 ( const float p1[3],
const float p2[3],
const float p3[3] )

Quicker than full angle computation.

Definition at line 382 of file math_vector.c.

References dot_v3v3(), normalize_v3(), and sub_v3_v3v3().

Referenced by bm_vert_collapse_is_degenerate(), and blender::geometry::p_vec_cos().

◆ dist_ensure_v2_v2fl()

◆ dist_ensure_v3_v3fl()

void dist_ensure_v3_v3fl ( float v1[3],
const float v2[3],
float dist )

ensure v1 is dist from v2

Definition at line 924 of file math_vector.c.

References equals_v3v3(), madd_v3_v3v3fl(), nor, normalize_v3(), sub_v3_v3v3(), and v2.

Referenced by Bend(), BKE_nurbList_handles_recalculate(), and brush_puff().

◆ dot_vn_vn()

double dot_vn_vn ( const float * array_src_a,
const float * array_src_b,
const int size )

◆ flip_v2_v2v2()

void flip_v2_v2v2 ( float v[2],
const float v1[2],
const float v2[2] )

Definition at line 337 of file math_vector.c.

References v, and v2.

◆ flip_v3_v3v3()

void flip_v3_v3v3 ( float v[3],
const float v1[3],
const float v2[3] )

Definition at line 330 of file math_vector.c.

References v, and v2.

◆ flip_v4_v4v4()

void flip_v4_v4v4 ( float v[4],
const float v1[4],
const float v2[4] )

Equivalent to: interp_v3_v3v3(v, v1, v2, -1.0f);

Definition at line 322 of file math_vector.c.

References v, and v2.

◆ interp_v2_v2v2()

◆ interp_v2_v2v2_db()

void interp_v2_v2v2_db ( double target[2],
const double a[2],
const double b[2],
const double t )

Definition at line 1327 of file math_vector.c.

References b.

Referenced by lineart_edge_first_bounding_area().

◆ interp_v2_v2v2_slerp()

bool interp_v2_v2v2_slerp ( float target[2],
const float a[2],
const float b[2],
const float t )

Definition at line 77 of file math_vector.c.

References b, BLI_ASSERT_UNIT_V2, dot_v2v2(), interp_dot_slerp(), UNLIKELY, and w().

Referenced by interp_v2_v2v2_slerp_safe().

◆ interp_v2_v2v2_slerp_safe()

void interp_v2_v2v2_slerp_safe ( float target[2],
const float a[2],
const float b[2],
const float t )

Definition at line 120 of file math_vector.c.

References b, BLI_assert, copy_v2_v2(), interp_v2_v2v2_slerp(), ortho_v2_v2(), and UNLIKELY.

◆ interp_v2_v2v2v2()

void interp_v2_v2v2v2 ( float r[2],
const float a[2],
const float b[2],
const float c[2],
const float t[3] )

Weight 3 2D vectors, 'w' must be unit length but is not a vector, just 3 weights.

Definition at line 29 of file math_vector.c.

References b.

Referenced by project_bucket_clip_face(), project_face_pixel(), project_paint_PickColor(), rect_to_uvspace_ortho(), and rect_to_uvspace_persp().

◆ interp_v2_v2v2v2v2_cubic()

void interp_v2_v2v2v2v2_cubic ( float p[2],
const float v1[2],
const float v2[2],
const float v3[2],
const float v4[2],
float u )

Cubic curve interpolation (bezier spline).

Definition at line 142 of file math_vector.c.

References interp_v2_v2v2(), q1, and v2.

Referenced by BKE_mask_point_segment_co(), and wm_xr_navigation_fly_modal().

◆ interp_v3_v3v3()

void interp_v3_v3v3 ( float r[3],
const float a[3],
const float b[3],
const float t )

Definition at line 36 of file math_vector.c.

References b.

Referenced by alter_co(), BKE_gpencil_stroke_close(), BKE_gpencil_stroke_smooth_point(), BKE_lattice_deform_data_eval_co(), BKE_mesh_remap_calc_edges_from_mesh(), blend_m3_m3m3(), blend_m4_m4m4(), bm_bridge_splice_loops(), bm_decim_edge_collapse(), bm_edgering_pair_interpolate(), bm_face_split_edge_find(), bm_grid_fill_array(), bm_isect_tri_tri(), bm_subdivide_edge_addvert(), bmo_planar_faces_exec(), bmo_smooth_vert_exec(), boid_find_ground(), bone_locked_color_shade(), calculate_new_bezier_point(), calculate_profile_segments(), blender::nodes::node_shader_curves_cc::rgb::CurveRGBFunction::call(), blender::nodes::node_shader_curves_cc::vec::CurveVecFunction::call(), blender::bke::pbvh::clip_ray_ortho(), closest_ray_to_segment_v3(), cloth_calc_average_acceleration(), cloth_calc_force(), cloth_collision_response_static(), cloth_continuum_step(), collision_move_object(), collision_newton_rhapson(), collision_response(), compute_collision_point_edge_tri(), constraint_target_to_mat4(), converge(), dist_squared_ray_to_seg_v3(), distlimit_evaluate(), do_clump_level(), do_guides(), do_kink(), do_kink_spiral(), draw_frustum_bound_sphere_calc(), edbm_blend_from_shape_exec(), evaluate_cubic_bezier(), find_nearest_edge__doClosest(), flyApply(), blender::draw::View::frustum_culling_sphere_calc(), get_bezier_interpolated_point(), GPENCIL_draw_scene(), graph_refresh_fcurve_colors(), hook_co_apply(), interp_line_v3_v3v3v3(), interp_m3_m3m3(), interp_m4_m4m4(), interp_slerp_co_no_v3(), interpolate_pathcache(), intersect_line_tri(), isect_tri_tri_v3_ex(), knife_closest_constrain_to_edge(), limit_dist_v3(), lineart_chain_create_crossing_point(), loop_interp_multires_cb(), mesh_symmetry_snap_exec(), meshcache_do(), mixColors(), blender::ed::space_node::nodelink_get_draw_config(), offset_on_edge_between(), pipe_adj_vmesh(), position_tail_on_spline(), project_paint_face_init(), psys_cache_edit_paths_iter(), psys_get_particle_state(), ptcache_rigidbody_interpolate(), blender::ed::sculpt_paint::rake_data_update(), blender::io::alembic::read_mverts_interp(), rotateBevelPiece(), shrinkwrap_calc_nearest_surface_point_cb_ex(), shrinkwrap_calc_nearest_vertex_cb_ex(), shrinkwrap_calc_normal_projection_cb_ex(), shrinkwrap_get_tarmat(), shrinkwrap_snap_with_side(), SIM_cloth_solve(), SIM_hair_volume_add_segment(), SIM_hair_volume_grid_velocity(), SIM_hair_volume_solve_divergence(), simple_helper(), skin_smooth_hulls(), SnapData::snap_edge_points_impl(), splineik_evaluate_bone(), square_out_adj_vmesh(), state_calc_co_pair(), blender::ed::curves::stroke_elem_interp(), stroke_elem_interp(), subdivide_base(), subdividenurb(), target_project_edge(), timeline_cache_draw_single(), track_channel_color(), transdata_elem_bend(), transform_point_by_seg_v3(), tri_v3_scale(), ui_draw_but_CURVE(), ui_draw_but_CURVEPROFILE(), blender::compositor::ColorCurveOperation::update_memory_buffer_partial(), blender::compositor::ConstantLevelColorCurveOperation::update_memory_buffer_partial(), vert_slide_apply_elem(), view3d_preselect_mesh_edgering_update_edges_from_edge(), view3d_preselect_mesh_edgering_update_verts_from_edge(), view3d_smoothview_apply_with_interp(), viewrotate_apply(), warpModifier_do(), and WIDGETGROUP_xform_shear_setup().

◆ interp_v3_v3v3_char()

void interp_v3_v3v3_char ( char target[3],
const char a[3],
const char b[3],
const float t )

Definition at line 219 of file math_vector.c.

References b, and interp_v3_v3v3_uchar().

◆ interp_v3_v3v3_db()

◆ interp_v3_v3v3_slerp()

bool interp_v3_v3v3_slerp ( float target[3],
const float a[3],
const float b[3],
float t )

slerp, treat vectors as spherical coordinates

See also
interp_qt_qtqt
Returns
success

Definition at line 55 of file math_vector.c.

References b, BLI_ASSERT_UNIT_V3, dot_v3v3(), interp_dot_slerp(), UNLIKELY, and w().

Referenced by interp_slerp_co_no_v3(), and interp_v3_v3v3_slerp_safe().

◆ interp_v3_v3v3_slerp_safe()

void interp_v3_v3v3_slerp_safe ( float target[3],
const float a[3],
const float b[3],
float t )

◆ interp_v3_v3v3_uchar()

void interp_v3_v3v3_uchar ( uchar target[3],
const uchar a[3],
const uchar b[3],
const float t )

Definition at line 211 of file math_vector.c.

References b, and floorf.

Referenced by interp_v3_v3v3_char(), and widget_tab().

◆ interp_v3_v3v3v3()

◆ interp_v3_v3v3v3_uv()

void interp_v3_v3v3v3_uv ( float p[3],
const float v1[3],
const float v2[3],
const float v3[3],
const float uv[2] )

◆ interp_v3_v3v3v3v3()

void interp_v3_v3v3v3v3 ( float p[3],
const float v1[3],
const float v2[3],
const float v3[3],
const float v4[3],
const float w[4] )

Weight 3 vectors, 'w' must be unit length but is not a vector, just 4 weights.

Definition at line 169 of file math_vector.c.

References v2, and w().

Referenced by BKE_where_on_path(), psys_interpolate_face(), psys_interpolate_particle(), and psys_thread_create_path().

◆ interp_v4_v4v4()

◆ interp_v4_v4v4_char()

void interp_v4_v4v4_char ( char target[4],
const char a[4],
const char b[4],
const float t )

Definition at line 233 of file math_vector.c.

References b, and interp_v4_v4v4_uchar().

◆ interp_v4_v4v4_uchar()

void interp_v4_v4v4_uchar ( uchar target[4],
const uchar a[4],
const uchar b[4],
const float t )

Definition at line 224 of file math_vector.c.

References b, and floorf.

Referenced by interp_v4_v4v4_char().

◆ interp_v4_v4v4v4()

void interp_v4_v4v4v4 ( float p[4],
const float v1[4],
const float v2[4],
const float v3[4],
const float w[3] )

Definition at line 181 of file math_vector.c.

References v2, and w().

Referenced by dynamic_paint_set_init_color_vcol_to_imseq_cb(), and blender::bke::attribute_math::mix3().

◆ interp_v4_v4v4v4v4()

void interp_v4_v4v4v4v4 ( float p[4],
const float v1[4],
const float v2[4],
const float v3[4],
const float v4[4],
const float w[4] )

Definition at line 190 of file math_vector.c.

References v2, and w().

Referenced by blender::bke::attribute_math::mix4(), and blender::bke::attribute_math::mix4().

◆ interp_vn_vn()

void interp_vn_vn ( float * array_tar,
const float * array_src,
const float t,
const int size )

Definition at line 1221 of file math_vector.c.

References size().

Referenced by meshcache_do(), and Vector_lerp().

◆ is_finite_v2()

bool is_finite_v2 ( const float v[2])

Definition at line 349 of file math_vector.c.

References v.

Referenced by accumulate_marker().

◆ is_finite_v3()

◆ is_finite_v4()

bool is_finite_v4 ( const float v[4])

Definition at line 359 of file math_vector.c.

References v.

Referenced by barycentric_weights_v2_quad(), and blender::ed::sculpt_paint::color::do_paint_brush().

◆ len_squared_vn()

double len_squared_vn ( const float * array,
const int size )

Definition at line 1001 of file math_vector.c.

References size(), and sqr_db().

Referenced by normalize_vn_vn(), and Vector_richcmpr().

◆ madd_vn_vn()

void madd_vn_vn ( float * array_tar,
const float * array_src,
const float f,
const int size )

Definition at line 1147 of file math_vector.c.

References size().

◆ madd_vn_vnvn()

void madd_vn_vnvn ( float * array_tar,
const float * array_src_a,
const float * array_src_b,
const float f,
const int size )

Definition at line 1157 of file math_vector.c.

References size().

◆ mid_v2_v2v2()

◆ mid_v2_v2v2v2()

void mid_v2_v2v2v2 ( float v[2],
const float v1[2],
const float v2[2],
const float v3[2] )

Definition at line 251 of file math_vector.c.

References v, and v2.

Referenced by overlap_tri_tri_uv_test().

◆ mid_v3_angle_weighted()

void mid_v3_angle_weighted ( float r[3])

Same as mid_v3_v3v3_angle_weighted but r is assumed to be accumulated normals, divided by their total.

Definition at line 300 of file math_vector.c.

References acosf, angle(), BLI_assert, float, len_squared_v3(), mul_v3_fl(), and normalize_v3().

◆ mid_v3_v3_array()

void mid_v3_v3_array ( float r[3],
const float(*) vec_arr[3],
const uint vec_arr_num )

Definition at line 272 of file math_vector.c.

References float, madd_v3_v3fl(), and zero_v3().

Referenced by computeBindWeights(), and deformVert().

◆ mid_v3_v3v3()

void mid_v3_v3v3 ( float r[3],
const float a[3],
const float b[3] )

Definition at line 238 of file math_vector.c.

References b.

Referenced by _scan_for_ext_spring_forces(), _softbody_calc_forces_slice_in_a_thread(), alter_co(), BKE_curve_texspace_calc(), BKE_mball_center_bounds(), BKE_mesh_mirror_apply_mirror_on_axis_for_modifier(), BKE_mesh_remesh_voxel_fix_poles(), BKE_mesh_texspace_calc(), bm_decim_build_quadrics(), bm_edge_symmetry_map(), BM_editselection_center(), BM_face_calc_center_bounds(), BM_face_calc_center_bounds_vcos(), BM_face_multires_bounds_smooth(), BM_vert_tri_calc_tangent_edge_pair(), bm_vert_tri_find_unique_edge(), BMBVH_EdgeVisible(), bmo_inset_region_exec(), brush_edit_init(), build_vmesh(), bundle_midpoint(), calc_ortho_extent(), calculateCenterBound(), blender::bke::pbvh::clip_ray_ortho(), collapse_face_corners(), compute_mdisp_quad(), createTransEdge(), cutEdges(), draw_bone_name(), draw_frustum_bound_sphere_calc(), draw_primitive_view_impl(), drw_call_calc_orco(), drw_call_culling_init(), ED_armature_origin_set(), edbm_face_split_by_edges_exec(), edbm_point_normals_modal(), edbm_polybuild_face_at_cursor_invoke(), edbm_polybuild_split_at_cursor_invoke(), edbm_rip_invoke__vert(), EDBM_unified_findnearest_from_raycast(), edgetag_cut_cost_face(), facetag_cut_cost_edge(), find_first_points(), blender::draw::View::frustum_culling_sphere_calc(), gizmo_3d_calc_pos(), interp_slerp_co_no_v3(), isect_face_dst(), isect_face_dst(), knife_find_closest_edge_of_face(), knife_find_line_hits(), knife_verts_edge_in_face(), match_texture_space_exec(), merge_frame_corners(), multires_subdivide_create_object_space_linear_grids(), blender::ed::object::object_origin_set_exec(), offset_meet(), offset_on_edge_between(), blender::bke::pbvh::pbvh_bmesh_collapse_edge(), blender::bke::pbvh::pbvh_bmesh_split_edge(), pchan_culling_calc_bsphere(), peelObjectsTransform(), quad_verts_to_barycentric_tri(), set_profile_params(), smoothModifier_do(), snap_curs_to_sel_ex(), SnapData::snap_edge_points_impl(), sort_bmelem_flag(), square_out_adj_vmesh(), uv_map_transform_center(), view3d_from_minmax(), view3d_interactive_add_modal(), view3d_localview_init(), view3d_preselect_update_preview_triangle_from_edge(), blender::ed::object::voxel_size_edit_invoke(), blender::ed::object::voxel_size_parallel_lines_draw(), and WIDGETGROUP_xform_cage_refresh().

◆ mid_v3_v3v3_angle_weighted()

void mid_v3_v3v3_angle_weighted ( float r[3],
const float a[3],
const float b[3] )

Specialized function for calculating normals. Fast-path for:

add_v3_v3v3(r, a, b);
#define M_PI_2
MINLINE void mul_v3_fl(float r[3], float f)
MINLINE void add_v3_v3v3(float r[3], const float a[3], const float b[3])
float angle_normalized_v3v3(const float v1[3], const float v2[3]) ATTR_WARN_UNUSED_RESULT
MINLINE float normalize_v3(float n[3])

We can use the length of (a + b) to calculate the angle.

Definition at line 282 of file math_vector.c.

References acosf, add_v3_v3v3(), angle(), b, BLI_ASSERT_UNIT_V3, float, mul_v3_fl(), and normalize_v3().

Referenced by mesh_calc_hq_normal().

◆ mid_v3_v3v3v3()

◆ mid_v3_v3v3v3v3()

void mid_v3_v3v3v3v3 ( float v[3],
const float v1[3],
const float v2[3],
const float v3[3],
const float v4[3] )

◆ minmax_v2v2_v2()

◆ minmax_v3v3_v3()

◆ minmax_v4v4_v4()

void minmax_v4v4_v4 ( float min[4],
float max[4],
const float vec[4] )

Definition at line 855 of file math_vector.c.

References min.

Referenced by layerDoMinMax_propcol().

◆ msub_vn_vn()

void msub_vn_vn ( float * array_tar,
const float * array_src,
const float f,
const int size )

Definition at line 1196 of file math_vector.c.

References size().

◆ msub_vn_vnvn()

void msub_vn_vnvn ( float * array_tar,
const float * array_src_a,
const float * array_src_b,
const float f,
const int size )

Definition at line 1206 of file math_vector.c.

References size().

◆ mul_vn_db()

void mul_vn_db ( double * array_tar,
const int size,
const double f )

Definition at line 1309 of file math_vector.c.

References size().

Referenced by BLI_quadric_mul().

◆ mul_vn_fl()

◆ mul_vn_vn()

void mul_vn_vn ( float * array_tar,
const float * array_src,
const int size )

Definition at line 1080 of file math_vector.c.

References size().

Referenced by Matrix_imul(), Quaternion_imul(), and Vector_imul().

◆ mul_vn_vn_fl()

void mul_vn_vn_fl ( float * array_tar,
const float * array_src,
const int size,
const float f )

Definition at line 1113 of file math_vector.c.

References size().

Referenced by color_mul_float(), matrix_mul_float(), normalize_vn_vn(), Vector_div(), and vector_mul_float().

◆ mul_vn_vnvn()

void mul_vn_vnvn ( float * array_tar,
const float * array_src_a,
const float * array_src_b,
const int size )

Definition at line 1090 of file math_vector.c.

References size().

Referenced by Matrix_mul(), Quaternion_mul(), and vector_mul_vec().

◆ negate_vn()

void negate_vn ( float * array_tar,
const int size )

Definition at line 1061 of file math_vector.c.

References size().

Referenced by Vector_negate().

◆ negate_vn_vn()

void negate_vn_vn ( float * array_tar,
const float * array_src,
const int size )

Definition at line 1070 of file math_vector.c.

References size().

Referenced by Color_neg(), and Vector_neg().

◆ normalize_vn()

float normalize_vn ( float * array_tar,
const int size )

Definition at line 1027 of file math_vector.c.

References normalize_vn_vn().

Referenced by M_Noise_random_unit_vector(), Vector_normalize(), and Vector_slerp().

◆ normalize_vn_vn()

float normalize_vn_vn ( float * array_tar,
const float * array_src,
const int size )

Definition at line 1012 of file math_vector.c.

References copy_vn_fl(), float, len_squared_vn(), mul_vn_vn_fl(), and sqrt().

Referenced by normalize_vn(), and Vector_slerp().

◆ ortho_basis_v3v3_v3()

void ortho_basis_v3v3_v3 ( float r_n1[3],
float r_n2[3],
const float n[3] )

Takes a vector and computes 2 orthogonal directions.

Note
if n is n unit length, computed values will be too.

Definition at line 720 of file math_vector.c.

References BLI_assert, eps, len_squared_v2(), and sqrtf.

Referenced by blender::ed::sculpt_paint::pose::align_pivot_local_space(), alter_co(), axis_dominant_v3_to_m3(), axis_dominant_v3_to_m3_negate(), gizmo_3d_dial_matrixbasis_calc(), mesh_calc_eigen_matrix(), and wm_gizmo_set_matrix_rotation_from_z_axis__internal().

◆ ortho_v2_v2()

void ortho_v2_v2 ( float out[2],
const float v[2] )

Trivial compared to v3, include for consistency.

Definition at line 770 of file math_vector.c.

References BLI_assert, and v.

Referenced by interp_v2_v2v2_slerp_safe(), Vector_orthogonal(), and wm_gesture_draw_line_active_side().

◆ ortho_v3_v3()

◆ print_v2()

void print_v2 ( const char * str,
const float v[2] )

Definition at line 830 of file math_vector.c.

References printf, str, and v.

Referenced by add_vertex_extrude().

◆ print_v3()

void print_v3 ( const char * str,
const float v[3] )

Definition at line 835 of file math_vector.c.

References printf, str, and v.

Referenced by raycast_callback().

◆ print_v4()

void print_v4 ( const char * str,
const float v[4] )

Definition at line 840 of file math_vector.c.

References printf, str, and v.

◆ print_vn()

void print_vn ( const char * str,
const float v[],
const int n )

Definition at line 845 of file math_vector.c.

References printf, str, and v.

◆ project_plane_normalized_v2_v2v2()

void project_plane_normalized_v2_v2v2 ( float out[2],
const float p[2],
const float v_plane[2] )

Definition at line 673 of file math_vector.c.

References BLI_ASSERT_UNIT_V2, dot_v2v2(), madd_v2_v2v2fl(), and mul().

◆ project_plane_normalized_v3_v3v3()

◆ project_plane_v2_v2v2()

void project_plane_v2_v2v2 ( float out[2],
const float p[2],
const float v_plane[2] )

Definition at line 658 of file math_vector.c.

References dot_v2v2(), madd_v2_v2v2fl(), and mul().

◆ project_plane_v3_v3v3()

void project_plane_v3_v3v3 ( float out[3],
const float p[3],
const float v_plane[3] )

In this case plane is a 3D vector only (no 4th component).

Projecting will make out a copy of p orthogonal to v_plane.

Note
If p is exactly perpendicular to v_plane, out will just be a copy of p.
This function is a convenience to call:
project_v3_v3v3(out, p, v_plane);
sub_v3_v3v3(out, p, out);
MINLINE void sub_v3_v3v3(float r[3], const float a[3], const float b[3])
void project_v3_v3v3(float out[3], const float p[3], const float v_proj[3])

Definition at line 651 of file math_vector.c.

References dot_v3v3(), madd_v3_v3v3fl(), and mul().

Referenced by BKE_object_empty_image_data_is_visible_in_view3d(), blender::ed::sculpt_paint::brush_delta_update(), blender::ed::sculpt_paint::calc_brush_plane(), do_vpaint_brush_smear(), do_wpaint_brush_smear(), ED_view3d_cursor3d_position_rotation(), gizmo_arrow_modal(), is_quad_convex_v3(), screen_px_line_point_factor_v2_persp(), sculpt_project_v3_normal_align(), transform_orientations_create_from_axis(), and blender::ed::sculpt_paint::update_sculpt_normal().

◆ project_v2_v2v2()

void project_v2_v2v2 ( float out[2],
const float p[2],
const float v_proj[2] )

Project p onto v_proj

Definition at line 602 of file math_vector.c.

References dot_v2v2(), is_zero_v2(), mul(), mul_v2_v2fl(), UNLIKELY, and zero_v2().

Referenced by BKE_mask_point_set_handle(), and initResize().

◆ project_v2_v2v2_normalized()

void project_v2_v2v2_normalized ( float out[2],
const float p[2],
const float v_proj[2] )

Project p onto a unit length v_proj

Definition at line 635 of file math_vector.c.

References BLI_ASSERT_UNIT_V2, dot_v2v2(), mul(), and mul_v2_v2fl().

Referenced by slide_point_modal().

◆ project_v3_plane()

void project_v3_plane ( float out[3],
const float plane_no[3],
const float plane_co[3] )

Project a vector on a plane defined by normal and a plane point p.

Definition at line 681 of file math_vector.c.

References dot_v3v3(), len_squared_v3(), madd_v3_v3fl(), mul(), and sub_v3_v3v3().

Referenced by interp_slerp_co_no_v3(), and blender::bke::mesh_surface_sample::sample_surface_points_spherical().

◆ project_v3_v3v3()

◆ project_v3_v3v3_db()

void project_v3_v3v3_db ( double out[3],
const double p[3],
const double v_proj[3] )

Definition at line 624 of file math_vector.c.

References dot_v3v3_db(), is_zero_v3_db(), mul(), mul_v3_v3db_db(), UNLIKELY, and zero_v3_db().

◆ project_v3_v3v3_normalized()

void project_v3_v3v3_normalized ( float out[3],
const float p[3],
const float v_proj[3] )

◆ range_vn_fl()

void range_vn_fl ( float * array_tar,
const int size,
const float start,
const float step )

Definition at line 1052 of file math_vector.c.

References size().

Referenced by C_Vector_Linspace(), and C_Vector_Range().

◆ range_vn_i()

void range_vn_i ( int * array_tar,
const int size,
const int start )

◆ range_vn_u()

void range_vn_u ( uint * array_tar,
const int size,
const uint start )

Definition at line 1042 of file math_vector.c.

References size().

Referenced by BLI_scanfill_calc_ex(), and material_slot_move_exec().

◆ reflect_v3_v3v3()

void reflect_v3_v3v3 ( float out[3],
const float v[3],
const float normal[3] )

Returns a reflection vector from a vector and a normal vector reflect = vec - ((2 * dot(vec, mirror)) * mirror).

v
+  ^
 \ |
  |
   + normal: axis of reflection
  /
 /
+
out: result (negate for a 'bounce').

Definition at line 704 of file math_vector.c.

References BLI_ASSERT_UNIT_V3, dot_v3v3(), madd_v3_v3v3fl(), and v.

Referenced by alter_co(), ElementMirror(), studiolight_lights_eval(), studiolight_radiance_preview(), and Vector_reflect().

◆ reflect_v3_v3v3_db()

void reflect_v3_v3v3_db ( double out[3],
const double v[3],
const double normal[3] )

Definition at line 712 of file math_vector.c.

References BLI_ASSERT_UNIT_V3_DB, dot_v3v3_db(), madd_v3_v3v3db_db(), and v.

◆ rotate_normalized_v3_v3v3fl()

void rotate_normalized_v3_v3v3fl ( float out[3],
const float p[3],
const float axis[3],
float angle )

◆ rotate_v2_v2fl()

◆ rotate_v3_v3v3fl()

◆ sqr_db()

MINLINE double sqr_db ( double f)

Definition at line 984 of file math_vector.c.

Referenced by len_squared_vn().

◆ sub_vn_vn()

void sub_vn_vn ( float * array_tar,
const float * array_src,
const int size )

Definition at line 1172 of file math_vector.c.

References size().

Referenced by Color_isub(), and Vector_isub().

◆ sub_vn_vnvn()

void sub_vn_vnvn ( float * array_tar,
const float * array_src_a,
const float * array_src_b,
const int size )

Definition at line 1182 of file math_vector.c.

References size().

Referenced by Color_sub(), Matrix_sub(), v3d_editvertex_buts(), and Vector_sub().