Apollo  6.0
Open source self driving car software
gps_6d.h
Go to the documentation of this file.
1 /******************************************************************************
2  * Copyright 2017 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 
22 #pragma once
23 
24 #include "modules/canbus/proto/chassis_detail.pb.h"
26 
31 namespace apollo {
32 namespace canbus {
33 namespace lincoln {
34 
41  ::apollo::canbus::ChassisDetail> {
42  public:
43  static const int32_t ID;
44 
45  /*
46  * @brief parse received data
47  * @param bytes a pointer to the input bytes
48  * @param length the length of the input bytes
49  * @param timestamp the timestamp of input data
50  * @param chassis_detail the parsed chassis_detail
51  */
52  virtual void Parse(const std::uint8_t *bytes, int32_t length,
53  ChassisDetail *chassis_detail) const;
54 
65  double latitude(const std::uint8_t *bytes, int32_t length) const;
66 
77  double longitude(const std::uint8_t *bytes, int32_t length) const;
78 
88  bool is_valid(const std::uint8_t *bytes, int32_t length) const;
89 };
90 
91 } // namespace lincoln
92 } // namespace canbus
93 } // namespace apollo
PlanningContext is the runtime context in planning. It is persistent across multiple frames...
Definition: atomic_hash_map.h:25
double latitude(const std::uint8_t *bytes, int32_t length) const
get latitude from byte array config detail: {'name': 'latitude', 'offset': 0.0, 'precision': 3...
This is the base class of protocol data.
Definition: protocol_data.h:44
double longitude(const std::uint8_t *bytes, int32_t length) const
get longitude from byte array config detail: {'name': 'longitude', 'offset': 0.0, 'precision': 3...
bool is_valid(const std::uint8_t *bytes, int32_t length) const
check is_valid from byte array config detail: {'name': 'valid', 'offset': 0.0, 'precision': 1...
one of the protocol data of lincoln vehicle
Definition: gps_6d.h:40
static const int32_t ID
Definition: gps_6d.h:43
The class of ProtocolData.
virtual void Parse(const std::uint8_t *bytes, int32_t length, ChassisDetail *chassis_detail) const