View Javadoc
1   package org.opentrafficsim.demo;
2   
3   import java.awt.Dimension;
4   import java.rmi.RemoteException;
5   
6   import javax.naming.NamingException;
7   
8   import org.djunits.value.vdouble.scalar.Duration;
9   import org.djunits.value.vdouble.scalar.Time;
10  import org.opentrafficsim.core.dsol.OTSAnimator;
11  import org.opentrafficsim.core.dsol.OTSSimulatorInterface;
12  import org.opentrafficsim.core.gtu.GTUDirectionality;
13  import org.opentrafficsim.core.network.NetworkException;
14  import org.opentrafficsim.draw.core.OTSDrawingException;
15  import org.opentrafficsim.draw.graphs.ContourDataSource;
16  import org.opentrafficsim.draw.graphs.ContourPlotAcceleration;
17  import org.opentrafficsim.draw.graphs.ContourPlotDensity;
18  import org.opentrafficsim.draw.graphs.ContourPlotFlow;
19  import org.opentrafficsim.draw.graphs.ContourPlotSpeed;
20  import org.opentrafficsim.draw.graphs.GraphPath;
21  import org.opentrafficsim.draw.graphs.TrajectoryPlot;
22  import org.opentrafficsim.draw.graphs.road.GraphLaneUtil;
23  import org.opentrafficsim.kpi.sampling.KpiLaneDirection;
24  import org.opentrafficsim.road.network.OTSRoadNetwork;
25  import org.opentrafficsim.road.network.lane.LaneDirection;
26  import org.opentrafficsim.road.network.sampling.RoadSampler;
27  import org.opentrafficsim.swing.graphs.SwingContourPlot;
28  import org.opentrafficsim.swing.graphs.SwingPlot;
29  import org.opentrafficsim.swing.graphs.SwingTrajectoryPlot;
30  import org.opentrafficsim.swing.gui.OTSAnimationPanel;
31  import org.opentrafficsim.swing.gui.OTSSimulationApplication;
32  
33  import nl.tudelft.simulation.dsol.SimRuntimeException;
34  import nl.tudelft.simulation.dsol.swing.gui.TablePanel;
35  import nl.tudelft.simulation.dsol.swing.gui.inputparameters.TabbedParameterDialog;
36  
37  /**
38   * Circular lane simulation demo.
39   * <p>
40   * Copyright (c) 2013-2020 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
41   * BSD-style license. See <a href="http://opentrafficsim.org/docs/license.html">OpenTrafficSim License</a>.
42   * <p>
43   * $LastChangedDate: 2018-11-18 20:49:04 +0100 (Sun, 18 Nov 2018) $, @version $Revision: 4743 $, by $Author: averbraeck $,
44   * initial version 21 nov. 2014 <br>
45   * @author <a href="http://www.tudelft.nl/pknoppers">Peter Knoppers</a>
46   */
47  public class CircularLaneSwing extends OTSSimulationApplication<CircularLaneModel>
48  {
49      /** */
50      private static final long serialVersionUID = 1L;
51  
52      /**
53       * Create a CircularLane Swing application.
54       * @param title String; the title of the Frame
55       * @param panel OTSAnimationPanel; the tabbed panel to display
56       * @param model CircularLaneModel; the model
57       * @throws OTSDrawingException on animation error
58       */
59      public CircularLaneSwing(final String title, final OTSAnimationPanel panel, final CircularLaneModel model)
60              throws OTSDrawingException
61      {
62          super(model, panel);
63          OTSRoadNetwork network = model.getNetwork();
64          System.out.println(network.getLinkMap());
65  
66      }
67  
68      /** {@inheritDoc} */
69      @Override
70      protected void addTabs()
71      {
72          addStatisticsTabs(getModel().getSimulator());
73      }
74  
75      /**
76       * Main program.
77       * @param args String[]; the command line arguments (not used)
78       */
79      public static void main(final String[] args)
80      {
81          demo(true);
82      }
83  
84      /**
85       * Start the demo.
86       * @param exitOnClose boolean; when running stand-alone: true; when running as part of a demo: false
87       */
88      public static void demo(final boolean exitOnClose)
89      {
90          try
91          {
92              OTSAnimator simulator = new OTSAnimator();
93              final CircularLaneModelml#CircularLaneModel">CircularLaneModel otsModel = new CircularLaneModel(simulator);
94              if (TabbedParameterDialog.process(otsModel.getInputParameterMap()))
95              {
96                  simulator.initialize(Time.ZERO, Duration.ZERO, Duration.instantiateSI(3600.0), otsModel);
97                  OTSAnimationPanel animationPanel = new OTSAnimationPanel(otsModel.getNetwork().getExtent(),
98                          new Dimension(800, 600), simulator, otsModel, DEFAULT_COLORER, otsModel.getNetwork());
99                  CircularLaneSwingng.html#CircularLaneSwing">CircularLaneSwing app = new CircularLaneSwing("Circular Lane", animationPanel, otsModel);
100                 app.setExitOnClose(exitOnClose);
101             }
102             else
103             {
104                 if (exitOnClose)
105                 {
106                     System.exit(0);
107                 }
108             }
109         }
110         catch (SimRuntimeException | NamingException | RemoteException | OTSDrawingException exception)
111         {
112             exception.printStackTrace();
113         }
114     }
115 
116     /**
117      * Add the statistics tabs.
118      * @param simulator OTSSimulatorInterface; the simulator on which sampling can be scheduled
119      */
120     protected final void addStatisticsTabs(final OTSSimulatorInterface simulator)
121     {
122         GraphPath<KpiLaneDirection> path;
123         try
124         {
125             path = GraphLaneUtil.createPath("Lane", new LaneDirection(getModel().getPath().get(0), GTUDirectionality.DIR_PLUS));
126         }
127         catch (NetworkException exception)
128         {
129             throw new RuntimeException("Could not create a path as a lane has no set speed limit.", exception);
130         }
131 
132         RoadSampler sampler = new RoadSampler(simulator);
133         ContourDataSource<?> dataPool = new ContourDataSource<>(sampler, path);
134         TablePanel charts = new TablePanel(3, 2);
135         SwingPlot plot = null;
136 
137         plot = new SwingTrajectoryPlot(new TrajectoryPlot("TrajectoryPlot", Duration.instantiateSI(10.0), simulator, sampler, path));
138         charts.setCell(plot.getContentPane(), 0, 0);
139 
140         plot = new SwingContourPlot(new ContourPlotDensity("DensityPlot", simulator, dataPool));
141         charts.setCell(plot.getContentPane(), 1, 0);
142 
143         plot = new SwingContourPlot(new ContourPlotSpeed("SpeedPlot", simulator, dataPool));
144         charts.setCell(plot.getContentPane(), 2, 0);
145 
146         plot = new SwingContourPlot(new ContourPlotFlow("FlowPlot", simulator, dataPool));
147         charts.setCell(plot.getContentPane(), 1, 1);
148 
149         plot = new SwingContourPlot(new ContourPlotAcceleration("AccelerationPlot", simulator, dataPool));
150         charts.setCell(plot.getContentPane(), 2, 1);
151 
152         getAnimationPanel().getTabbedPane().addTab(getAnimationPanel().getTabbedPane().getTabCount(), "statistics ", charts);
153     }
154 
155 }