Apollo  6.0
Open source self driving car software
base_lane_detector.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 #include <string>
20 
25 
26 namespace apollo {
27 namespace perception {
28 namespace camera {
29 
31  std::shared_ptr<base::BaseCameraModel> base_camera_model = nullptr;
32  int gpu_id = 0;
33 };
34 
36 
38  public:
39  BaseLaneDetector() = default;
40 
41  virtual ~BaseLaneDetector() = default;
42 
43  virtual bool Init(
44  const LaneDetectorInitOptions& options = LaneDetectorInitOptions()) = 0;
45 
46  // @brief: detect lane from image.
47  // @param [in]: options
48  // @param [in/out]: frame
49  // detected lanes should be filled, required,
50  // 3D information of lane can be filled, optional.
51  virtual bool Detect(const LaneDetectorOptions& options,
52  CameraFrame* frame) = 0;
53 
54  virtual std::string Name() const = 0;
55 
56  BaseLaneDetector(const BaseLaneDetector&) = delete;
57  BaseLaneDetector& operator=(const BaseLaneDetector&) = delete;
58 }; // class BaseLaneDetector
59 
61 #define REGISTER_LANE_DETECTOR(name) \
62  PERCEPTION_REGISTER_CLASS(BaseLaneDetector, name)
63 
64 } // namespace camera
65 } // namespace perception
66 } // namespace apollo
PERCEPTION_REGISTER_REGISTERER(BaseCalibrationService)
Definition: base_init_options.h:24
Definition: camera_frame.h:33
PlanningContext is the runtime context in planning. It is persistent across multiple frames...
Definition: atomic_hash_map.h:25
std::shared_ptr< base::BaseCameraModel > base_camera_model
Definition: base_lane_detector.h:31
Definition: base_lane_detector.h:37
Definition: base_lane_detector.h:35
bool Init(const char *binary_name)
int gpu_id
Definition: base_lane_detector.h:32
Definition: base_lane_detector.h:30