package org.opentrafficsim.demo.conflictAndControl; import java.awt.BorderLayout; import java.awt.Dimension; import java.io.Serializable; import java.net.URL; import java.rmi.RemoteException; import java.util.LinkedHashSet; import java.util.Set; import javax.naming.NamingException; import javax.swing.JPanel; import javax.swing.JScrollPane; import org.djunits.unit.LengthUnit; import org.djunits.value.vdouble.scalar.Duration; import org.djunits.value.vdouble.scalar.Length; import org.djunits.value.vdouble.scalar.Time; import org.djutils.event.EventInterface; import org.djutils.event.EventListenerInterface; import org.djutils.event.EventTypeInterface; import org.djutils.io.URLResource; import org.opentrafficsim.core.animation.gtu.colorer.DefaultSwitchableGTUColorer; import org.opentrafficsim.core.compatibility.Compatible; import org.opentrafficsim.core.dsol.AbstractOTSModel; import org.opentrafficsim.core.dsol.OTSAnimator; import org.opentrafficsim.core.dsol.OTSSimulatorInterface; import org.opentrafficsim.core.gtu.GTUType; import org.opentrafficsim.core.gtu.RelativePosition; import org.opentrafficsim.core.network.NetworkException; import org.opentrafficsim.demo.conflictAndControl.DemoTrafcodAndTurbo.TrafCODModel; import org.opentrafficsim.draw.core.OTSDrawingException; import org.opentrafficsim.draw.road.TrafficLightAnimation; import org.opentrafficsim.road.network.OTSRoadNetwork; import org.opentrafficsim.road.network.factory.xml.parser.XmlNetworkLaneParser; import org.opentrafficsim.road.network.lane.CrossSectionLink; import org.opentrafficsim.road.network.lane.CrossSectionLink.Priority; import org.opentrafficsim.road.network.lane.Lane; import org.opentrafficsim.road.network.lane.conflict.ConflictBuilder; import org.opentrafficsim.road.network.lane.object.sensor.TrafficLightSensor; import org.opentrafficsim.road.network.lane.object.trafficlight.SimpleTrafficLight; import org.opentrafficsim.road.network.lane.object.trafficlight.TrafficLight; import org.opentrafficsim.swing.gui.OTSAnimationPanel; import org.opentrafficsim.swing.gui.OTSSimulationApplication; import org.opentrafficsim.trafficcontrol.TrafficController; import org.opentrafficsim.trafficcontrol.trafcod.TrafCOD; import nl.tudelft.simulation.dsol.SimRuntimeException; import nl.tudelft.simulation.language.DSOLException; /** *

* Copyright (c) 2013-2020 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved.
* BSD-style license. See OpenTrafficSim License. *

* @version $Revision$, $LastChangedDate$, by $Author$, * initial version Dec 06, 2016
* @author Alexander Verbraeck * @author Peter Knoppers * @author Wouter Schakel */ public class DemoTrafcodAndTurbo extends OTSSimulationApplication { /** */ private static final long serialVersionUID = 20161118L; /** * Create a TrafcodAndTurbo demo. * @param title String; the title of the Frame * @param panel OTSAnimationPanel; the tabbed panel to display * @param model TrafCODModel; the model * @throws OTSDrawingException on animation error */ public DemoTrafcodAndTurbo(final String title, final OTSAnimationPanel panel, final TrafCODModel model) throws OTSDrawingException { super(model, panel); } /** * Main program. * @param args String[]; the command line arguments (not used) */ public static void main(final String[] args) { demo(true); } /** * Start the demo. * @param exitOnClose boolean; when running stand-alone: true; when running as part of a demo: false */ public static void demo(final boolean exitOnClose) { try { OTSAnimator simulator = new OTSAnimator("DemoTrafcodAndTurbo"); final TrafCODModel junctionModel = new TrafCODModel(simulator); simulator.initialize(Time.ZERO, Duration.ZERO, Duration.instantiateSI(3600.0), junctionModel); OTSAnimationPanel animationPanel = new OTSAnimationPanel(junctionModel.getNetwork().getExtent(), new Dimension(800, 600), simulator, junctionModel, new DefaultSwitchableGTUColorer(), junctionModel.getNetwork()); DemoTrafcodAndTurbo app = new DemoTrafcodAndTurbo("TrafCOD Turbo demo", animationPanel, junctionModel); app.setExitOnClose(exitOnClose); } catch (SimRuntimeException | NamingException | RemoteException | OTSDrawingException | DSOLException exception) { exception.printStackTrace(); } } /** * Add tab with trafCOD status. */ @Override protected void addTabs() { JScrollPane scrollPane = new JScrollPane(getModel().getControllerDisplayPanel()); JPanel wrapper = new JPanel(new BorderLayout()); wrapper.add(scrollPane); getAnimationPanel().getTabbedPane().addTab(getAnimationPanel().getTabbedPane().getTabCount() - 1, getModel().getTrafCOD().getId(), wrapper); } /** * The simulation model. */ static class TrafCODModel extends AbstractOTSModel implements EventListenerInterface { /** */ private static final long serialVersionUID = 20161020L; /** The network. */ private OTSRoadNetwork network; /** The TrafCOD controller. */ private TrafCOD trafCOD; /** TrafCOD controller display. */ private JPanel controllerDisplayPanel = new JPanel(new BorderLayout()); /** * @param simulator OTSSimulatorInterface; the simulator for this model */ TrafCODModel(final OTSSimulatorInterface simulator) { super(simulator); } /** {@inheritDoc} */ @Override public void constructModel() throws SimRuntimeException { try { URL xmlURL = URLResource.getResource("/conflictAndControl/TurboRoundaboutAndSignal.xml"); this.network = new OTSRoadNetwork("TurboRoundaboutAndSignal", true, getSimulator()); XmlNetworkLaneParser.build(xmlURL, this.network, false); // add conflicts ((CrossSectionLink) this.network.getLink("EBNA")).setPriority(Priority.PRIORITY); ((CrossSectionLink) this.network.getLink("NBWA")).setPriority(Priority.PRIORITY); ((CrossSectionLink) this.network.getLink("WBSA")).setPriority(Priority.PRIORITY); ((CrossSectionLink) this.network.getLink("SBEA")).setPriority(Priority.PRIORITY); ConflictBuilder.buildConflicts(this.network, this.network.getGtuType(GTUType.DEFAULTS.VEHICLE), this.simulator, new ConflictBuilder.FixedWidthGenerator(new Length(2.0, LengthUnit.SI))); // CrossSectionLink csLink = ((CrossSectionLink) // this.network.getLink("WWW")); // Lane lane = (Lane) csLink.getCrossSectionElement("RIGHT"); // GTUColorer gtuColorer = null; // setupBlock(lane, (DEVSSimulatorInterface.TimeDoubleUnit) this.simulator, // gtuColorer ); String[] directions = {"E", "S", "W", "N"}; // Add the traffic lights and the detectors Set trafficLights = new LinkedHashSet<>(); Set sensors = new LinkedHashSet<>(); Length stopLineMargin = new Length(0.1, LengthUnit.METER); Length headDetectorLength = new Length(1, LengthUnit.METER); Length headDetectorMargin = stopLineMargin.plus(headDetectorLength).plus(new Length(3, LengthUnit.METER)); Length longDetectorLength = new Length(30, LengthUnit.METER); Length longDetectorMargin = stopLineMargin.plus(longDetectorLength).plus(new Length(10, LengthUnit.METER)); int stream = 1; for (String direction : directions) { for (int laneNumber = 3; laneNumber >= 1; laneNumber--) { Lane lane = (Lane) ((CrossSectionLink) this.network.getLink(direction + "S", direction + "C")) .getCrossSectionElement("FORWARD" + laneNumber); if (lane != null) { if (stream != 7) { TrafficLight tl = new SimpleTrafficLight(String.format("%02d", stream), lane, lane.getLength().minus(stopLineMargin), this.simulator); trafficLights.add(tl); try { new TrafficLightAnimation(tl, this.simulator); } catch (RemoteException | NamingException exception) { throw new NetworkException(exception); } sensors.add(new TrafficLightSensor(String.format("D%02d1", stream), lane, lane.getLength().minus(headDetectorMargin), lane, lane.getLength().minus(headDetectorMargin).plus(headDetectorLength), null, RelativePosition.FRONT, RelativePosition.REAR, this.simulator, Compatible.EVERYTHING)); sensors.add(new TrafficLightSensor(String.format("D%02d2", stream), lane, lane.getLength().minus(longDetectorMargin), lane, lane.getLength().minus(longDetectorMargin).plus(longDetectorLength), null, RelativePosition.FRONT, RelativePosition.REAR, this.simulator, Compatible.EVERYTHING)); } else { lane = (Lane) ((CrossSectionLink) this.network.getLink("ESS1", "ESS")) .getCrossSectionElement("FORWARD"); TrafficLight tl = new SimpleTrafficLight(String.format("%02d", stream), lane, lane.getLength().minus(stopLineMargin), this.simulator); trafficLights.add(tl); try { new TrafficLightAnimation(tl, this.simulator); } catch (RemoteException | NamingException exception) { throw new NetworkException(exception); } sensors.add(new TrafficLightSensor(String.format("D%02d1", stream), lane, lane.getLength().minus(headDetectorMargin), lane, lane.getLength().minus(headDetectorMargin).plus(headDetectorLength), null, RelativePosition.FRONT, RelativePosition.REAR, this.simulator, Compatible.EVERYTHING)); sensors.add(new TrafficLightSensor(String.format("D%02d2", stream), lane, lane.getLength().minus(longDetectorMargin), lane, lane.getLength().minus(longDetectorMargin).plus(longDetectorLength), null, RelativePosition.FRONT, RelativePosition.REAR, this.simulator, Compatible.EVERYTHING)); } } stream++; } } String controllerName = "Not so simple TrafCOD controller"; this.trafCOD = new TrafCOD(controllerName, URLResource.getResource("/conflictAndControl/Intersection12Dir.tfc"), this.simulator, this.controllerDisplayPanel, null, null); this.trafCOD.addListener(this, TrafficController.TRAFFICCONTROL_CONTROLLER_EVALUATING); this.trafCOD.addListener(this, TrafficController.TRAFFICCONTROL_CONTROLLER_WARNING); this.trafCOD.addListener(this, TrafficController.TRAFFICCONTROL_CONFLICT_GROUP_CHANGED); this.trafCOD.addListener(this, TrafficController.TRAFFICCONTROL_STATE_CHANGED); this.trafCOD.addListener(this, TrafficController.TRAFFICCONTROL_VARIABLE_CREATED); this.trafCOD.addListener(this, TrafficController.TRAFFICCONTROL_TRACED_VARIABLE_UPDATED); // Subscribe the TrafCOD machine to trace command events that we // emit addListener(this.trafCOD, TrafficController.TRAFFICCONTROL_SET_TRACING); // fireEvent(TrafficController.TRAFFICCONTROL_SET_TRACING, new // Object[] {controllerName, "TGX", 8, true}); // fireEvent(TrafficController.TRAFFICCONTROL_SET_TRACING, new // Object[] {controllerName, "XR1", 11, true}); // fireEvent(TrafficController.TRAFFICCONTROL_SET_TRACING, new // Object[] {controllerName, "TD1", 11, true}); // fireEvent(TrafficController.TRAFFICCONTROL_SET_TRACING, new // Object[] {controllerName, "TGX", 11, true}); // fireEvent(TrafficController.TRAFFICCONTROL_SET_TRACING, new // Object[] {controllerName, "TL", 11, true}); // System.out.println("demo: emitting a SET TRACING event for // all variables related to stream 11"); // fireEvent(TrafficController.TRAFFICCONTROL_SET_TRACING, new // Object[] { controllerName, "", 11, true }); // TrafCODDemo2.this.trafCOD.traceVariablesOfStream(TrafficController.NO_STREAM, // true); // TrafCODDemo2.this.trafCOD.traceVariablesOfStream(11, true); // TrafCODDemo2.this.trafCOD.traceVariable("MRV", 11, true); } catch (Exception exception) { exception.printStackTrace(); } } /** {@inheritDoc} */ @Override public final OTSRoadNetwork getNetwork() { return this.network; } /** * @return trafCOD */ public final TrafCOD getTrafCOD() { return this.trafCOD; } /** * @return controllerDisplayPanel */ public final JPanel getControllerDisplayPanel() { return this.controllerDisplayPanel; } /** {@inheritDoc} */ @Override public void notify(final EventInterface event) throws RemoteException { EventTypeInterface type = event.getType(); Object[] payload = (Object[]) event.getContent(); if (TrafficController.TRAFFICCONTROL_CONTROLLER_EVALUATING.equals(type)) { // System.out.println("Evaluation starts at " + // getSimulator().getSimulatorTime()); return; } else if (TrafficController.TRAFFICCONTROL_CONFLICT_GROUP_CHANGED.equals(type)) { System.out.println("Conflict group changed from " + ((String) payload[1]) + " to " + ((String) payload[2])); } else if (TrafficController.TRAFFICCONTROL_TRACED_VARIABLE_UPDATED.equals(type)) { System.out.println(String.format("Variable changed %s <- %d %s", payload[1], payload[4], payload[5])); } else if (TrafficController.TRAFFICCONTROL_CONTROLLER_WARNING.equals(type)) { System.out.println("Warning " + payload[1]); } else { System.out.print("TrafCODDemo received event of type " + event.getType() + ", payload ["); String separator = ""; for (Object o : payload) { System.out.print(separator + o); separator = ","; } System.out.println("]"); } } /** {@inheritDoc} */ @Override public Serializable getSourceId() { return "TrafCODModel"; } } }