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