Auterion App SDK
Auterion SDK is a library that can be used by AuterionOS apps to communicate with the system.
geodesic.hpp
1 /****************************************************************************
2  *
3  * Copyright 2024 Auterion AG. All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * 1. Redistributions of source code must retain the above copyright notice, this
9  * list of conditions and the following disclaimer.
10  *
11  * 2. Redistributions in binary form must reproduce the above copyright notice,
12  * this list of conditions and the following disclaimer in the documentation
13  * and/or other materials provided with the distribution.
14  *
15  * 3. Neither the name of the copyright holder nor the names of its contributors
16  * may be used to endorse or promote products derived from this software without
17  * specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29  * POSSIBILITY OF SUCH DAMAGE.
30  *
31  ****************************************************************************/
32 
33 #pragma once
34 
35 #include <Eigen/Eigen>
36 #include <auterion_sdk/auterion.hpp>
37 #include <memory>
38 
39 namespace auterion {
44 class MapProjectionImpl;
45 
55  public:
56  explicit MapProjection(SDK& sdk);
57 
58  ~MapProjection();
59 
63  bool isInitialized() const;
64 
72  Eigen::Vector2f globalToLocal(const Eigen::Vector2d& global_position) const;
73 
81  Eigen::Vector3f globalToLocal(const Eigen::Vector3d& global_position) const;
82 
90  Eigen::Vector2d localToGlobal(const Eigen::Vector2f& local_position_en) const;
91 
99  Eigen::Vector3d localToGlobal(const Eigen::Vector3f& local_position_enu) const;
100 
101  private:
102  std::unique_ptr<MapProjectionImpl> _impl;
103 };
104 
112 float horizontalDistanceToGlobalPosition(const Eigen::Vector2d& global_position_now,
113  const Eigen::Vector2d& global_position_next);
114 
122 float horizontalDistanceToGlobalPosition(const Eigen::Vector3d& global_position_now,
123  const Eigen::Vector3d& global_position_next);
124 
132 float distanceToGlobalPosition(const Eigen::Vector3d& global_position_now,
133  const Eigen::Vector3d& global_position_next);
134 
142 float headingToGlobalPosition(const Eigen::Vector2d& global_position_now,
143  const Eigen::Vector2d& global_position_next);
144 
152 float headingToGlobalPosition(const Eigen::Vector3d& global_position_now,
153  const Eigen::Vector3d& global_position_next);
154 
162 Eigen::Vector2f vectorToGlobalPosition(const Eigen::Vector2d& global_position_now,
163  const Eigen::Vector2d& global_position_next);
164 
172 Eigen::Vector3f vectorToGlobalPosition(const Eigen::Vector3d& global_position_now,
173  const Eigen::Vector3d& global_position_next);
174 
184 Eigen::Vector2d globalPositionFromLineAndDist(const Eigen::Vector2d& global_position_line_start,
185  const Eigen::Vector2d& global_position_line_end,
186  float dist_from_start);
187 
197 Eigen::Vector2d globalPositionFromHeadingAndDist(const Eigen::Vector2d& global_position_now,
198  float heading, float dist);
199 
209 Eigen::Vector3d globalPositionFromHeadingAndDist(const Eigen::Vector3d& global_position_now,
210  float heading, float dist);
211 
220 Eigen::Vector2d addVectorToGlobalPosition(const Eigen::Vector2d& global_position,
221  const Eigen::Vector2f& vector_enu);
222 
231 Eigen::Vector3d addVectorToGlobalPosition(const Eigen::Vector3d& global_position,
232  const Eigen::Vector3f& vector_enu);
233 
235 } // namespace auterion
Provides methods to convert between the geographical coordinate system ("global") and the ENU local a...
Definition: geodesic.hpp:54
Eigen::Vector2d localToGlobal(const Eigen::Vector2f &local_position_en) const
Transform a point in the local azimuthal equidistant plane to the geographic coordinate system using ...
Eigen::Vector3f globalToLocal(const Eigen::Vector3d &global_position) const
Transform a point in the geographic coordinate system to the local azimuthal equidistant plane using ...
Eigen::Vector3d localToGlobal(const Eigen::Vector3f &local_position_enu) const
Transform a point in the local azimuthal equidistant plane to the geographic coordinate system using ...
bool isInitialized() const
Eigen::Vector2f globalToLocal(const Eigen::Vector2d &global_position) const
Transform a point in the geographic coordinate system to the local azimuthal equidistant plane using ...
SDK execution class. All callbacks are called on the same thread.
Definition: auterion.hpp:45