Apollo  6.0
Open source self driving car software
base_map_node_index.h
Go to the documentation of this file.
1 /******************************************************************************
2  * Copyright 2019 The Apollo Authors. All Rights Reserved.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *****************************************************************************/
16 #pragma once
17 
18 #include <iostream>
19 #include <string>
20 
23 
24 namespace apollo {
25 namespace localization {
26 namespace msf {
27 namespace pyramid_map {
28 
29 class MapNodeIndex;
30 
31 std::ostream& operator<<(std::ostream& cout, const MapNodeIndex& index);
32 
33 class MapNodeIndex {
34  public:
36  MapNodeIndex();
38  bool operator<(const MapNodeIndex& index) const;
40  bool operator==(const MapNodeIndex& index) const;
42  bool operator!=(const MapNodeIndex& index) const;
43  std::string ToString() const;
44 
47  static MapNodeIndex GetMapNodeIndex(const BaseMapConfig& option,
48  const Eigen::Vector3d& coordinate,
49  unsigned int resolution_id, int zone_id);
50  static MapNodeIndex GetMapNodeIndex(const BaseMapConfig& option,
51  const Eigen::Vector2d& coordinate,
52  unsigned int resolution_id, int zone_id);
53 
56  static unsigned int GetMapIndexRangeEast(const BaseMapConfig& option,
57  unsigned int resolution_id);
60  static unsigned int GetMapIndexRangeNorth(const BaseMapConfig& option,
61  unsigned int resolution_id);
62 
63  friend std::ostream& operator<<(std::ostream& cout,
64  const MapNodeIndex& index);
65 
68  unsigned int resolution_id_ = 0;
71  int zone_id_ = 10;
73  unsigned int m_ = 0;
75  unsigned int n_ = 0;
76 };
77 
78 } // namespace pyramid_map
79 } // namespace msf
80 } // namespace localization
81 } // namespace apollo
bool operator!=(const MapNodeIndex &index) const
Overload the unequal operator.
PlanningContext is the runtime context in planning. It is persistent across multiple frames...
Definition: atomic_hash_map.h:25
Eigen::Vector2d Vector2d
Definition: base_map_fwd.h:36
Eigen::Vector3d Vector3d
Definition: frame_transform.h:27
static unsigned int GetMapIndexRangeEast(const BaseMapConfig &option, unsigned int resolution_id)
Get the index range (maximum possible index + 1) in the east direction.
static unsigned int GetMapIndexRangeNorth(const BaseMapConfig &option, unsigned int resolution_id)
Get the index range (maximum possible index + 1) in the north direction.
bool operator<(const MapNodeIndex &index) const
Overload the less than operator.
unsigned int n_
The map node ID at the easting direction.
Definition: base_map_node_index.h:75
unsigned int resolution_id_
The ID of the resolution. Should be less than BaseMapConfig::_map_resolutions.size().
Definition: base_map_node_index.h:68
std::ostream & operator<<(std::ostream &cout, const MapNodeIndex &index)
apollo::localization::msf::pyramid_map::MapNodeIndex MapNodeIndex
Definition: lidar_locator_ndt.h:72
int zone_id_
The zone ID. 1 - 60 and -1 - -60. The positive value is the zone at the north hemisphere.
Definition: base_map_node_index.h:71
static MapNodeIndex GetMapNodeIndex(const BaseMapConfig &option, const Eigen::Vector3d &coordinate, unsigned int resolution_id, int zone_id)
Construct a map node index, given a global coordinate, eigen version.
friend std::ostream & operator<<(std::ostream &cout, const MapNodeIndex &index)
The options of the reflectance map.
Definition: base_map_config.h:42
unsigned int m_
The map node ID at the northing direction.
Definition: base_map_node_index.h:73
bool operator==(const MapNodeIndex &index) const
Overload the equal operator.
Definition: base_map_node_index.h:33