View Javadoc
1   package org.opentrafficsim.road.test;
2   
3   import java.awt.geom.Rectangle2D;
4   import java.awt.geom.Rectangle2D.Double;
5   import java.io.IOException;
6   import java.net.URL;
7   import java.util.ArrayList;
8   
9   import javax.naming.NamingException;
10  import javax.swing.JPanel;
11  import javax.swing.SwingUtilities;
12  import javax.xml.parsers.ParserConfigurationException;
13  
14  import nl.tudelft.simulation.dsol.SimRuntimeException;
15  import nl.tudelft.simulation.dsol.simulators.SimulatorInterface;
16  import nl.tudelft.simulation.language.io.URLResource;
17  
18  import org.djunits.unit.TimeUnit;
19  import org.djunits.value.vdouble.scalar.DoubleScalar;
20  import org.djunits.value.vdouble.scalar.Time;
21  import org.opentrafficsim.core.dsol.OTSDEVSSimulatorInterface;
22  import org.opentrafficsim.core.dsol.OTSModelInterface;
23  import org.opentrafficsim.core.dsol.OTSSimTimeDouble;
24  import org.opentrafficsim.core.geometry.OTSGeometryException;
25  import org.opentrafficsim.core.gtu.GTUException;
26  import org.opentrafficsim.core.gtu.animation.GTUColorer;
27  import org.opentrafficsim.core.network.NetworkException;
28  import org.opentrafficsim.road.network.factory.xml.XmlNetworkLaneParser;
29  import org.opentrafficsim.simulationengine.AbstractWrappableAnimation;
30  import org.opentrafficsim.simulationengine.OTSSimulationException;
31  import org.opentrafficsim.simulationengine.properties.AbstractProperty;
32  import org.xml.sax.SAXException;
33  
34  /**
35   * Four stop demo
36   * <p>
37   * Copyright (c) 2013-2015 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
38   * BSD-style license. See <a href="http://opentrafficsim.org/node/13">OpenTrafficSim License</a>.
39   * <p>
40   * @version $Revision$, $LastChangedDate$, by $Author$, initial version Dec 1, 2015 <br>
41   * @author <a href="http://www.tbm.tudelft.nl/averbraeck">Alexander Verbraeck</a>
42   * @author <a href="http://www.tudelft.nl/pknoppers">Peter Knoppers</a>
43   * @author Wouter Schakel
44   */
45  public class LMRSTests extends AbstractWrappableAnimation
46  {
47      /**
48       * Main program.
49       * @param args String[]; the command line arguments (not used)
50       * @throws SimRuntimeException should never happen
51       */
52      public static void main(final String[] args) throws SimRuntimeException
53      {
54          SwingUtilities.invokeLater(new Runnable()
55          {
56              @Override
57              public void run()
58              {
59                  try
60                  {
61                  	LMRSTests xmlModel = new LMRSTests();
62                      // 1 hour simulation run for testing
63                      xmlModel.buildAnimator(new Time.Abs(0.0, TimeUnit.SECOND), new Time.Rel(0.0, TimeUnit.SECOND),
64                          new Time.Rel(60.0, TimeUnit.MINUTE), new ArrayList<AbstractProperty<?>>(), null, true);
65                  }
66                  catch (SimRuntimeException | NamingException | OTSSimulationException exception)
67                  {
68                      exception.printStackTrace();
69                  }
70              }
71          });
72      }
73  
74      /** {@inheritDoc} */
75      @Override
76      public final String shortName()
77      {
78          return "TestXMLModel";
79      }
80  
81      /** {@inheritDoc} */
82      @Override
83      public final String description()
84      {
85          return "TestXMLModel";
86      }
87  
88      /** {@inheritDoc} */
89      @Override
90      public final void stopTimersThreads()
91      {
92          super.stopTimersThreads();
93      }
94  
95      /** {@inheritDoc} */
96      @Override
97      protected final JPanel makeCharts()
98      {
99          return null;
100     }
101 
102     /** {@inheritDoc} */
103     @Override
104     protected final OTSModelInterface makeModel(final GTUColorer colorer)
105     {
106         return new TestXMLModel();
107     }
108 
109     /** {@inheritDoc} */
110     @Override
111     protected final Double makeAnimationRectangle()
112     {
113         return new Rectangle2D.Double(-100, -100, 3200, 200);
114     }
115 
116     /**
117      * Model to test the XML parser.
118      * <p>
119      * Copyright (c) 2013-2015 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. <br>
120      * All rights reserved. BSD-style license. See <a href="http://opentrafficsim.org/docs/license.html">OpenTrafficSim
121      * License</a>.
122      * <p>
123      * $LastChangedDate: 2015-09-14 01:33:02 +0200 (Mon, 14 Sep 2015) $, @version $Revision: 1401 $, by $Author: averbraeck $,
124      * initial version un 27, 2015 <br>
125      * @author <a href="http://www.tbm.tudelft.nl/averbraeck">Alexander Verbraeck</a>
126      * @author <a href="http://www.tudelft.nl/pknoppers">Peter Knoppers</a>
127      */
128     class TestXMLModel implements OTSModelInterface
129     {
130         /** */
131         private static final long serialVersionUID = 20141121L;
132 
133         /** The simulator. */
134         private OTSDEVSSimulatorInterface simulator;
135 
136         /** {@inheritDoc} */
137         @Override
138         public final
139             void
140             constructModel(
141                 final SimulatorInterface<DoubleScalar.Abs<TimeUnit>, DoubleScalar.Rel<TimeUnit>, OTSSimTimeDouble> pSimulator)
142                 throws SimRuntimeException
143         {
144             this.simulator = (OTSDEVSSimulatorInterface) pSimulator;
145             //URL url = URLResource.getResource("/LMRSStraightTest.xml");
146             //URL url = URLResource.getResource("/LMRSLaneDropTest.xml");
147             URL url = URLResource.getResource("/LMRSOnRampTest.xml");
148             //URL url = URLResource.getResource("/LMRSOnRampTaperTest.xml");
149             //URL url = URLResource.getResource("/networkv2_90km_V5.xml");
150             XmlNetworkLaneParser nlp = new XmlNetworkLaneParser(this.simulator);
151             try
152             {
153                 nlp.build(url);
154             }
155             catch (NetworkException | ParserConfigurationException | SAXException | IOException | NamingException
156                 | GTUException | OTSGeometryException exception)
157             {
158                 exception.printStackTrace();
159             }
160         }
161 
162         /** {@inheritDoc} */
163         @Override
164         public SimulatorInterface<DoubleScalar.Abs<TimeUnit>, DoubleScalar.Rel<TimeUnit>, OTSSimTimeDouble>
165             getSimulator()
166 
167         {
168             return this.simulator;
169         }
170 
171     }
172 
173 }