|
Blender V4.3
|
#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) |
Referenced by axis_sort_v3().
Definition at line 1123 of file math_vector.c.
References size().
Referenced by Color_iadd(), and Vector_iadd().
Definition at line 1285 of file math_vector.c.
References size().
Referenced by BLI_quadric_add_qu_qu().
| 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().
| 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().
Definition at line 470 of file math_vector.c.
References b, BLI_ASSERT_UNIT_V2, dot_v2v2(), len_v2v2(), M_PI, negate_v2_v2(), and safe_asinf().
Referenced by angle_v2v2(), angle_v2v2v2(), computeBindWeights(), edbm_rip_edge_invoke(), blender::draw::edituv_get_edituv_stretch_angle(), and InputAngle().
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 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().
| 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().
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().
| 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.
Definition at line 497 of file math_vector.c.
References angle(), angle_v3v3(), cross_v3_v3v3(), dot_v3v3(), float, M_PI, project_plane_normalized_v3_v3v3(), and v2.
Referenced by blender::nodes::node_fn_align_euler_to_vector_cc::align_rotations_fixed_pivot(), blender::nodes::node_fn_align_rotation_to_vector_cc::align_rotations_fixed_pivot(), angle_signed_on_axis_v3v3v3_v3(), blender::bke::curves::poly::calculate_normals_minimum(), blender::nodes::node_geo_curve_primitive_arc_cc::create_arc_curve_from_points(), dial_ghostarc_get_angles(), ED_view3d_cursor3d_update(), gizmo_bisect_prop_angle_get(), gizmo_bisect_prop_angle_set(), gizmo_spin_prop_axis_angle_get(), gizmo_spin_prop_axis_angle_set(), MOD_solidify_extrude_modifyMesh(), RotationBetween(), and snap_v3_angle_plane().
| float angle_signed_on_axis_v3v3v3_v3 | ( | const float | v1[3], |
| const float | v2[3], | ||
| const float | v3[3], | ||
| const float | axis[3] ) |
Definition at line 530 of file math_vector.c.
References angle_signed_on_axis_v3v3_v3(), sub_v3_v3v3(), and v2.
Referenced by bm_face_split_edgenet_find_loop_walk(), BM_verts_sort_radial_plane(), and edbm_face_split_by_edges_exec().
Definition at line 448 of file math_vector.c.
References atan2f, dot_v2v2(), and v2.
Referenced by computeBindWeights(), blender::bke::pbvh::uv_islands::UVBorder::outside_angle(), slide_marker_modal(), snap_v2_angle(), ui_but_isect_pie_seg(), Vector_angle_signed(), and wm_gesture_straightline_do_angle_snap().
Definition at line 543 of file math_vector.c.
References angle_normalized_v3v3(), float, M_PI, normalize_v3(), sub_v3_v3v3(), and v2.
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().
Definition at line 404 of file math_vector.c.
References angle_normalized_v2v2(), b, and normalize_v2().
Referenced by MOD_lineart_chain_split_angle(), and blender::geometry::p_chart_minimum_area_angle().
Return the shortest angle in radians between the 2 vectors.
Definition at line 394 of file math_vector.c.
References angle_normalized_v3v3(), b, and normalize_v3_v3().
Referenced by angle_on_axis_v3v3_v3(), angle_signed_on_axis_v3v3_v3(), axisProjection(), bevel_vert_construct(), blender::geometry::calculate_angles(), blender::ed::sculpt_paint::do_multiplane_scrape_brush(), ED_armature_ebone_roll_to_vector(), blender::nodes::node_fn_compare_cc::get_multi_function(), make_unit_square_map(), mix_normals(), modify_mesh(), nearly_parallel(), offset_meet(), select_similar_direction(), similar_face_select_exec(), and viewrotate_apply_snap().
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().
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().
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().
Definition at line 1270 of file math_vector.c.
References size().
Referenced by blender::math::bilinear_fl_impl(), BKE_defvert_extract_vgroup_to_edgeweights(), BKE_defvert_extract_vgroup_to_faceweights(), BKE_defvert_extract_vgroup_to_loopweights(), BKE_defvert_extract_vgroup_to_vertweights(), BKE_mesh_normals_loop_to_vertex(), BKE_mesh_remap_calc_edges_from_mesh(), BKE_mesh_remap_calc_faces_from_mesh(), BLI_astar_graph_solve(), blo_do_versions_260(), BM_mesh_calc_path_edge(), BM_mesh_calc_path_face(), BM_mesh_calc_path_uv_edge(), BM_mesh_calc_path_uv_face(), BM_mesh_calc_path_uv_vert(), BM_mesh_calc_path_vert(), BM_vert_loop_groups_data_layer_create(), C_Vector_Fill(), calc_deltas(), calc_tangent_spaces(), calcEdgeSlide_mval_range(), CustomData_bmesh_interp(), CustomData_interp(), initNumInput(), Matrix_zero(), MOD_solidify_extrude_modifyMesh(), normalize_vn_vn(), blender::compositor::MemoryBuffer::read_bilinear(), smooth_verts(), blender::draw::statvis_calc_sharp(), blender::draw::statvis_calc_thickness(), v3d_editvertex_buts(), Vector_CreatePyObject(), Vector_length_set(), Vector_new(), Vector_resize(), Vector_resized(), and Vector_zero().
Definition at line 1234 of file math_vector.c.
References size().
Referenced by arrayModifier_doArray(), BM_face_split_edgenet_connect_islands(), BM_mesh_decimate_dissolve_ex(), bm_uv_build_islands(), CustomData_reset(), DM_init(), filelist_cache_clear(), filelist_cache_init(), initNumInput(), layerDefault_origindex(), mesh_calc_path_region_elem(), mesh_calc_path_region_elem(), mesh_merge_transform(), mesh_remove_doubles_on_axis(), MOD_solidify_extrude_modifyMesh(), sequencer_select_side_exec(), skin_set_orig_indices(), and transform_convert_mesh_islands_calc().
| void copy_vn_short | ( | short * | array_tar, |
| const int | size, | ||
| const short | val ) |
Definition at line 1261 of file math_vector.c.
References size().
Definition at line 1252 of file math_vector.c.
References size().
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().
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().
Definition at line 935 of file math_vector.c.
References equals_v2v2(), madd_v2_v2v2fl(), nor, normalize_v2(), sub_v2_v2v2(), and v2.
Referenced by BKE_mask_calc_handle_adjacent_interp(), BKE_mask_calc_handle_point_auto(), mask_spline_feather_differentiated_points_with_resolution__double(), and ui_numedit_but_HSVCIRCLE().
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().
Definition at line 989 of file math_vector.c.
References double(), and size().
Referenced by Vector_dot(), Vector_length_get(), Vector_length_set(), Vector_length_squared_get(), Vector_matmul(), and Vector_slerp().
Definition at line 337 of file math_vector.c.
Definition at line 330 of file math_vector.c.
Equivalent to: interp_v3_v3v3(v, v1, v2, -1.0f);
Definition at line 322 of file math_vector.c.
Definition at line 21 of file math_vector.c.
References b.
Referenced by annotation_add_missing_events(), annotation_draw_apply(), annotation_smooth_buffer(), BKE_fcurve_bezt_subdivide_handles(), BKE_tracking_marker_get_interpolated(), BKE_tracking_marker_get_subframe_position(), BKE_tracking_plane_marker_get_subframe_corners(), BKE_tracking_tracks_join(), edbm_rip_edgedist_squared(), find_nearest_edge__doClosest(), insert_point_to_segment(), interp_v2_v2v2v2v2_cubic(), interpolate_averaged_track_contributions(), blender::ed::sculpt_paint::paint_smooth_stroke(), project_paint_face_init(), resolve_quad_uv_v2_deriv(), slide_spline_curvature_modal(), blender::ed::curves::stroke_elem_interp(), stroke_elem_interp(), track_plane_from_existing_motion(), and uv_warp_compute().
Definition at line 1327 of file math_vector.c.
References b.
Referenced by lineart_edge_first_bounding_area().
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().
| 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.
| 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().
| 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().
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().
| 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().
Definition at line 1318 of file math_vector.c.
References b.
Referenced by lineart_do_closest_segment(), lineart_shadow_cast_onto_triangle(), lineart_shadow_create_shadow_edge_array(), lineart_shadow_register_enclosed_shapes(), lineart_shadow_segment_slice_get(), lineart_triangle_2v_intersection_math(), lineart_triangle_cull_single(), lineart_triangle_edge_image_space_occlusion(), and MOD_lineart_chain_feature_lines().
slerp, treat vectors as spherical coordinates
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().
Same as interp_v3_v3v3_slerp but uses fallback values for opposite vectors.
Definition at line 99 of file math_vector.c.
References b, BLI_assert, copy_v3_v3(), interp_v3_v3v3_slerp(), normalize_v3(), ortho_v3_v3(), and UNLIKELY.
Referenced by BKE_mesh_remap_calc_edges_from_mesh(), layerCopyValue_normal(), mix_normals(), and blender::ed::object::object_rand_transverts().
Definition at line 211 of file math_vector.c.
Referenced by interp_v3_v3v3_char(), and widget_tab().
| void interp_v3_v3v3v3 | ( | float | p[3], |
| const float | v1[3], | ||
| const float | v2[3], | ||
| const float | v3[3], | ||
| const float | w[3] ) |
Weight 3 vectors, 'w' must be unit length but is not a vector, just 3 weights.
Definition at line 161 of file math_vector.c.
Referenced by BKE_shrinkwrap_compute_smooth_normal(), blender::ed::sculpt_paint::paint::image::calc_pixel_position(), dynamic_paint_generate_bake_data_cb(), dynamic_paint_paint_mesh_cell_point_cb_ex(), dynamic_paint_set_init_color_tex_to_imseq_cb(), project_paint_face_init(), project_paint_occlude_ptv_clip(), project_paint_op(), psys_interpolate_face(), blender::nodes::node_geo_distribute_points_on_faces_cc::sample_mesh_surface(), screen_px_from_ortho(), screen_px_from_persp(), target_project_solve_point_tri(), target_project_tri_deviation(), and transform_point_by_tri_v3().
| void interp_v3_v3v3v3_uv | ( | float | p[3], |
| const float | v1[3], | ||
| const float | v2[3], | ||
| const float | v3[3], | ||
| const float | uv[2] ) |
Definition at line 203 of file math_vector.c.
References v2.
Referenced by bmbvh_ray_cast_handle_hit(), knife_ray_intersect_face(), and blender::draw::statvis_calc_thickness().
| 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.
Referenced by BKE_where_on_path(), psys_interpolate_face(), psys_interpolate_particle(), and psys_thread_create_path().
Definition at line 45 of file math_vector.c.
References b.
Referenced by BKE_gpencil_stroke_close(), blender::ed::sculpt_paint::color::color_filter_task(), DRW_globals_update(), drw_shgroup_bone_envelope(), get_pchan_color_constraint(), gizmo_axis_draw(), gpencil_editcurve_subdivide_curve_segment(), OVERLAY_grid_cache_init(), psys_thread_create_path(), setkeys(), subdividenurb(), blender::compositor::DespeckleOperation::update_memory_buffer_partial(), blender::compositor::VariableSizeBokehBlurOperation::update_memory_buffer_partial(), blender::compositor::ZCombineMaskOperation::update_memory_buffer_partial(), blender::compositor::ColorBalanceWhitepointOperation::update_memory_buffer_row(), version_principled_bsdf_specular_tint(), and version_principled_bsdf_subsurface().
| 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().
Definition at line 224 of file math_vector.c.
Referenced by interp_v4_v4v4_char().
| 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.
Referenced by dynamic_paint_set_init_color_vcol_to_imseq_cb(), and blender::bke::attribute_math::mix3().
| 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.
Referenced by blender::bke::attribute_math::mix4(), and blender::bke::attribute_math::mix4().
Definition at line 1221 of file math_vector.c.
References size().
Referenced by meshcache_do(), and Vector_lerp().
| bool is_finite_v2 | ( | const float | v[2] | ) |
| bool is_finite_v3 | ( | const float | v[3] | ) |
Definition at line 354 of file math_vector.c.
References v.
Referenced by barycentric_coords_v2(), barycentric_weights(), barycentric_weights_v2(), barycentric_weights_v2_clamped(), barycentric_weights_v2_persp(), BKE_mesh_center_of_surface(), BKE_mesh_center_of_volume(), and GPU_matrix_unproject_3fv().
| 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().
Definition at line 1001 of file math_vector.c.
References size(), and sqr_db().
Referenced by normalize_vn_vn(), and Vector_richcmpr().
Definition at line 1147 of file math_vector.c.
References size().
| 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().
Definition at line 245 of file math_vector.c.
References b.
Referenced by BM_face_splits_check_legal(), computeBindWeights(), ED_uvedit_center_multi(), edgetag_cut_cost_face_uv(), facetag_cut_cost_edge_uv(), find_nearest_edge__doClosest(), find_nearest_edge_center__doZBuf(), gizmo2d_calc_bounds(), knife_find_line_hits(), knifetool_draw_visible_distances(), OVERLAY_camera_cache_populate(), blender::geometry::uv_parametrizer_average(), and uvedit_pack_islands_multi().
Definition at line 251 of file math_vector.c.
Referenced by overlap_tri_tri_uv_test().
| 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().
Definition at line 272 of file math_vector.c.
References float, madd_v3_v3fl(), and zero_v3().
Referenced by computeBindWeights(), and deformVert().
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().
Specialized function for calculating normals. Fast-path for:
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().
Definition at line 257 of file math_vector.c.
Referenced by bindVert(), BM_face_calc_point_in_face(), compute_collision_point_edge_tri(), compute_collision_point_tri_tri(), blender::bke::mesh::face_area_centroid_calc(), blender::bke::mesh::face_center_calc(), ob_parvert3(), and tri_v3_scale().
| void mid_v3_v3v3v3v3 | ( | float | v[3], |
| const float | v1[3], | ||
| const float | v2[3], | ||
| const float | v3[3], | ||
| const float | v4[3] ) |
Definition at line 264 of file math_vector.c.
Referenced by connect_frames(), draw_primitive_view_impl(), blender::bke::mesh::face_center_calc(), and mdisp_in_mdispquad().
Definition at line 907 of file math_vector.c.
References min.
Referenced by BKE_mask_spline_feather_collapse_inner_loops(), BKE_mesh_remap_calc_faces_from_mesh(), BKE_tracking_marker_pattern_minmax(), BKE_tracking_plane_track_add(), BM_face_uv_minmax(), clip_uv_transform_translation(), draw_distortion(), draw_spline_points(), dynamicPaint_createUVSurface(), ED_mask_selected_minmax(), ED_uvedit_minmax_multi(), feather_bucket_check_intersect(), blender::compositor::PlaneDistortWarpImageOperation::get_area_of_interest(), layerDoMinMax_mloop_origspace(), blender::geometry::p_chart_uv_bbox(), pixel_bounds_array(), pixel_bounds_uv(), proj_paint_state_screen_coords_init(), project_paint_delayed_face_init(), screen_geom_vertices_scale_pass(), selected_tracking_boundbox(), SEQ_image_transform_bounding_box_from_collection(), spline_under_mouse_get(), tracking_check_marker_margin(), uv_map_clip_correct(), and uv_weld_align().
Definition at line 884 of file math_vector.c.
References min.
Referenced by BKE_boundbox_minmax(), BKE_displist_minmax(), BKE_editmesh_cache_calc_minmax(), BKE_gpencil_stroke_minmax(), BKE_lattice_minmax(), BKE_mball_minmax(), BKE_mball_minmax_ex(), BKE_object_minmax(), BKE_object_minmax_dupli(), BKE_pchan_minmax(), BM_face_calc_bounds_expand(), BM_face_calc_center_bounds(), BM_face_calc_center_bounds_vcos(), boundInsert(), box_minmax_bounds_m4(), bundle_midpoint(), calc_nurb_minmax(), calc_ortho_extent(), calc_tw_center(), calculateCenterBound(), blender::bke::pbvh::clip_ray_ortho(), cuboid_do(), curve_deform_coords_impl(), distribute_grid(), ED_armature_origin_set(), ED_view3d_minmax_verts(), edbm_point_normals_modal(), generate_vert_coordinates(), harmonic_coordinates_bind(), heat_ray_tree_create(), blender::ed::object::object_origin_set_exec(), paintface_minmax(), particle_intersect_mesh(), particle_system_minmax(), points_in_planes_minmax_fn(), sb_detect_edge_collisionCached(), scopes_update_cb(), snap_curs_to_sel_ex(), softbody_apply_forces(), view3d_object_calc_minmax(), viewselected_exec(), and WM_gizmomap_minmax().
Definition at line 855 of file math_vector.c.
References min.
Referenced by layerDoMinMax_propcol().
Definition at line 1196 of file math_vector.c.
References size().
| 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().
Definition at line 1104 of file math_vector.c.
References size().
Referenced by BM_vert_loop_groups_data_layer_create(), bm_vert_loop_groups_data_layer_merge_weights__single(), Color_idiv(), Color_imul(), Matrix_imul(), Vector_idiv(), Vector_imul(), and Vector_length_set().
Definition at line 1080 of file math_vector.c.
References size().
Referenced by Matrix_imul(), Quaternion_imul(), and Vector_imul().
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().
| 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().
Definition at line 1070 of file math_vector.c.
References size().
Referenced by Color_neg(), and Vector_neg().
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().
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().
Takes a vector and computes 2 orthogonal directions.
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().
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().
Calculates p - a perpendicular vector to v
Definition at line 745 of file math_vector.c.
References axis_dominant_v3_single(), BLI_assert, and v.
Referenced by BM_loop_interp_from_face(), bm_vert_pair_to_matrix(), getTransformOrientation_ex(), gizmo_spin_prop_axis_angle_get(), gizmo_spin_prop_axis_angle_set(), interp_v3_v3v3_slerp_safe(), orthogonalize_m3_zero_axes_impl(), rotation_between_vecs_to_mat3(), rotation_between_vecs_to_quat(), and Vector_orthogonal().
| 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().
| 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().
| void print_v4 | ( | const char * | str, |
| const float | v[4] ) |
Definition at line 840 of file math_vector.c.
Definition at line 845 of file math_vector.c.
Definition at line 673 of file math_vector.c.
References BLI_ASSERT_UNIT_V2, dot_v2v2(), madd_v2_v2v2fl(), and mul().
Definition at line 665 of file math_vector.c.
References BLI_ASSERT_UNIT_V3, dot_v3v3(), madd_v3_v3v3fl(), and mul().
Referenced by angle_on_axis_v3v3_v3(), angle_signed_on_axis_v3v3_v3(), bm_vert_pair_to_matrix(), BM_verts_calc_normal_from_cloud_ex(), clip_to_ortho_planes(), blender::bke::pbvh::edge_queue_tri_in_circle(), getTransformOrientation_ex(), gizmo_bisect_prop_angle_get(), gizmo_bisect_prop_angle_set(), gizmo_mesh_bisect_update_from_op(), gizmo_mesh_spin_init_refresh(), gizmo_mesh_spin_redo_draw_prepare(), gizmo_mesh_spin_redo_update_from_op(), gizmo_spin_prop_axis_angle_get(), gizmo_spin_prop_axis_angle_set(), blender::bke::pbvh::long_edge_queue_create(), mesh_customdatacorrect_apply_vert(), and blender::bke::pbvh::short_edge_queue_create().
Definition at line 658 of file math_vector.c.
References dot_v2v2(), madd_v2_v2v2fl(), and mul().
In this case plane is a 3D vector only (no 4th component).
Projecting will make out a copy of p orthogonal to v_plane.
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 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 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 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 p onto v_proj
Definition at line 613 of file math_vector.c.
References dot_v3v3(), is_zero_v3(), mul(), mul_v3_v3fl(), UNLIKELY, and zero_v3().
Referenced by _scan_for_ext_spring_forces(), axisProjection(), bm_loop_flip_disp(), bm_vert_tri_find_unique_edge(), boid_body(), boid_climb(), do_kink(), do_kink_spiral(), followtrack_distance_from_viewplane_get(), get_effector_data(), getTransformOrientation_ex(), InputHorizontalAbsolute(), InputVerticalAbsolute(), isect_line_line_epsilon_v3(), locktrack_evaluate(), pivotcon_evaluate(), prop_dist_loc_get(), psys_get_birth_coords(), psys_thread_create_path(), ResizeBetween(), rule_average_speed(), setNearestAxis3d(), transdata_elem_push_pull(), update_velocities(), vectomat(), and viewAxisCorrectCenter().
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 p onto a unit length v_proj
Definition at line 643 of file math_vector.c.
References BLI_ASSERT_UNIT_V3, dot_v3v3(), mul(), and mul_v3_v3fl().
Referenced by dist_squared_to_ray_v3_normalized(), ED_armature_ebone_roll_to_vector(), mesh_remove_doubles_on_axis(), wm_xr_fly_compute_move(), wm_xr_navigation_reset_exec(), and wm_xr_navigation_teleport().
Definition at line 1052 of file math_vector.c.
References size().
Referenced by C_Vector_Linspace(), and C_Vector_Range().
Definition at line 1032 of file math_vector.c.
References size().
Referenced by bpy_bmelemseq_sort(), ensure_orig_index_layer(), blender::bke::mesh_calc_modifiers(), blender::geometry::mesh_merge_by_distance_connected(), and modify_mesh().
Definition at line 1042 of file math_vector.c.
References size().
Referenced by BLI_scanfill_calc_ex(), and material_slot_move_exec().
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().
Definition at line 712 of file math_vector.c.
References BLI_ASSERT_UNIT_V3_DB, dot_v3v3_db(), madd_v3_v3v3db_db(), and v.
| void rotate_normalized_v3_v3v3fl | ( | float | out[3], |
| const float | p[3], | ||
| const float | axis[3], | ||
| float | angle ) |
Rotate a point p by angle around an arbitrary unit length axis. http://local.wasp.uwa.edu.au/~pbourke/geometry/
Definition at line 789 of file math_vector.c.
References BLI_ASSERT_UNIT_V3, cosf, and sinf.
Referenced by build_emats_stack(), connection_node_mat(), map_to_plane_axis_angle_v2_v3v3fl(), rotate_v3_v3v3fl(), and blender::write_weights_for_drawing().
Rotate a point p by angle around origin (0, 0)
Definition at line 778 of file math_vector.c.
References BLI_assert, cosf, and sinf.
Referenced by blender::ed::sculpt_paint::dyntopo::dyntopo_detail_size_edit_invoke(), blender::ed::sculpt_paint::dyntopo::dyntopo_detail_size_parallel_lines_draw(), gpencil_vfx_shadow(), rotate_around_center_v2(), vfont_to_curve(), and wm_gesture_straightline_do_angle_snap().
Definition at line 813 of file math_vector.c.
References BLI_assert, normalize_v3_v3(), and rotate_normalized_v3_v3v3fl().
Referenced by blender::ed::sculpt_paint::boundary::calc_bend_position(), blender::ed::sculpt_paint::do_clay_thumb_brush(), blender::ed::sculpt_paint::do_multiplane_scrape_brush(), do_twist(), gizmo2d_resize_draw_prepare(), blender::ed::sculpt_paint::multiplane_scrape_preview_draw(), SCULPT_tilt_apply_to_normal(), and snap_v3_angle_plane().
Definition at line 984 of file math_vector.c.
Referenced by len_squared_vn().
Definition at line 1172 of file math_vector.c.
References size().
Referenced by Color_isub(), and Vector_isub().
| 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().