From db05700052958a9e75802b7e4d66a8db26e39fe6 Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Wed, 9 Oct 2013 01:56:35 -0500 Subject: [PATCH] Use simple multiplication for squaring. Fixes BUKKIT-4836 This change adds a method to NumberConversions for squaring and replaces uses of Math.pow(..., 2) with the new method for efficiency reasons. By: Wesley Wolfe --- paper-api/src/main/java/org/bukkit/Location.java | 6 +++--- .../main/java/org/bukkit/util/NumberConversions.java | 4 ++++ paper-api/src/main/java/org/bukkit/util/Vector.java | 10 +++++----- 3 files changed, 12 insertions(+), 8 deletions(-) diff --git a/paper-api/src/main/java/org/bukkit/Location.java b/paper-api/src/main/java/org/bukkit/Location.java index bcc963bf7f..e3f362fdc9 100644 --- a/paper-api/src/main/java/org/bukkit/Location.java +++ b/paper-api/src/main/java/org/bukkit/Location.java @@ -334,7 +334,7 @@ public class Location implements Cloneable { * @return the magnitude */ public double length() { - return Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2) + Math.pow(z, 2)); + return Math.sqrt(NumberConversions.square(x) + NumberConversions.square(y) + NumberConversions.square(z)); } /** @@ -345,7 +345,7 @@ public class Location implements Cloneable { * @return the magnitude */ public double lengthSquared() { - return Math.pow(x, 2) + Math.pow(y, 2) + Math.pow(z, 2); + return NumberConversions.square(x) + NumberConversions.square(y) + NumberConversions.square(z); } /** @@ -381,7 +381,7 @@ public class Location implements Cloneable { throw new IllegalArgumentException("Cannot measure distance between " + getWorld().getName() + " and " + o.getWorld().getName()); } - return Math.pow(x - o.x, 2) + Math.pow(y - o.y, 2) + Math.pow(z - o.z, 2); + return NumberConversions.square(x - o.x) + NumberConversions.square(y - o.y) + NumberConversions.square(z - o.z); } /** diff --git a/paper-api/src/main/java/org/bukkit/util/NumberConversions.java b/paper-api/src/main/java/org/bukkit/util/NumberConversions.java index dba11afb3a..29f81d011e 100644 --- a/paper-api/src/main/java/org/bukkit/util/NumberConversions.java +++ b/paper-api/src/main/java/org/bukkit/util/NumberConversions.java @@ -20,6 +20,10 @@ public final class NumberConversions { return floor(num + 0.5d); } + public static double square(double num) { + return num * num; + } + public static int toInt(Object object) { if (object instanceof Number) { return ((Number) object).intValue(); diff --git a/paper-api/src/main/java/org/bukkit/util/Vector.java b/paper-api/src/main/java/org/bukkit/util/Vector.java index 30547c52bc..de30d2babb 100644 --- a/paper-api/src/main/java/org/bukkit/util/Vector.java +++ b/paper-api/src/main/java/org/bukkit/util/Vector.java @@ -152,7 +152,7 @@ public class Vector implements Cloneable, ConfigurationSerializable { * @return the magnitude */ public double length() { - return Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2) + Math.pow(z, 2)); + return Math.sqrt(NumberConversions.square(x) + NumberConversions.square(y) + NumberConversions.square(z)); } /** @@ -161,7 +161,7 @@ public class Vector implements Cloneable, ConfigurationSerializable { * @return the magnitude */ public double lengthSquared() { - return Math.pow(x, 2) + Math.pow(y, 2) + Math.pow(z, 2); + return NumberConversions.square(x) + NumberConversions.square(y) + NumberConversions.square(z); } /** @@ -175,7 +175,7 @@ public class Vector implements Cloneable, ConfigurationSerializable { * @return the distance */ public double distance(Vector o) { - return Math.sqrt(Math.pow(x - o.x, 2) + Math.pow(y - o.y, 2) + Math.pow(z - o.z, 2)); + return Math.sqrt(NumberConversions.square(x - o.x) + NumberConversions.square(y - o.y) + NumberConversions.square(z - o.z)); } /** @@ -185,7 +185,7 @@ public class Vector implements Cloneable, ConfigurationSerializable { * @return the distance */ public double distanceSquared(Vector o) { - return Math.pow(x - o.x, 2) + Math.pow(y - o.y, 2) + Math.pow(z - o.z, 2); + return NumberConversions.square(x - o.x) + NumberConversions.square(y - o.y) + NumberConversions.square(z - o.z); } /** @@ -346,7 +346,7 @@ public class Vector implements Cloneable, ConfigurationSerializable { * @return whether this vector is in the sphere */ public boolean isInSphere(Vector origin, double radius) { - return (Math.pow(origin.x - x, 2) + Math.pow(origin.y - y, 2) + Math.pow(origin.z - z, 2)) <= Math.pow(radius, 2); + return (NumberConversions.square(origin.x - x) + NumberConversions.square(origin.y - y) + NumberConversions.square(origin.z - z)) <= NumberConversions.square(radius); } /**