1#include <vanetza/common/position_fix.hpp>
2#include <vanetza/asn1/security/Latitude.h>
3#include <vanetza/asn1/security/Longitude.h>
4#include <vanetza/asn1/security/TwoDLocation.h>
5#include <vanetza/security/v3/distance.hpp>
6#include <boost/units/cmath.hpp>
15units::Length distance(
const PositionFix& one,
const asn1::TwoDLocation& other)
17 static const auto earth_radius = 6371000.0 * units::si::meter;
18 const auto other_lat = convert_latitude(other.latitude);
19 const auto other_lon = convert_longitude(other.longitude);
20 const units::Angle delta_phi { one.latitude - other_lat };
21 const units::Angle delta_lambda { one.longitude - other_lon };
22 const auto sin_delta_phi = sin(delta_phi / 2.0);
23 const auto sin_delta_lambda = sin(delta_lambda / 2.0);
24 const auto a = sin_delta_phi * sin_delta_phi +
25 cos(one.latitude) * cos(other_lat) * sin_delta_lambda * sin_delta_lambda;
26 const auto c = 2.0 * atan2(sqrt(a), sqrt(1 - a));
27 return earth_radius * c;
30units::GeoAngle convert_latitude(
const asn1::Latitude& in)
32 if (in >= Vanetza_Security_NinetyDegreeInt_min && in <= Vanetza_Security_NinetyDegreeInt_max) {
33 return in * 90.0 / Vanetza_Security_NinetyDegreeInt_max * units::degree;
35 return units::GeoAngle::from_value(std::numeric_limits<double>::quiet_NaN());
39units::GeoAngle convert_longitude(
const asn1::Longitude& in)
41 if (in >= Vanetza_Security_OneEightyDegreeInt_min && in <= Vanetza_Security_OneEightyDegreeInt_max) {
42 return in * 180.0 / Vanetza_Security_OneEightyDegreeInt_max * units::degree;
44 return units::GeoAngle::from_value(std::numeric_limits<double>::quiet_NaN());