32#ifndef ETSI_ITS_MSGS_UTILS_IMPL_CDD_CDD_V2_1_1_SETTERS_H
33#define ETSI_ITS_MSGS_UTILS_IMPL_CDD_CDD_V2_1_1_SETTERS_H
37#include <GeographicLib/UTMUPS.hpp>
48inline void setItsPduHeader(ItsPduHeader& header,
const uint8_t message_id,
const uint32_t station_id,
49 const uint8_t protocol_version = 0) {
52 header.message_id.value = message_id;
53 throwIfOutOfRange(protocol_version, OrdinalNumber1B::MIN, OrdinalNumber1B::MAX,
"ProtocolVersion");
54 header.protocol_version.value = protocol_version;
64 int64_t accel_val = (int64_t)std::round(value * 1e1);
65 if (accel_val >= AccelerationValue::MIN && accel_val <= AccelerationValue::MAX) {
66 accel.value = accel_val;
67 }
else if (accel_val < AccelerationValue::MIN) {
68 accel.value = AccelerationValue::MIN;
69 }
else if (accel_val > AccelerationValue::MAX) {
70 accel.value = AccelerationValue::MAX - 1;
94 int64_t accel_val = (int64_t)std::round(value * 1e1);
95 if (accel_val >= AccelerationValue::MIN && accel_val <= AccelerationValue::MAX) {
96 accel.value = accel_val;
97 }
else if (accel_val < AccelerationValue::MIN) {
98 accel.value = AccelerationValue::MIN;
99 }
else if (accel_val > AccelerationValue::MAX) {
100 accel.value = AccelerationValue::MAX - 1;
125template <
typename PositionConf
idenceEllipse,
typename Wgs84AngleValue = decltype(PositionConf
idenceEllipse::semi_major_axis_orientation)>
127 const double semi_minor_axis,
const double orientation) {
128 setSemiAxis(position_confidence_ellipse.semi_major_axis_length, semi_major_axis);
129 setSemiAxis(position_confidence_ellipse.semi_minor_axis_length, semi_minor_axis);
130 setHeadingValue(position_confidence_ellipse.semi_major_axis_orientation, orientation);
142template <
typename PositionConf
idenceEllipse>
143inline void setPositionConfidenceEllipse(PositionConfidenceEllipse& position_confidence_ellipse,
const std::array<double, 4>& covariance_matrix,
const double object_heading){
157template <
typename PositionConf
idenceEllipse>
Common setter functions for the ETSI ITS Common Data Dictionary (CDD) v1.3.1, v2.1....
void setAccelerationConfidence(AccelerationConfidence &accel_confidence, const double value)
Set the Acceleration Confidence object.
void setStationId(StationId &station_id, const uint32_t id_value)
Set the Station Id object.
std::tuple< double, double, double > confidenceEllipseFromCovMatrix(const std::array< double, 4 > &covariance_matrix, const double object_heading)
Gets the values needed to set a confidence ellipse from a covariance matrix.
void setSemiAxis(SemiAxisLength &semi_axis_length, const double length)
Set the Semi Axis length.
void setHeadingValue(HeadingValue &heading, const double value)
Set the HeadingValue object.
std::tuple< double, double, double > confidenceEllipseFromWGSCovMatrix(const std::array< double, 4 > &covariance_matrix)
Gets the values needed to set a confidence ellipse from a covariance matrix.
void setLateralAccelerationValue(AccelerationValue &accel, const double value)
Set the LateralAccelerationValue object.
void setWGSPositionConfidenceEllipse(PositionConfidenceEllipse &position_confidence_ellipse, const std::array< double, 4 > &covariance_matrix)
Set the Position Confidence Ellipse object.
void setLateralAcceleration(AccelerationComponent &accel, const double value, const double confidence)
Set the LateralAcceleration object.
void setLongitudinalAcceleration(AccelerationComponent &accel, const double value, const double confidence)
Set the LongitudinalAcceleration object.
void setPositionConfidenceEllipse(PositionConfidenceEllipse &position_confidence_ellipse, const double semi_major_axis, const double semi_minor_axis, const double orientation)
Set the Position Confidence Ellipse object.
void setLongitudinalAccelerationValue(AccelerationValue &accel, const double value)
Set the LongitudinalAccelerationValue object.
void setItsPduHeader(ItsPduHeader &header, const uint8_t message_id, const uint32_t station_id, const uint8_t protocol_version=0)
Set the Its Pdu Header object.
Sanity-check functions etc.
void throwIfOutOfRange(const T1 &val, const T2 &min, const T2 &max, const std::string val_desc)
Throws an exception if a given value is out of a defined range.