/*
* Copyright 2014 Red Hat, Inc. and/or its affiliates.
*
* Licensed 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 org.optaplanner.examples.tsp.domain.location;
import java.util.Map;
import com.thoughtworks.xstream.annotations.XStreamAlias;
/**
* The cost between 2 locations was precalculated on a real road network route.
* The cost itself might be the distance in km, the travel time, the fuel usage or a weighted function of any of those.
* Used with {@link DistanceType#ROAD_DISTANCE}.
*/
@XStreamAlias("TspRoadLocation")
public class RoadLocation extends Location {
// Prefer Map over array or List because customers might be added and removed in real-time planning.
protected Map<RoadLocation, Double> travelDistanceMap;
public RoadLocation() {
}
public RoadLocation(long id, double latitude, double longitude) {
super(id, latitude, longitude);
}
public Map<RoadLocation, Double> getTravelDistanceMap() {
return travelDistanceMap;
}
public void setTravelDistanceMap(Map<RoadLocation, Double> travelDistanceMap) {
this.travelDistanceMap = travelDistanceMap;
}
@Override
public long getDistanceTo(Location location) {
if (this == location) {
return 0L;
}
double distance = travelDistanceMap.get((RoadLocation) location);
// Multiplied by 1000 to avoid floating point arithmetic rounding errors
return (long) (distance * 1000.0 + 0.5);
}
}