1   package org.opentrafficsim.kpi.sampling;
2   
3   import org.djunits.value.vdouble.scalar.Length;
4   import org.djunits.value.vdouble.scalar.Time;
5   import org.djutils.exceptions.Throw;
6   import org.opentrafficsim.kpi.interfaces.LaneData;
7   
8   /**
9    * Defines a rectangular region over space and time on a lane.
10   * <p>
11   * Copyright (c) 2013-2024 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
12   * BSD-style license. See <a href="https://opentrafficsim.org/docs/license.html">OpenTrafficSim License</a>.
13   * </p>
14   * @author <a href="https://github.com/averbraeck">Alexander Verbraeck</a>
15   * @author <a href="https://github.com/peter-knoppers">Peter Knoppers</a>
16   * @author <a href="https://github.com/wjschakel">Wouter Schakel</a>
17   * @param <L> lane data type
18   * @param lane lane
19   * @param startPosition start position
20   * @param endPosition end position
21   * @param startTime start time
22   * @param endTime end time
23   */
24  public record SpaceTimeRegion<L extends LaneData<L>>(L lane, Length startPosition, Length endPosition, Time startTime,
25          Time endTime)
26  {
27  
28      /**
29       * Creates a space-time region.
30       * @param lane lane
31       * @param startPosition start position
32       * @param endPosition end position
33       * @param startTime start time
34       * @param endTime end time
35       * @throws IllegalArgumentException if start time is larger than end time
36       */
37      public SpaceTimeRegion
38      {
39          Throw.whenNull(startPosition, "Start position may not be null.");
40          Throw.whenNull(endPosition, "End position may not be null.");
41          Throw.whenNull(startTime, "Start time may not be null.");
42          Throw.whenNull(endTime, "End time may not be null.");
43          Throw.when(endPosition.lt(startPosition), IllegalArgumentException.class,
44                  "End position should be greater than start position.");
45          Throw.when(endTime.lt(startTime), IllegalArgumentException.class, "End time should be greater than start time.");
46      }
47  
48  }