在optaplanner中使用点之间的实际距离

时间:2014-01-30 11:51:42

标签: optaplanner


你好

我是optaplanner的新手。我试图使用vrp(tw)示例。

我想设置真实距离(路线距离)以获得真正的解决方案。

我在双NXN矩阵(距离(a,b)<>距离(b,a))中的所有点之间有实际距离,因此,我如何使用.xml(.vrp)输入文件中的矩阵来解决vrp问题?

注意:我的矩阵大约是2X10X10到2X100X100。

在此先感谢。

奥普

2 个答案:

答案 0 :(得分:2)

这是我去的方式。可能有比这更好的解决方案 - 我不得不承认我刚开始玩Optaplanner。 欢迎任何有关改进的建议。

希望这会有所帮助。布拉德,保罗

我的矩阵采用“从客户”“到客户”“距离”的形式,我创建了一个班级距离。 *在导入器中,我为每个位置构建了一个DistanceMap: *

 readConstantLine("CustFrom CustTo Distance");
            long locationId = -1;
            line = bufferedReader.readLine(); 
            distanceMap = new HashMap<Long, Double>(locationListSize);
            while (line != null && !line.trim().isEmpty()) {
                 String[] lineTokens = splitBySpacesOrTabs(line.trim(), 3);
                 if (locationId != Long.parseLong(lineTokens[0])){
                        if (distanceMap.isEmpty() == false){
                             Location location = new Location();
                             location = locationList.get((int) locationId);
                             distance.setDistanceMap(distanceMap);
                             location.setDistance(distance);
                             locationList.set((int) locationId, location);

                         }
                        locationId = Long.parseLong(lineTokens[0]);
                        distance = new Distance();
                        distanceMap = new HashMap<Long, Double>(locationListSize);

                 }
                 distanceMap.put( Long.parseLong(lineTokens[1]), Double.parseDouble(lineTokens[2]));         
                 line = bufferedReader.readLine();       
                }
            if (distanceMap.isEmpty() == false){
             Location location = new Location();
             location = locationList.get((int) locationId);
             distance.setDistanceMap(distanceMap);
             location.setDistance(distance);
             locationList.set((int) locationId, location);

在位置类中,我使用以下方法获取距离:

 public int getMilliDistanceDistanceMap(Location location) {
        // Implementation distanceMap
     return distance.getDistance(location, this)  ; 

距离类方法如下所示:

public int getDistance(Location fromLocation,Location toLocation )
{
    double distance = toLocation.getDistance().distanceMap.get(fromLocation.getId());
    return  (int) (distance * 1000);
}

答案 1 :(得分:0)

从2019年开始,从optaweb-vehicle-routing