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 import nl.tudelft.simulation.language.DSOLException;
37
38
39
40
41
42
43
44
45
46
47
48 public class CircularLaneSwing extends OTSSimulationApplication<CircularLaneModel>
49 {
50
51 private static final long serialVersionUID = 1L;
52
53
54
55
56
57
58
59
60 public CircularLaneSwing(final String title, final OTSAnimationPanel panel, final CircularLaneModel model)
61 throws OTSDrawingException
62 {
63 super(model, panel);
64 OTSRoadNetwork network = model.getNetwork();
65 System.out.println(network.getLinkMap());
66
67 }
68
69
70 @Override
71 protected void addTabs()
72 {
73 addStatisticsTabs(getModel().getSimulator());
74 }
75
76
77
78
79
80 public static void main(final String[] args)
81 {
82 demo(true);
83 }
84
85
86
87
88
89 public static void demo(final boolean exitOnClose)
90 {
91 try
92 {
93 OTSAnimator simulator = new OTSAnimator("CircularLaneSwing");
94 final CircularLaneModelml#CircularLaneModel">CircularLaneModel otsModel = new CircularLaneModel(simulator);
95 if (TabbedParameterDialog.process(otsModel.getInputParameterMap()))
96 {
97 simulator.initialize(Time.ZERO, Duration.ZERO, Duration.instantiateSI(3600.0), otsModel);
98 OTSAnimationPanel animationPanel = new OTSAnimationPanel(otsModel.getNetwork().getExtent(),
99 new Dimension(800, 600), simulator, otsModel, DEFAULT_COLORER, otsModel.getNetwork());
100 CircularLaneSwingng.html#CircularLaneSwing">CircularLaneSwing app = new CircularLaneSwing("Circular Lane", animationPanel, otsModel);
101 app.setExitOnClose(exitOnClose);
102 }
103 else
104 {
105 if (exitOnClose)
106 {
107 System.exit(0);
108 }
109 }
110 }
111 catch (SimRuntimeException | NamingException | RemoteException | OTSDrawingException | DSOLException exception)
112 {
113 exception.printStackTrace();
114 }
115 }
116
117
118
119
120
121 protected final void addStatisticsTabs(final OTSSimulatorInterface simulator)
122 {
123 GraphPath<KpiLaneDirection> path;
124 try
125 {
126 path = GraphLaneUtil.createPath("Lane", new LaneDirection(getModel().getPath().get(0), GTUDirectionality.DIR_PLUS));
127 }
128 catch (NetworkException exception)
129 {
130 throw new RuntimeException("Could not create a path as a lane has no set speed limit.", exception);
131 }
132
133 RoadSampler sampler = new RoadSampler(getModel().getNetwork());
134 GraphPath.initRecording(sampler, path);
135 ContourDataSource<?> dataPool = new ContourDataSource<>(sampler.getSamplerData(), path);
136 TablePanel charts = new TablePanel(3, 2);
137 SwingPlot plot = null;
138
139 plot = new SwingTrajectoryPlot(
140 new TrajectoryPlot("TrajectoryPlot", Duration.instantiateSI(10.0), simulator, sampler.getSamplerData(), path));
141 charts.setCell(plot.getContentPane(), 0, 0);
142
143 plot = new SwingContourPlot(new ContourPlotDensity("DensityPlot", simulator, dataPool));
144 charts.setCell(plot.getContentPane(), 1, 0);
145
146 plot = new SwingContourPlot(new ContourPlotSpeed("SpeedPlot", simulator, dataPool));
147 charts.setCell(plot.getContentPane(), 2, 0);
148
149 plot = new SwingContourPlot(new ContourPlotFlow("FlowPlot", simulator, dataPool));
150 charts.setCell(plot.getContentPane(), 1, 1);
151
152 plot = new SwingContourPlot(new ContourPlotAcceleration("AccelerationPlot", simulator, dataPool));
153 charts.setCell(plot.getContentPane(), 2, 1);
154
155 getAnimationPanel().getTabbedPane().addTab(getAnimationPanel().getTabbedPane().getTabCount(), "statistics ", charts);
156 }
157
158 }