DSRC-addgrp-C.asn 14.1 KB
Newer Older
Thomas Ritter's avatar
Thomas Ritter committed
/** draft 001 of the ETSI-ITS-DSRC-AddGrpC module for TS 103 301 V2.2.1 integrating:
* initial revision based on ASN.1 files of [ISO TS 19091] and [SAE J2735]
*/
-- Note: the above information will be deleted before publication

--! @options: no-fields-header

ritterth's avatar
ritterth committed
ETSI-ITS-DSRC-AddGrpC {
  itu-t (0) identified-organization (4) etsi (0) itsDomain (5) wg1 (1) ts103301 (103301) dsrc (6) addgrpc (0) major-version-2 (2) minor-version-1 (1)
ritterth's avatar
ritterth committed
}

DEFINITIONS AUTOMATIC TAGS::= BEGIN

IMPORTS

DeltaTime, FuelType, IntersectionID, LaneConnectionID, LaneID, NodeOffsetPointXY, NodeSetXY, PrioritizationResponseStatus, SignalGroupID, VehicleHeight
FROM ETSI-ITS-DSRC {
  itu-t (0) identified-organization (4) etsi (0) itsDomain (5) wg1 (1) ts103301 (103301) dsrc (6) major-version-2 (2) minor-version-1 (1)
ritterth's avatar
ritterth committed
}
WITH SUCCESSORS
ritterth's avatar
ritterth committed

Altitude, DeltaAltitude, StationID, VehicleMass
FROM ETSI-ITS-CDD {
  itu-t (0) identified-organization (4) etsi (0) itsDomain (5) wg1 (1) 102894 cdd (2) major-version-4 (4) minor-version-1 (1)
ritterth's avatar
ritterth committed
}
WITH SUCCESSORS;

ritterth's avatar
ritterth committed
/**
* This DF adds positioning support from the infrastructure to the vehicle.
ritterth's avatar
ritterth committed
*
* @field itsStationPositions: defines a list of ITS stations (e.g. vehicles) and their corresponding position on
*                             the driving lane as defined in the lane topology of the MapData message or the GNSS position
*                             deviation of the ITS Station from the high precision reference position in X/Y coordinates. It
*                             enables accurate, real-time positioning support to the moving ITS entities by the infrastructure.*
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
ConnectionManeuverAssist-addGrpC ::=	SEQUENCE {
  itsStationPosition ItsStationPositionList OPTIONAL,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DF defines the trajectory for travelling through the conflict area of an intersection and connects 
* e.g an ingress with an egress lane. The trajectory is defined by two or more nodes. 
* The starting node overlaps e.g. with the node of the ingress lane towards the
Thomas Ritter's avatar
Thomas Ritter committed
* conflict zone. The ending node overlaps e.g. with the first node of the connected egress lane. 
* See the example in clause [ISO TS 19091] G.8.2.5.
*
* @field nodes: defines a list of nodes for the trajectory. It defines e.g. a geometric trajectory from an ingressing
*               to a connected egressing lane and the X/Y position value of the first node of the trajectory is the same as
*               the node of the ingress lane. The X/Y position of the last node is the same as the X/Y position of the first
*               node of the egressing lane.
* @field connectionID: defines the identifier of an allowed `maneuver` (e.g. ingress / egress relation). 
*               A generic Lane offers one or more allowed `maneuvers`, therefore the trajectory is reference to the related `maneuver`.
Thomas Ritter's avatar
Thomas Ritter committed
*
* @note: @ref Reg-GenericLane allows providing up to 4 connecting trajectories. In case a lane has more than 4 connecting trajectories,
Thomas Ritter's avatar
Thomas Ritter committed
* priority should be given to connecting trajectories of motorized traffic and complex manoeuvres.
*
*
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
ConnectionTrajectory-addGrpC ::= SEQUENCE {
  nodes         NodeSetXY,
  connectionID  LaneConnectionID,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DF defines a list of prioritization responses e.g. public transport acceleration.
Thomas Ritter's avatar
Thomas Ritter committed
* The signal prioritization (e.g. public transport) procedure in this profile follows two strategies.
* - For simple prioritization requests, the CAM/SPAT messages are used. 
*   This allows the migration of old legal systems towards C-ITS.
Thomas Ritter's avatar
Thomas Ritter committed
*   In this case, the CAM message is used to trigger the request towards the traffic light controller. 
*   The traffic light controller checks the request and broadcasts the status for the priority request with this DF (see [ISO TS 19091] G.5.1.9).
Thomas Ritter's avatar
Thomas Ritter committed
* - For more complex signal requests, the SignalRequestMessage/SignalStatusMessage messages are to be used.
*
* @field activePrioritizations: list of Prioritizations.
*
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
IntersectionState-addGrpC ::=	SEQUENCE {
  activePrioritizations  PrioritizationResponseList	OPTIONAL,
  ...
}

ritterth's avatar
ritterth committed
/**
Thomas Ritter's avatar
Thomas Ritter committed
* Lanes may have limitations regarding vehicle height (e.g. due to a tunnel) and vehicle weight (e.g. due to a bridge). 
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @field maxVehicleHeight: maximum allowed vehicle height
* @field maxVehicleWeight: maximum allowed vehicle mass
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
LaneAttributes-addGrpC ::= SEQUENCE {
  maxVehicleHeight  VehicleHeight OPTIONAL,
  maxVehicleWeight  VehicleMass   OPTIONAL,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DF defines a list of three-dimensional positions of signal heads in an intersection. 
Thomas Ritter's avatar
Thomas Ritter committed
* It enables vehicles to identify the signal head location for optical evaluation of the traffic light. 
* Combined with the SPAT/MapData messages, it enables e.g. driving vehicles to enhance safety decision in critical situations.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @field signalHeadLocations: list of geo positions
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
MapData-addGrpC ::=	SEQUENCE {
  signalHeadLocations  SignalHeadLocationList	OPTIONAL,
  ...
}

ritterth's avatar
ritterth committed
/**
Thomas Ritter's avatar
Thomas Ritter committed
* Priority and preemption have a considerable impact to the timing parameters in the SPAT message (eventState).
* User acceptance is expected to increase if the reason for sudden changes in timing parameters is communicated to them.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @field stateChangeReason: reason code
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
MovementEvent-addGrpC ::= SEQUENCE {
  stateChangeReason  ExceptionalCondition OPTIONAL,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DF defines additional attributes to support public transport and to enable a simple way of defining lane links.
Thomas Ritter's avatar
Thomas Ritter committed
*
* @field ptvRequest: defines control types attached to a node on a lane used by public transport for triggering
*                    the transmission of messages (e.g. prioritization request). It includes control points for public transport prioritization. 
*                    These control points are currently implemented by legacy systems using hardware sensors mounted on the roadside.
* @field nodeLink:   defines a link to one or to a set of another node/lane from this node. The nodeLink allows to set a link between specific nodes 
*                    of generic lanes or trajectories. This supports e.g. lane merging/diverging situations ([ISO TS 19091] G.8.2.7) and the linking of trajectories 
*                    in the conflict zone to lanes (see example [ISO TS 19091] G.8.2.5).
* @field node:       defines an identifier of this node.
*
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
NodeAttributeSet-addGrpC  ::=	SEQUENCE {
  ptvRequest  PtvRequestType  OPTIONAL,
  nodeLink    NodeLink        OPTIONAL,
  node        Node            OPTIONAL,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DF includes the altitude data element defined in the common data dictionary [ETSI CDD].
ritterth's avatar
ritterth committed
*
* @field elevation: the data element is replaced by the ETSI `altitude` data element using the regional extension. 
*                   The `altitude` data element is defined in Position3D-addGrpC of this profile.
*                   Position3D-addGrpC extends the @ref Position3D using the regional extension framework.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
Position3D-addGrpC ::=	SEQUENCE {
  altitude  Altitude,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DF defines the driving restriction based on toxic emission type. 
* The meaning of the word `restriction` is ambiguous as it may have a double interpretation, being:
Thomas Ritter's avatar
Thomas Ritter committed
*  - only these vehicles are allowed OR 
*  - these vehicles are not allowed and all others are. 
* The former is what is intended by the base standard.
*
* @field emission: restriction baesed on emission.
* @field fuel: restriction baesed on fuel.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
RestrictionUserType-addGrpC ::=	SEQUENCE {
  emission  EmissionType OPTIONAL,
  fuel      FuelType     OPTIONAL,
  ...
}

ritterth's avatar
ritterth committed
/**
* Some road authorities like to give priority to vehicles based on the type of fuel they use. In addition,
Thomas Ritter's avatar
Thomas Ritter committed
* electric vehicles may receive priority based on their battery status.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @field fuel: fuel used by vehicle.
* @field batteryStatus: current batter status of vehicle.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
RequestorDescription-addGrpC ::= SEQUENCE {
  fuel           FuelType      OPTIONAL,
  batteryStatus  BatteryStatus OPTIONAL,
  ...
}

ritterth's avatar
ritterth committed
/**
Thomas Ritter's avatar
Thomas Ritter committed
* The traffic control centre (TCC) may advice a public transport vehicle (e.g. bus) to synchronize his travel time. 
* This may happen when, for example, two busses, due to special traffic conditions, are out of schedule. 
* The first might be too late, the second too fast. The consequence is that the second is driving
* just behind the first and is empty as all passengers are within the first one. To avoid this often-occurring
* situation, the TCC transmits time synchronization advices to the public transport vehicles using the
* signal status message. 
*
* @field synchToSchedule: DeltaTime.
* @field rejectedReason: RejectedReason.
*
* @Note: The @ref PrioritizationResponseStatus provides optionally the reason for prioritization response rejection.
Thomas Ritter's avatar
Thomas Ritter committed
*
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
SignalStatusPackage-addGrpC ::= SEQUENCE {
  synchToSchedule  DeltaTime      OPTIONAL,
  rejectedReason   RejectedReason OPTIONAL,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DF is used to provide real-time positioning information feedback to a specific ITS station 
* (e.g. vehicle, pedestrian, bicycle) by infrastructure equipment.
*  The position information includes, for example, the driving, crossing lane and/or the X/Y coordinates in relation to
* the reference position of the MapData. The `timeReference` indicates the time stamp of the the
ritterth's avatar
ritterth committed
* message (received from an ITS station) for which the positioning feedback has been computed.
Thomas Ritter's avatar
Thomas Ritter committed
* 
* @field stationID: unique identifier.
* @field laneID: LaneID.
* @field nodeXY: NodeOffsetPointXY.
* @field timeReference: TimeReference.
*
* @note: The computation of the positioning feedback is out of focus of this standard.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
ItsStationPosition ::=	SEQUENCE {
  stationID      StationID,
  laneID         LaneID             OPTIONAL,
  nodeXY         NodeOffsetPointXY  OPTIONAL,
  timeReference  TimeReference      OPTIONAL,
  ...
}

ItsStationPositionList ::=	SEQUENCE SIZE(1..5) OF ItsStationPosition

ritterth's avatar
ritterth committed
/**
* This DF is used to to identify a node of a lane (waypoint) by its `lane` and node identifier `id`. 
*
* The `intersectionID` is used if the referenced lane belongs to an adjacent intersection. If the node
* belongs to a connection trajectory ([ISO TS 19091] G.5.1.2) the `connectionID` is used.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @field id: unique identifier.
* @field lane: identifier from lane.
* @field connectionID: identifier from connection.
* @field intersectionID: identifier from intersection.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
Node ::= SEQUENCE {
  id              INTEGER,
  lane            LaneID           OPTIONAL,
  connectionID    LaneConnectionID OPTIONAL,
  intersectionID  IntersectionID   OPTIONAL,
  ...
}

NodeLink ::= SEQUENCE SIZE (1..5) OF Node

ritterth's avatar
ritterth committed
/**
* This DF is used to provide the prioritization status response and the
ritterth's avatar
ritterth committed
* signal group identifier for a specific ITS station (e.g. vehicle).
*
Thomas Ritter's avatar
Thomas Ritter committed
* @field stationID: StationID.
* @field priorState: PrioritizationResponseStatus.
* @field signalGroup: SignalGroupID.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
PrioritizationResponse ::=	SEQUENCE {
  stationID    StationID,
  priorState   PrioritizationResponseStatus,
  signalGroup  SignalGroupID,
  ...
}

PrioritizationResponseList ::=	SEQUENCE SIZE(1..10) OF PrioritizationResponse

ritterth's avatar
ritterth committed
/**
* This DF defines the XYZ position of a signal head within an intersection
ritterth's avatar
ritterth committed
* and indicates the related signal group identifier.
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
SignalHeadLocation ::=	SEQUENCE {
  nodeXY         NodeOffsetPointXY,
  nodeZ          DeltaAltitude,
  signalGroupID  SignalGroupID,
  ...
}

SignalHeadLocationList ::=	SEQUENCE (SIZE(1..64)) OF	SignalHeadLocation

ritterth's avatar
ritterth committed
/**
* This DE defines an enumerated list of battery states.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
BatteryStatus ::= ENUMERATED {
  unknown,
  critical,
  low,
  good,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DE defines an enumerated list of toxic emission types for vehicles.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
EmissionType ::= ENUMERATED {
  euro1,
  euro2,
  euro3,
  euro4,
  euro5,
  euro6,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DE defines a list of reasons for sudden changes in
ritterth's avatar
ritterth committed
* eventState parameters, thereby offering a reason for extended waiting times.
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
ExceptionalCondition ::= ENUMERATED {
  unknown,
  publicTransportPriority,
  emergencyVehiclePriority,
  trainPriority,
  bridgeOpen,
  vehicleHeight,
  weather,
  trafficJam,
  tunnelClosure,
  meteringActive,
  truckPriority,
  bicyclePlatoonPriority,
  vehiclePlatoonPriority,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DE defines a list of activation requests used for C-ITS migration of legacy public 
* transport prioritization systems. 
* The activation points are used while approaching to an intersection.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
PtvRequestType  ::= ENUMERATED {
  preRequest,
  mainRequest,
  doorCloseRequest,
  cancelRequest,
  emergencyRequest,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DE defines a list of reasons for rejected priority requests.
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
RejectedReason ::= ENUMERATED {
  unknown,
  exceptionalCondition,
  maxWaitingTimeExceeded,
  ptPriorityDisabled,
  higherPTPriorityGranted,
  vehicleTrackingUnknown,
  ...
}

ritterth's avatar
ritterth committed
/**
* This DE defines a value in milliseconds in the current minute related to UTC time. 
* The range of 60 000 covers one minute (60 seconds * 1 000 milliseconds)
ritterth's avatar
ritterth committed
*
Thomas Ritter's avatar
Thomas Ritter committed
* @category: Infrastructure information
ritterth's avatar
ritterth committed
* @revision: V1.3.1
*/
ritterth's avatar
ritterth committed
TimeReference ::= INTEGER { oneMilliSec(1) } (0..60000)

/** 
* ## References:
* 1. [ISO TS 19091]: "Intelligent transport systems - Cooperative ITS - Using V2I and I2V communications for applications related to signalized intersections".
* 2. [SAE J2735]: "SURFACE VEHICLE STANDARD - V2X Communications Message Set Dictionary"
*/

ritterth's avatar
ritterth committed
END