From fda5a6d27c45184f5b9a732356efe7bd34d5b804 Mon Sep 17 00:00:00 2001 From: Thomas Butz Date: Thu, 25 Apr 2024 18:13:39 +0200 Subject: [PATCH] Use infinity for unstorable values --- .../routing/ev/DecimalEncodedValueImpl.java | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/core/src/main/java/com/graphhopper/routing/ev/DecimalEncodedValueImpl.java b/core/src/main/java/com/graphhopper/routing/ev/DecimalEncodedValueImpl.java index ee9b5b3aa31..2e50179d927 100644 --- a/core/src/main/java/com/graphhopper/routing/ev/DecimalEncodedValueImpl.java +++ b/core/src/main/java/com/graphhopper/routing/ev/DecimalEncodedValueImpl.java @@ -82,14 +82,10 @@ public DecimalEncodedValueImpl(String name, int bits, double minStorableValue, d public void setDecimal(boolean reverse, int edgeId, EdgeIntAccess edgeIntAccess, double value) { if (!isInitialized()) throw new IllegalStateException("Call init before using EncodedValue " + getName()); - if (useMaximumAsInfinity) { - if (Double.isInfinite(value)) { - super.setInt(reverse, edgeId, edgeIntAccess, maxStorableValue); - return; - } else if (value >= maxStorableValue * factor) { // equality is important as maxStorableValue is reserved for infinity - super.uncheckedSet(reverse, edgeId, edgeIntAccess, maxStorableValue - 1); - return; - } + if (useMaximumAsInfinity && value >= maxStorableValue * factor) { + // treat any value larger or equal to maxStorableValue as infinity + super.setInt(reverse, edgeId, edgeIntAccess, maxStorableValue); + return; } else if (Double.isInfinite(value)) throw new IllegalArgumentException("Value cannot be infinite if useMaximumAsInfinity is false");