Optimise color distance check in MapPalette by removing floating point math

This commit is contained in:
Barnaby 2024-06-29 12:04:48 +01:00
parent 30b4dedabb
commit 14832a70e9

View File

@ -29,14 +29,19 @@ public final class MapPalette {
} }
private static double getDistance(@NotNull Color c1, @NotNull Color c2) { private static double getDistance(@NotNull Color c1, @NotNull Color c2) {
double rmean = (c1.getRed() + c2.getRed()) / 2.0; // Paper start - Optimize color distance calculation by removing floating point math
double r = c1.getRed() - c2.getRed(); int rsum = c1.getRed() + c2.getRed(); // Use sum instead of mean for no division
double g = c1.getGreen() - c2.getGreen(); int r = c1.getRed() - c2.getRed();
int g = c1.getGreen() - c2.getGreen();
int b = c1.getBlue() - c2.getBlue(); int b = c1.getBlue() - c2.getBlue();
double weightR = 2 + rmean / 256.0; // All weights are 512x their original to avoid floating point division
double weightG = 4.0; int weightR = 1024 + rsum;
double weightB = 2 + (255 - rmean) / 256.0; int weightG = 2048;
int weightB = 1024 + (255*2 - rsum);
// Division by 256 here is unnecessary as this won't change the result of the sort
return weightR * r * r + weightG * g * g + weightB * b * b; return weightR * r * r + weightG * g * g + weightB * b * b;
// Paper end
} }
@NotNull @NotNull