Vanetza
Loading...
Searching...
No Matches
distance.cpp
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>
7
8namespace vanetza
9{
10namespace security
11{
12namespace v3
13{
14
15units::Length distance(const PositionFix& one, const asn1::TwoDLocation& other)
16{
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;
28}
29
30units::GeoAngle convert_latitude(const asn1::Latitude& in)
31{
32 if (in >= Vanetza_Security_NinetyDegreeInt_min && in <= Vanetza_Security_NinetyDegreeInt_max) {
33 return in * 90.0 / Vanetza_Security_NinetyDegreeInt_max * units::degree;
34 } else {
35 return units::GeoAngle::from_value(std::numeric_limits<double>::quiet_NaN());
36 }
37}
38
39units::GeoAngle convert_longitude(const asn1::Longitude& in)
40{
41 if (in >= Vanetza_Security_OneEightyDegreeInt_min && in <= Vanetza_Security_OneEightyDegreeInt_max) {
42 return in * 180.0 / Vanetza_Security_OneEightyDegreeInt_max * units::degree;
43 } else {
44 return units::GeoAngle::from_value(std::numeric_limits<double>::quiet_NaN());
45 }
46}
47
48} // namespace v3
49} // namespace security
50} // namespace vanetza