lomiri-location-service  ..
An aggregating location service providing positioning and geocoding capabilities to applications.
position.h
Go to the documentation of this file.
1 /*
2  * Copyright © 2012-2013 Canonical Ltd.
3  *
4  * This program is free software: you can redistribute it and/or modify it
5  * under the terms of the GNU Lesser General Public License version 3,
6  * as published by the Free Software Foundation.
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11  * GNU Lesser General Public License for more details.
12  *
13  * You should have received a copy of the GNU Lesser General Public License
14  * along with this program. If not, see <http://www.gnu.org/licenses/>.
15  *
16  * Authored by: Thomas Voß <thomas.voss@canonical.com>
17  */
18 #ifndef LOCATION_SERVICE_COM_LOMIRI_LOCATION_POSITION_H_
19 #define LOCATION_SERVICE_COM_LOMIRI_LOCATION_POSITION_H_
20 
24 
26 
27 #include <bitset>
28 #include <ostream>
29 
30 namespace com
31 {
32 namespace lomiri
33 {
34 namespace location
35 {
39 struct Position
40 {
41  struct Accuracy
42  {
45 
48  };
49 
50  Position() = default;
55 
56  bool operator==(const Position& rhs) const;
57  bool operator!=(const Position& rhs) const;
58 
63 };
64 
65 std::ostream& operator<<(std::ostream& out, const Position& position);
66 
67 units::Quantity<units::Length> haversine_distance(const Position& p1, const Position& p2);
68 }
69 }
70 }
71 #endif // LOCATION_SERVICE_COM_LOMIRI_LOCATION_POSITION_H_
com::lomiri::location::Position::operator!=
bool operator!=(const Position &rhs) const
com::lomiri::location::Position::altitude
Optional< wgs84::Altitude > altitude
Definition: position.h:61
optional.h
com::lomiri::location::Optional
boost::optional< T > Optional
Definition: optional.h:31
com::lomiri::location::haversine_distance
units::Quantity< units::Length > haversine_distance(const Position &p1, const Position &p2)
com::lomiri::location::wgs84::Longitude
Coordinate< tag::Longitude, units::PlaneAngle > Longitude
Definition: longitude.h:38
com::lomiri::location::wgs84::Latitude
Coordinate< tag::Latitude, units::PlaneAngle > Latitude
Definition: latitude.h:38
com::lomiri::location::Position::Accuracy::horizontal
Optional< Horizontal > horizontal
Definition: position.h:46
com::lomiri::location::Position
The Position struct models a position in the wgs84 coordinate system.
Definition: position.h:39
com::lomiri::location::Position::longitude
wgs84::Longitude longitude
Definition: position.h:60
com::lomiri::location::units::Quantity
boost::units::quantity< Unit, double > Quantity
Definition: units.h:60
com::lomiri::location::operator<<
std::ostream & operator<<(std::ostream &out, const Accuracy< T > &update)
Definition: accuracy.h:68
com::lomiri::location::Position::latitude
wgs84::Latitude latitude
Definition: position.h:59
longitude.h
com::lomiri::location::wgs84::Coordinate
Definition: coordinate.h:42
com::lomiri::location::Position::operator==
bool operator==(const Position &rhs) const
altitude.h
com::lomiri::location::Position::Position
Position()=default
com
Definition: accuracy.h:23
com::lomiri::location::Position::Accuracy::Horizontal
units::Quantity< units::Length > Horizontal
Definition: position.h:43
latitude.h
com::lomiri::location::Position::Accuracy::Vertical
units::Quantity< units::Length > Vertical
Definition: position.h:44
com::lomiri::location::Position::Accuracy::vertical
Optional< Vertical > vertical
Definition: position.h:47
com::lomiri::location::Position::accuracy
Accuracy accuracy
Definition: position.h:62
com::lomiri::location::Position::Accuracy
Definition: position.h:41