Class HeadwayDistance
java.lang.Object
org.opentrafficsim.road.gtu.lane.perception.headway.HeadwayDistance
- All Implemented Interfaces:
java.io.Serializable
,java.lang.Comparable<Headway>
,Identifiable
,PerceivedObject
,Headway
public class HeadwayDistance extends java.lang.Object implements Headway
Container for a reference to information about a headway with just a distance, without any further information about the
object; it assumes a speed of 0 at the headway, so it also good to store information about a lane drop. The reason for
storing a speed of zero at the end of a maximum headway is that we did not check the conditions beyond that point. A GTU or
lane drop could be right behind the last point we checked.
Copyright (c) 2013-2019 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved.
BSD-style license. See OpenTrafficSim License.
- Version:
- $Revision: 1368 $, $LastChangedDate: 2015-09-02 00:20:20 +0200 (Wed, 02 Sep 2015) $, by $Author: averbraeck $,
initial version 11 feb. 2015
- Author:
- Alexander Verbraeck, Peter Knoppers
- See Also:
- Serialized Form
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.opentrafficsim.road.gtu.lane.perception.headway.Headway
Headway.ObjectType
-
Constructor Summary
Constructors Constructor Description HeadwayDistance(double distance)
Construct a new Headway information object with just a distance, without any further information about the object; it assumes a speed of 0 at the headway, so it also good to store information about a lane drop.HeadwayDistance(Length distance)
Construct a new Headway information object with just a distance, without any further information about the object; it assumes a speed of 0 at the headway, so it also good to store information about a lane drop. -
Method Summary
Modifier and Type Method Description Acceleration
getAcceleration()
Length
getDistance()
Retrieve the strongly typed distance to the other object.java.lang.String
getId()
Length
getLength()
Headway.ObjectType
getObjectType()
Length
getOverlap()
Return the (perceived) overlap with the other object.Length
getOverlapFront()
Return the (perceived) front overlap to the other object.Length
getOverlapRear()
Return the (perceived) rear overlap to the other object.Speed
getSpeed()
boolean
isAhead()
boolean
isBehind()
boolean
isParallel()
java.lang.String
toString()
-
Constructor Details
-
HeadwayDistance
public HeadwayDistance(double distance)Construct a new Headway information object with just a distance, without any further information about the object; it assumes a speed of 0 at the headway, so it also good to store information about a lane drop.- Parameters:
distance
- double; the distance that needs to be stored.
-
HeadwayDistance
Construct a new Headway information object with just a distance, without any further information about the object; it assumes a speed of 0 at the headway, so it also good to store information about a lane drop.- Parameters:
distance
- Length; the distance that needs to be stored.
-
-
Method Details
-
getId
public final java.lang.String getId()- Specified by:
getId
in interfaceHeadway
- Specified by:
getId
in interfaceIdentifiable
- Returns:
- String; the id of the other object for comparison purposes, cannot be null.
-
getLength
-
getSpeed
-
getDistance
Retrieve the strongly typed distance to the other object.- Specified by:
getDistance
in interfaceHeadway
- Returns:
- Length; the distance to the object, return value null indicates that the other object is parallel to the reference object
-
getObjectType
- Specified by:
getObjectType
in interfaceHeadway
- Returns:
- Length; the (perceived) object Type, can be null if no object type unknown.
-
getAcceleration
- Specified by:
getAcceleration
in interfaceHeadway
- Returns:
- Acceleration; acceleration the (perceived) acceleration of the other object; can be null if unknown.
-
getOverlapFront
Return the (perceived) front overlap to the other object. This value should be null if there is no overlap. In the figure for two GTUs below, it is distance c, positive for GTU1, negative for GTU2.---------- | GTU 1 | -----> ---------- --------------- | GTU 2 | -----> --------------- | a | b | c |
- Specified by:
getOverlapFront
in interfaceHeadway
- Returns:
- Length; the (perceived) front overlap to the other object or null if there is no overlap.
-
getOverlapRear
Return the (perceived) rear overlap to the other object. This value should be null if there is no overlap.In the figure below for two GTUs, it is distance a, positive for GTU1, negative for GTU2.---------- | GTU 1 | -----> ---------- --------------- | GTU 2 | -----> --------------- | a | b | c |
- Specified by:
getOverlapRear
in interfaceHeadway
- Returns:
- Length; the (perceived) rear overlap to the other object or null if there is no overlap.
-
getOverlap
Return the (perceived) overlap with the other object. This value should be null if there is no overlap. In the figure below for two GTUs, it is distance b, positive for GTU1 and GTU2.---------- | GTU 1 | -----> ---------- --------------- | GTU 2 | -----> --------------- | a | b | c |
- Specified by:
getOverlap
in interfaceHeadway
- Returns:
- Length, the (perceived) overlap with the other object or null if there is no overlap.
-
isAhead
public final boolean isAhead() -
isBehind
public final boolean isBehind() -
isParallel
public final boolean isParallel()- Specified by:
isParallel
in interfaceHeadway
- Returns:
- whether the other object is parallel the reference object.
-
toString
public final java.lang.String toString()- Overrides:
toString
in classjava.lang.Object
-