Apollo  6.0
Open source self driving car software
lidar_object_util.h
Go to the documentation of this file.
1 /******************************************************************************
2  * Copyright 2018 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 <memory>
19 
21 
22 namespace apollo {
23 namespace perception {
24 namespace lidar {
25 
26 // @brief: get bounding box vertices and save in polygon type
27 // @param [in]: object
28 // @param [in]: expand valud, in meter
29 // @param [out]: bounding box vertices(4 in xy plane)
30 void GetBoundingBox2d(const std::shared_ptr<base::Object>& object,
31  base::PointCloud<base::PointD>* box, double expand = 0.0);
32 
33 // @brief: compute object shape(center, size) from given direction and polygon
34 // @param [in/out]: input object, center and size will be updated
35 // @param [in]: whether use world cloud or local cloud
36 void ComputeObjectShapeFromPolygon(std::shared_ptr<base::Object> object,
37  bool use_world_cloud = false);
38 
39 } // namespace lidar
40 } // namespace perception
41 } // namespace apollo
PlanningContext is the runtime context in planning. It is persistent across multiple frames...
Definition: atomic_hash_map.h:25
void GetBoundingBox2d(const std::shared_ptr< base::Object > &object, base::PointCloud< base::PointD > *box, double expand=0.0)
void ComputeObjectShapeFromPolygon(std::shared_ptr< base::Object > object, bool use_world_cloud=false)