Use approximate equallity methods in many places

This commit is contained in:
Aaron Franke 2019-01-16 10:42:53 -05:00
parent c577ec6ae4
commit b659e1eb2b
No known key found for this signature in database
GPG Key ID: 40A1750B977E56BF
21 changed files with 66 additions and 66 deletions

View File

@ -80,11 +80,11 @@ public:
} }
static bool edge_compare(const Vector<Vector2> &p_vertices, const Edge &p_a, const Edge &p_b) { static bool edge_compare(const Vector<Vector2> &p_vertices, const Edge &p_a, const Edge &p_b) {
if (p_vertices[p_a.edge[0]].distance_to(p_vertices[p_b.edge[0]]) < CMP_EPSILON && p_vertices[p_a.edge[1]].distance_to(p_vertices[p_b.edge[1]]) < CMP_EPSILON) { if (Math::is_zero_approx(p_vertices[p_a.edge[0]].distance_to(p_vertices[p_b.edge[0]])) && Math::is_zero_approx(p_vertices[p_a.edge[1]].distance_to(p_vertices[p_b.edge[1]]))) {
return true; return true;
} }
if (p_vertices[p_a.edge[0]].distance_to(p_vertices[p_b.edge[1]]) < CMP_EPSILON && p_vertices[p_a.edge[1]].distance_to(p_vertices[p_b.edge[0]]) < CMP_EPSILON) { if (Math::is_zero_approx(p_vertices[p_a.edge[0]].distance_to(p_vertices[p_b.edge[1]])) && Math::is_zero_approx(p_vertices[p_a.edge[1]].distance_to(p_vertices[p_b.edge[0]]))) {
return true; return true;
} }

View File

@ -836,7 +836,7 @@ Geometry::MeshData Geometry::build_convex_mesh(const PoolVector<Plane> &p_planes
Vector3 rel = edge1_A - edge0_A; Vector3 rel = edge1_A - edge0_A;
real_t den = clip.normal.dot(rel); real_t den = clip.normal.dot(rel);
if (Math::abs(den) < CMP_EPSILON) if (Math::is_zero_approx(den))
continue; // point too short continue; // point too short
real_t dist = -(clip.normal.dot(edge0_A) - clip.d) / den; real_t dist = -(clip.normal.dot(edge0_A) - clip.d) / den;

View File

@ -181,8 +181,8 @@ public:
} }
} }
// finally do the division to get sc and tc // finally do the division to get sc and tc
sc = (Math::abs(sN) < CMP_EPSILON ? 0.0 : sN / sD); sc = (Math::is_zero_approx(sN) ? 0.0 : sN / sD);
tc = (Math::abs(tN) < CMP_EPSILON ? 0.0 : tN / tD); tc = (Math::is_zero_approx(tN) ? 0.0 : tN / tD);
// get the difference of the two closest points // get the difference of the two closest points
Vector3 dP = w + (sc * u) - (tc * v); // = S1(sc) - S2(tc) Vector3 dP = w + (sc * u) - (tc * v); // = S1(sc) - S2(tc)
@ -195,7 +195,7 @@ public:
Vector3 e2 = p_v2 - p_v0; Vector3 e2 = p_v2 - p_v0;
Vector3 h = p_dir.cross(e2); Vector3 h = p_dir.cross(e2);
real_t a = e1.dot(h); real_t a = e1.dot(h);
if (a > -CMP_EPSILON && a < CMP_EPSILON) // parallel test if (Math::is_zero_approx(a)) // parallel test
return false; return false;
real_t f = 1.0 / a; real_t f = 1.0 / a;
@ -233,7 +233,7 @@ public:
Vector3 e2 = p_v2 - p_v0; Vector3 e2 = p_v2 - p_v0;
Vector3 h = rel.cross(e2); Vector3 h = rel.cross(e2);
real_t a = e1.dot(h); real_t a = e1.dot(h);
if (a > -CMP_EPSILON && a < CMP_EPSILON) // parallel test if (Math::is_zero_approx(a)) // parallel test
return false; return false;
real_t f = 1.0 / a; real_t f = 1.0 / a;
@ -535,7 +535,7 @@ public:
// see http://paulbourke.net/geometry/pointlineplane/ // see http://paulbourke.net/geometry/pointlineplane/
const real_t denom = p_dir_b.y * p_dir_a.x - p_dir_b.x * p_dir_a.y; const real_t denom = p_dir_b.y * p_dir_a.x - p_dir_b.x * p_dir_a.y;
if (Math::abs(denom) < CMP_EPSILON) { // parallel? if (Math::is_zero_approx(denom)) { // parallel?
return false; return false;
} }

View File

@ -434,7 +434,7 @@ bool EditorPropertyRevert::is_node_property_different(Node *p_node, const Varian
float a = p_current; float a = p_current;
float b = p_orig; float b = p_orig;
return Math::abs(a - b) > CMP_EPSILON; //this must be done because, as some scenes save as text, there might be a tiny difference in floats due to numerical error return !Math::is_equal_approx(a, b); //this must be done because, as some scenes save as text, there might be a tiny difference in floats due to numerical error
} }
return bool(Variant::evaluate(Variant::OP_NOT_EQUAL, p_current, p_orig)); return bool(Variant::evaluate(Variant::OP_NOT_EQUAL, p_current, p_orig));

View File

@ -194,7 +194,7 @@ void CurveEditor::on_gui_input(const Ref<InputEvent> &p_event) {
Vector2 dir = (control_pos - point_pos).normalized(); Vector2 dir = (control_pos - point_pos).normalized();
real_t tangent; real_t tangent;
if (Math::abs(dir.x) > CMP_EPSILON) if (!Math::is_zero_approx(dir.x))
tangent = dir.y / dir.x; tangent = dir.y / dir.x;
else else
tangent = 9999 * (dir.y >= 0 ? 1 : -1); tangent = 9999 * (dir.y >= 0 ? 1 : -1);

View File

@ -2473,7 +2473,7 @@ void SpatialEditorViewport::_draw() {
real_t max_speed = camera->get_zfar(); real_t max_speed = camera->get_zfar();
real_t scale_length = (max_speed - min_speed); real_t scale_length = (max_speed - min_speed);
if (Math::abs(scale_length) > CMP_EPSILON) { if (!Math::is_zero_approx(scale_length)) {
real_t logscale_t = 1.0 - Math::log(1 + freelook_speed - min_speed) / Math::log(1 + scale_length); real_t logscale_t = 1.0 - Math::log(1 + freelook_speed - min_speed) / Math::log(1 + scale_length);
// There is no real maximum speed so that factor can become negative, // There is no real maximum speed so that factor can become negative,
@ -2491,7 +2491,7 @@ void SpatialEditorViewport::_draw() {
real_t max_distance = camera->get_zfar(); real_t max_distance = camera->get_zfar();
real_t scale_length = (max_distance - min_distance); real_t scale_length = (max_distance - min_distance);
if (Math::abs(scale_length) > CMP_EPSILON) { if (!Math::is_zero_approx(scale_length)) {
real_t logscale_t = 1.0 - Math::log(1 + cursor.distance - min_distance) / Math::log(1 + scale_length); real_t logscale_t = 1.0 - Math::log(1 + cursor.distance - min_distance) / Math::log(1 + scale_length);
// There is no real maximum distance so that factor can become negative, // There is no real maximum distance so that factor can become negative,

View File

@ -242,7 +242,7 @@ void CSGBrushOperation::BuildPoly::_clip_segment(const CSGBrush *p_brush, int p_
//check if edge and poly share a vertex, of so, assign it to segment_idx //check if edge and poly share a vertex, of so, assign it to segment_idx
for (int i = 0; i < points.size(); i++) { for (int i = 0; i < points.size(); i++) {
for (int j = 0; j < 2; j++) { for (int j = 0; j < 2; j++) {
if (segment[j].distance_to(points[i].point) < CMP_EPSILON) { if (Math::is_zero_approx(segment[j].distance_to(points[i].point))) {
segment_idx[j] = i; segment_idx[j] = i;
inserted_points.push_back(i); inserted_points.push_back(i);
break; break;
@ -310,7 +310,7 @@ void CSGBrushOperation::BuildPoly::_clip_segment(const CSGBrush *p_brush, int p_
Vector2 edgeseg[2] = { points[edges[i].points[0]].point, points[edges[i].points[1]].point }; Vector2 edgeseg[2] = { points[edges[i].points[0]].point, points[edges[i].points[1]].point };
Vector2 closest = Geometry::get_closest_point_to_segment_2d(segment[j], edgeseg); Vector2 closest = Geometry::get_closest_point_to_segment_2d(segment[j], edgeseg);
if (closest.distance_to(segment[j]) < CMP_EPSILON) { if (Math::is_zero_approx(closest.distance_to(segment[j]))) {
//point rest of this edge //point rest of this edge
res = closest; res = closest;
found = true; found = true;
@ -439,7 +439,7 @@ void CSGBrushOperation::BuildPoly::clip(const CSGBrush *p_brush, int p_face, Mes
//transform A points to 2D //transform A points to 2D
if (segment[0].distance_to(segment[1]) < CMP_EPSILON) if (Math::is_zero_approx(segment[0].distance_to(segment[1])))
return; //too small return; //too small
_clip_segment(p_brush, p_face, segment, mesh_merge, p_for_B); _clip_segment(p_brush, p_face, segment, mesh_merge, p_for_B);
@ -461,10 +461,10 @@ void CSGBrushOperation::_collision_callback(const CSGBrush *A, int p_face_a, Map
{ {
//check if either is a degenerate //check if either is a degenerate
if (va[0].distance_to(va[1]) < CMP_EPSILON || va[0].distance_to(va[2]) < CMP_EPSILON || va[1].distance_to(va[2]) < CMP_EPSILON) if (Math::is_zero_approx(va[0].distance_to(va[1])) || Math::is_zero_approx(va[0].distance_to(va[2])) || Math::is_zero_approx(va[1].distance_to(va[2])))
return; return;
if (vb[0].distance_to(vb[1]) < CMP_EPSILON || vb[0].distance_to(vb[2]) < CMP_EPSILON || vb[1].distance_to(vb[2]) < CMP_EPSILON) if (Math::is_zero_approx(vb[0].distance_to(vb[1])) || Math::is_zero_approx(vb[0].distance_to(vb[2])) || Math::is_zero_approx(vb[1].distance_to(vb[2])))
return; return;
} }

View File

@ -542,7 +542,7 @@ Vector<Vector2> Navigation2D::get_simple_path(const Vector2 &p_start, const Vect
if (CLOCK_TANGENT(apex_point, portal_left, left) >= 0) { if (CLOCK_TANGENT(apex_point, portal_left, left) >= 0) {
//process //process
if (portal_left.distance_squared_to(apex_point) < CMP_EPSILON || CLOCK_TANGENT(apex_point, left, portal_right) > 0) { if (Math::is_zero_approx(portal_left.distance_squared_to(apex_point)) || CLOCK_TANGENT(apex_point, left, portal_right) > 0) {
left_poly = p; left_poly = p;
portal_left = left; portal_left = left;
} else { } else {
@ -552,7 +552,7 @@ Vector<Vector2> Navigation2D::get_simple_path(const Vector2 &p_start, const Vect
left_poly = p; left_poly = p;
portal_left = apex_point; portal_left = apex_point;
portal_right = apex_point; portal_right = apex_point;
if (!path.size() || path[path.size() - 1].distance_to(apex_point) > CMP_EPSILON) if (!path.size() || !Math::is_zero_approx(path[path.size() - 1].distance_to(apex_point)))
path.push_back(apex_point); path.push_back(apex_point);
skip = true; skip = true;
} }
@ -560,7 +560,7 @@ Vector<Vector2> Navigation2D::get_simple_path(const Vector2 &p_start, const Vect
if (!skip && CLOCK_TANGENT(apex_point, portal_right, right) <= 0) { if (!skip && CLOCK_TANGENT(apex_point, portal_right, right) <= 0) {
//process //process
if (portal_right.distance_squared_to(apex_point) < CMP_EPSILON || CLOCK_TANGENT(apex_point, right, portal_left) < 0) { if (Math::is_zero_approx(portal_right.distance_squared_to(apex_point)) || CLOCK_TANGENT(apex_point, right, portal_left) < 0) {
right_poly = p; right_poly = p;
portal_right = right; portal_right = right;
} else { } else {
@ -570,7 +570,7 @@ Vector<Vector2> Navigation2D::get_simple_path(const Vector2 &p_start, const Vect
right_poly = p; right_poly = p;
portal_right = apex_point; portal_right = apex_point;
portal_left = apex_point; portal_left = apex_point;
if (!path.size() || path[path.size() - 1].distance_to(apex_point) > CMP_EPSILON) if (!path.size() || !Math::is_zero_approx(path[path.size() - 1].distance_to(apex_point)))
path.push_back(apex_point); path.push_back(apex_point);
} }
} }
@ -596,7 +596,7 @@ Vector<Vector2> Navigation2D::get_simple_path(const Vector2 &p_start, const Vect
} }
} }
if (!path.size() || path[path.size() - 1].distance_squared_to(begin_point) > CMP_EPSILON) { if (!path.size() || !Math::is_zero_approx(path[path.size() - 1].distance_squared_to(begin_point))) {
path.push_back(begin_point); // Add the begin point path.push_back(begin_point); // Add the begin point
} else { } else {
path.write[path.size() - 1] = begin_point; // Replace first midpoint by the exact begin point path.write[path.size() - 1] = begin_point; // Replace first midpoint by the exact begin point
@ -604,7 +604,7 @@ Vector<Vector2> Navigation2D::get_simple_path(const Vector2 &p_start, const Vect
path.invert(); path.invert();
if (path.size() <= 1 || path[path.size() - 1].distance_squared_to(end_point) > CMP_EPSILON) { if (path.size() <= 1 || !Math::is_zero_approx(path[path.size() - 1].distance_squared_to(end_point))) {
path.push_back(end_point); // Add the end point path.push_back(end_point); // Add the end point
} else { } else {
path.write[path.size() - 1] = end_point; // Replace last midpoint by the exact end point path.write[path.size() - 1] = end_point; // Replace last midpoint by the exact end point

View File

@ -173,7 +173,7 @@ void PathFollow::_update_transform() {
float dot = t_prev.dot(t_cur); float dot = t_prev.dot(t_cur);
float angle = Math::acos(CLAMP(dot, -1, 1)); float angle = Math::acos(CLAMP(dot, -1, 1));
if (likely(Math::abs(angle) > CMP_EPSILON)) { if (likely(!Math::is_zero_approx(angle))) {
if (rotation_mode == ROTATION_Y) { if (rotation_mode == ROTATION_Y) {
// assuming we're referring to global Y-axis. is this correct? // assuming we're referring to global Y-axis. is this correct?
axis.x = 0; axis.x = 0;
@ -184,7 +184,7 @@ void PathFollow::_update_transform() {
// all components are allowed // all components are allowed
} }
if (likely(axis.length() > CMP_EPSILON)) { if (likely(!Math::is_zero_approx(axis.length()))) {
t.rotate_basis(axis.normalized(), angle); t.rotate_basis(axis.normalized(), angle);
} }
} }
@ -193,7 +193,7 @@ void PathFollow::_update_transform() {
float tilt_angle = c->interpolate_baked_tilt(o); float tilt_angle = c->interpolate_baked_tilt(o);
Vector3 tilt_axis = t_cur; // not sure what tilt is supposed to do, is this correct?? Vector3 tilt_axis = t_cur; // not sure what tilt is supposed to do, is this correct??
if (likely(Math::abs(tilt_angle) > CMP_EPSILON)) { if (likely(!Math::is_zero_approx(Math::abs(tilt_angle)))) {
if (rotation_mode == ROTATION_Y) { if (rotation_mode == ROTATION_Y) {
tilt_axis.x = 0; tilt_axis.x = 0;
tilt_axis.z = 0; tilt_axis.z = 0;
@ -203,7 +203,7 @@ void PathFollow::_update_transform() {
// all components are allowed // all components are allowed
} }
if (likely(tilt_axis.length() > CMP_EPSILON)) { if (likely(!Math::is_zero_approx(tilt_axis.length()))) {
t.rotate_basis(tilt_axis.normalized(), tilt_angle); t.rotate_basis(tilt_axis.normalized(), tilt_angle);
} }
} }

View File

@ -835,7 +835,7 @@ void VoxelLightBaker::plot_light_directional(const Vector3 &p_direction, const C
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
if (ABS(light_axis[i]) < CMP_EPSILON) if (Math::is_zero_approx(light_axis[i]))
continue; continue;
clip[clip_planes].normal[i] = 1.0; clip[clip_planes].normal[i] = 1.0;
@ -978,7 +978,7 @@ void VoxelLightBaker::plot_light_omni(const Vector3 &p_pos, const Color &p_color
for (int c = 0; c < 3; c++) { for (int c = 0; c < 3; c++) {
if (ABS(light_axis[c]) < CMP_EPSILON) if (Math::is_zero_approx(light_axis[c]))
continue; continue;
clip[clip_planes].normal[c] = 1.0; clip[clip_planes].normal[c] = 1.0;
@ -1113,7 +1113,7 @@ void VoxelLightBaker::plot_light_spot(const Vector3 &p_pos, const Vector3 &p_axi
for (int c = 0; c < 3; c++) { for (int c = 0; c < 3; c++) {
if (ABS(light_axis[c]) < CMP_EPSILON) if (Math::is_zero_approx(light_axis[c]))
continue; continue;
clip[clip_planes].normal[c] = 1.0; clip[clip_planes].normal[c] = 1.0;

View File

@ -1053,7 +1053,7 @@ void GraphEdit::set_connection_activity(const StringName &p_from, int p_from_por
if (E->get().from == p_from && E->get().from_port == p_from_port && E->get().to == p_to && E->get().to_port == p_to_port) { if (E->get().from == p_from && E->get().from_port == p_from_port && E->get().to == p_to && E->get().to_port == p_to_port) {
if (ABS(E->get().activity - p_activity) < CMP_EPSILON) { if (Math::is_equal_approx(E->get().activity, p_activity)) {
//update only if changed //update only if changed
top_layer->update(); top_layer->update();
connections_layer->update(); connections_layer->update();

View File

@ -1160,7 +1160,7 @@ void SceneTree::_update_root_rect() {
WARN_PRINT("Font oversampling only works with the resize modes 'Keep Width', 'Keep Height', and 'Expand'."); WARN_PRINT("Font oversampling only works with the resize modes 'Keep Width', 'Keep Height', and 'Expand'.");
} }
if (stretch_aspect == STRETCH_ASPECT_IGNORE || ABS(viewport_aspect - video_mode_aspect) < CMP_EPSILON) { if (stretch_aspect == STRETCH_ASPECT_IGNORE || Math::is_equal_approx(viewport_aspect, video_mode_aspect)) {
//same aspect or ignore aspect //same aspect or ignore aspect
viewport_size = desired_res; viewport_size = desired_res;
screen_size = video_mode; screen_size = video_mode;

View File

@ -1680,10 +1680,10 @@ T Animation::_interpolate(const Vector<TKey<T> > &p_keys, float p_time, Interpol
float delta = p_keys[next].time - p_keys[idx].time; float delta = p_keys[next].time - p_keys[idx].time;
float from = p_time - p_keys[idx].time; float from = p_time - p_keys[idx].time;
if (Math::absf(delta) > CMP_EPSILON) if (Math::is_zero_approx(delta))
c = from / delta;
else
c = 0; c = 0;
else
c = from / delta;
} else { } else {
@ -1691,10 +1691,10 @@ T Animation::_interpolate(const Vector<TKey<T> > &p_keys, float p_time, Interpol
float delta = (length - p_keys[idx].time) + p_keys[next].time; float delta = (length - p_keys[idx].time) + p_keys[next].time;
float from = p_time - p_keys[idx].time; float from = p_time - p_keys[idx].time;
if (Math::absf(delta) > CMP_EPSILON) if (Math::is_zero_approx(delta))
c = from / delta;
else
c = 0; c = 0;
else
c = from / delta;
} }
} else { } else {
@ -1707,10 +1707,10 @@ T Animation::_interpolate(const Vector<TKey<T> > &p_keys, float p_time, Interpol
float delta = endtime + p_keys[next].time; float delta = endtime + p_keys[next].time;
float from = endtime + p_time; float from = endtime + p_time;
if (Math::absf(delta) > CMP_EPSILON) if (Math::is_zero_approx(delta))
c = from / delta;
else
c = 0; c = 0;
else
c = from / delta;
} }
} else { // no loop } else { // no loop
@ -1723,10 +1723,10 @@ T Animation::_interpolate(const Vector<TKey<T> > &p_keys, float p_time, Interpol
float delta = p_keys[next].time - p_keys[idx].time; float delta = p_keys[next].time - p_keys[idx].time;
float from = p_time - p_keys[idx].time; float from = p_time - p_keys[idx].time;
if (Math::absf(delta) > CMP_EPSILON) if (Math::is_zero_approx(delta))
c = from / delta;
else
c = 0; c = 0;
else
c = from / delta;
} else { } else {
@ -2774,9 +2774,9 @@ bool Animation::_transform_track_optimize_key(const TKey<TransformKey> &t0, cons
const Vector3 &v1 = t1.value.loc; const Vector3 &v1 = t1.value.loc;
const Vector3 &v2 = t2.value.loc; const Vector3 &v2 = t2.value.loc;
if (v0.distance_to(v2) < CMP_EPSILON) { if (Math::is_zero_approx(v0.distance_to(v2))) {
//0 and 2 are close, let's see if 1 is close //0 and 2 are close, let's see if 1 is close
if (v0.distance_to(v1) > CMP_EPSILON) { if (!Math::is_zero_approx(v0.distance_to(v1))) {
//not close, not optimizable //not close, not optimizable
return false; return false;
} }
@ -2813,9 +2813,9 @@ bool Animation::_transform_track_optimize_key(const TKey<TransformKey> &t0, cons
//localize both to rotation from q0 //localize both to rotation from q0
if ((q0 - q2).length() < CMP_EPSILON) { if (Math::is_zero_approx((q0 - q2).length())) {
if ((q0 - q1).length() > CMP_EPSILON) if (!Math::is_zero_approx((q0 - q1).length()))
return false; return false;
} else { } else {
@ -2863,9 +2863,9 @@ bool Animation::_transform_track_optimize_key(const TKey<TransformKey> &t0, cons
const Vector3 &v1 = t1.value.scale; const Vector3 &v1 = t1.value.scale;
const Vector3 &v2 = t2.value.scale; const Vector3 &v2 = t2.value.scale;
if (v0.distance_to(v2) < CMP_EPSILON) { if (Math::is_zero_approx(v0.distance_to(v2))) {
//0 and 2 are close, let's see if 1 is close //0 and 2 are close, let's see if 1 is close
if (v0.distance_to(v1) > CMP_EPSILON) { if (!Math::is_zero_approx(v0.distance_to(v1))) {
//not close, not optimizable //not close, not optimizable
return false; return false;
} }

View File

@ -535,7 +535,7 @@ Error SceneState::_parse_node(Node *p_owner, Node *p_node, int p_parent_idx, Map
float a = value; float a = value;
float b = original; float b = original;
if (Math::abs(a - b) < CMP_EPSILON) if (Math::is_equal_approx(a, b))
continue; continue;
} else if (bool(Variant::evaluate(Variant::OP_EQUAL, value, original))) { } else if (bool(Variant::evaluate(Variant::OP_EQUAL, value, original))) {

View File

@ -98,7 +98,7 @@ static void _generate_contacts_edge_edge(const Vector3 *p_points_A, int p_point_
Vector3 c = rel_A.cross(rel_B).cross(rel_B); Vector3 c = rel_A.cross(rel_B).cross(rel_B);
if (Math::abs(rel_A.dot(c)) < CMP_EPSILON) { if (Math::is_zero_approx(rel_A.dot(c))) {
// should handle somehow.. // should handle somehow..
//ERR_PRINT("TODO FIX"); //ERR_PRINT("TODO FIX");
@ -678,7 +678,7 @@ static void _collision_box_box(const ShapeSW *p_a, const Transform &p_transform_
Vector3 axis = p_transform_a.basis.get_axis(i).cross(p_transform_b.basis.get_axis(j)); Vector3 axis = p_transform_a.basis.get_axis(i).cross(p_transform_b.basis.get_axis(j));
if (axis.length_squared() < CMP_EPSILON) if (Math::is_zero_approx(axis.length_squared()))
continue; continue;
axis.normalize(); axis.normalize();
@ -767,7 +767,7 @@ static void _collision_box_capsule(const ShapeSW *p_a, const Transform &p_transf
// cylinder // cylinder
Vector3 box_axis = p_transform_a.basis.get_axis(i); Vector3 box_axis = p_transform_a.basis.get_axis(i);
Vector3 axis = box_axis.cross(cyl_axis); Vector3 axis = box_axis.cross(cyl_axis);
if (axis.length_squared() < CMP_EPSILON) if (Math::is_zero_approx(axis.length_squared()))
continue; continue;
if (!separator.test_axis(axis.normalized())) if (!separator.test_axis(axis.normalized()))

View File

@ -127,10 +127,10 @@ bool ConeTwistJointSW::setup(real_t p_timestep) {
Vector3 relPos = pivotBInW - pivotAInW; Vector3 relPos = pivotBInW - pivotAInW;
Vector3 normal[3]; Vector3 normal[3];
if (relPos.length_squared() > CMP_EPSILON) { if (Math::is_zero_approx(relPos.length_squared())) {
normal[0] = relPos.normalized();
} else {
normal[0] = Vector3(real_t(1.0), 0, 0); normal[0] = Vector3(real_t(1.0), 0, 0);
} else {
normal[0] = relPos.normalized();
} }
plane_space(normal[0], normal[1], normal[2]); plane_space(normal[0], normal[1], normal[2]);

View File

@ -107,7 +107,7 @@ real_t G6DOFRotationalLimitMotorSW::solveAngularLimits(
// correction velocity // correction velocity
real_t motor_relvel = m_limitSoftness * (target_velocity - m_damping * rel_vel); real_t motor_relvel = m_limitSoftness * (target_velocity - m_damping * rel_vel);
if (motor_relvel < CMP_EPSILON && motor_relvel > -CMP_EPSILON) { if (Math::is_zero_approx(motor_relvel)) {
return 0.0f; //no need for applying force return 0.0f; //no need for applying force
} }

View File

@ -167,10 +167,10 @@ bool HingeJointSW::setup(real_t p_step) {
Vector3 relPos = pivotBInW - pivotAInW; Vector3 relPos = pivotBInW - pivotAInW;
Vector3 normal[3]; Vector3 normal[3];
if (relPos.length_squared() > CMP_EPSILON) { if (Math::is_zero_approx(relPos.length_squared())) {
normal[0] = relPos.normalized();
} else {
normal[0] = Vector3(real_t(1.0), 0, 0); normal[0] = Vector3(real_t(1.0), 0, 0);
} else {
normal[0] = relPos.normalized();
} }
plane_space(normal[0], normal[1], normal[2]); plane_space(normal[0], normal[1], normal[2]);

View File

@ -237,8 +237,8 @@ public:
Vector2 axis = p_axis; Vector2 axis = p_axis;
if (Math::abs(axis.x) < CMP_EPSILON && if (Math::is_zero_approx(axis.x) &&
Math::abs(axis.y) < CMP_EPSILON) { Math::is_zero_approx(axis.y)) {
// strange case, try an upwards separator // strange case, try an upwards separator
axis = Vector2(0.0, 1.0); axis = Vector2(0.0, 1.0);
} }

View File

@ -82,7 +82,7 @@ public:
_FORCE_INLINE_ bool operator()(const Item *p_left, const Item *p_right) const { _FORCE_INLINE_ bool operator()(const Item *p_left, const Item *p_right) const {
if (Math::abs(p_left->ysort_pos.y - p_right->ysort_pos.y) < CMP_EPSILON) if (Math::is_equal_approx(p_left->ysort_pos.y, p_right->ysort_pos.y))
return p_left->ysort_pos.x < p_right->ysort_pos.x; return p_left->ysort_pos.x < p_right->ysort_pos.x;
else else
return p_left->ysort_pos.y < p_right->ysort_pos.y; return p_left->ysort_pos.y < p_right->ysort_pos.y;

View File

@ -2654,7 +2654,7 @@ void VisualServerScene::_bake_gi_probe_light(const GIProbeDataHeader *header, co
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
if (ABS(light_axis[i]) < CMP_EPSILON) if (Math::is_zero_approx(light_axis[i]))
continue; continue;
clip[clip_planes].normal[i] = 1.0; clip[clip_planes].normal[i] = 1.0;
@ -2789,7 +2789,7 @@ void VisualServerScene::_bake_gi_probe_light(const GIProbeDataHeader *header, co
for (int c = 0; c < 3; c++) { for (int c = 0; c < 3; c++) {
if (ABS(light_axis[c]) < CMP_EPSILON) if (Math::is_zero_approx(light_axis[c]))
continue; continue;
clip[clip_planes].normal[c] = 1.0; clip[clip_planes].normal[c] = 1.0;