com.graphhopper.routing.ev.EncodedValue Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of graphhopper-core Show documentation
Show all versions of graphhopper-core Show documentation
GraphHopper is a fast and memory efficient Java road routing engine
working seamlessly with OpenStreetMap data.
/*
* Licensed to GraphHopper GmbH under one or more contributor
* license agreements. See the NOTICE file distributed with this work for
* additional information regarding copyright ownership.
*
* GraphHopper GmbH licenses this file to you under the Apache License,
* Version 2.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.graphhopper.routing.ev;
import com.fasterxml.jackson.annotation.JsonTypeInfo;
/**
* This interface defines how to store and read values from a list of integers
*
* @see com.graphhopper.storage.IntsRef
*/
@JsonTypeInfo(use = JsonTypeInfo.Id.CLASS, property = "className")
public interface EncodedValue {
/**
* This method sets the dataIndex and shift of this EncodedValue object and potentially changes the submitted init
* object afterwards via calling next
*
* @return used bits
* @see InitializerConfig#next(int)
*/
int init(InitializerConfig init);
/**
* This method returns the hierarchical name like vehicle.type of this EncodedValue
*/
String getName();
/**
* @return true if this EncodedValue can store a different value for its reverse direction
*/
boolean isStoreTwoDirections();
class InitializerConfig {
int dataIndex = -1;
int shift = 32;
int nextShift = 32;
int bitMask = 0;
/**
* This method determines a space of the specified bits and sets shift and dataIndex accordingly
*/
void next(int usedBits) {
shift = nextShift;
if ((shift - 1 + usedBits) / 32 > (shift - 1) / 32) {
dataIndex++;
shift = 0;
}
// we need 1L as otherwise it'll fail for usedBits==32
bitMask = (int) ((1L << usedBits) - 1);
bitMask <<= shift;
nextShift = shift + usedBits;
}
public int getRequiredBits() {
return (dataIndex) * 32 + nextShift;
}
public int getRequiredInts() {
return (int) Math.ceil((double) getRequiredBits() / 32.0);
}
}
}