com.github.rinde.rinsim.examples.demo.factory.BlockingGraphRoadModel Maven / Gradle / Ivy
/*
* Copyright (C) 2011-2015 Rinde van Lon, iMinds-DistriNet, KU Leuven
*
* 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 com.github.rinde.rinsim.examples.demo.factory;
import static com.google.common.collect.Lists.newArrayList;
import static com.google.common.collect.Lists.newLinkedList;
import static com.google.common.collect.Sets.newLinkedHashSet;
import java.util.LinkedList;
import java.util.List;
import java.util.Queue;
import java.util.Set;
import javax.measure.quantity.Length;
import javax.measure.quantity.Velocity;
import javax.measure.unit.Unit;
import com.github.rinde.rinsim.core.TimeLapse;
import com.github.rinde.rinsim.core.model.road.GraphRoadModel;
import com.github.rinde.rinsim.core.model.road.MoveProgress;
import com.github.rinde.rinsim.core.model.road.MovingRoadUser;
import com.github.rinde.rinsim.geom.Connection;
import com.github.rinde.rinsim.geom.ConnectionData;
import com.github.rinde.rinsim.geom.Graph;
import com.github.rinde.rinsim.geom.Point;
import com.google.common.collect.LinkedHashMultimap;
import com.google.common.collect.Multimap;
/**
* @author Rinde van Lon
*
*/
public class BlockingGraphRoadModel extends GraphRoadModel {
Set blockedNodes;
Multimap vehicleBlocks;
BlockingGraphRoadModel(Graph extends ConnectionData> pGraph,
Unit distanceUnit, Unit speedUnit) {
super(pGraph, distanceUnit, speedUnit);
blockedNodes = newLinkedHashSet();
vehicleBlocks = LinkedHashMultimap.create();
}
@Override
protected MoveProgress doFollowPath(MovingRoadUser object, Queue path,
TimeLapse time) {
blockedNodes.removeAll(vehicleBlocks.get(object));
vehicleBlocks.removeAll(object);
final List inputP = newArrayList(path);
int index = -1;
for (int i = 0; i < inputP.size(); i++) {
if (blockedNodes.contains(inputP.get(i))) {
index = i;
break;
}
}
final MoveProgress mp;
if (index >= 0) {
final Queue newPath = index == -1 ? new LinkedList()
: newLinkedList(inputP.subList(0, index));
final int originalSize = newPath.size();
mp = super.doFollowPath(object, newPath, time);
for (int i = 0; i < originalSize - newPath.size(); i++) {
path.remove();
}
time.consumeAll();
} else {
mp = super.doFollowPath(object, path, time);
}
final Loc newLoc = objLocs.get(object);
if (newLoc.isOnConnection()) {
final Connection> conn = newLoc.conn.get();
blockedNodes.add(conn.to());
vehicleBlocks.put(object, conn.to());
} else {
blockedNodes.add(getPosition(object));
vehicleBlocks.put(object, getPosition(object));
}
return mp;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy