Apollo  6.0
Open source self driving car software
turn_rpt_230.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 
17 #pragma once
18 
19 #include "modules/canbus/proto/chassis_detail.pb.h"
21 
22 namespace apollo {
23 namespace canbus {
24 namespace lexus {
25 
27  ::apollo::canbus::ChassisDetail> {
28  public:
29  static const int32_t ID;
30  Turnrpt230();
31  void Parse(const std::uint8_t* bytes, int32_t length,
32  ChassisDetail* chassis) const override;
33 
34  private:
35  // config detail: {'name': 'VEHICLE_FAULT', 'offset': 0.0, 'precision': 1.0,
36  // 'len': 1, 'is_signed_var': False, 'physical_range': '[0|1]', 'bit': 6,
37  // 'type': 'bool', 'order': 'motorola', 'physical_unit': ''}
38  bool vehicle_fault(const std::uint8_t* bytes, const int32_t length) const;
39 
40  // config detail: {'name': 'PACMOD_FAULT', 'offset': 0.0, 'precision': 1.0,
41  // 'len': 1, 'is_signed_var': False, 'physical_range': '[0|1]', 'bit': 5,
42  // 'type': 'bool', 'order': 'motorola', 'physical_unit': ''}
43  bool pacmod_fault(const std::uint8_t* bytes, const int32_t length) const;
44 
45  // config detail: {'name': 'OVERRIDE_ACTIVE', 'offset': 0.0, 'precision': 1.0,
46  // 'len': 1, 'is_signed_var': False, 'physical_range': '[0|1]', 'bit': 1,
47  // 'type': 'bool', 'order': 'motorola', 'physical_unit': ''}
48  bool override_active(const std::uint8_t* bytes, const int32_t length) const;
49 
50  // config detail: {'name': 'OUTPUT_REPORTED_FAULT', 'offset': 0.0,
51  // 'precision': 1.0, 'len': 1, 'is_signed_var': False, 'physical_range':
52  // '[0|1]', 'bit': 4, 'type': 'bool', 'order': 'motorola', 'physical_unit':
53  // ''}
54  bool output_reported_fault(const std::uint8_t* bytes,
55  const int32_t length) const;
56 
57  // config detail: {'name': 'INPUT_OUTPUT_FAULT', 'offset': 0.0,
58  // 'precision': 1.0, 'len': 1, 'is_signed_var': False, 'physical_range':
59  // '[0|1]', 'bit': 3, 'type': 'bool', 'order': 'motorola', 'physical_unit':
60  // ''}
61  bool input_output_fault(const std::uint8_t* bytes,
62  const int32_t length) const;
63 
64  // config detail: {'name': 'ENABLED', 'offset': 0.0, 'precision': 1.0, 'len':
65  // 1, 'is_signed_var': False, 'physical_range': '[0|1]', 'bit': 0, 'type':
66  // 'bool', 'order': 'motorola', 'physical_unit': ''}
67  bool enabled(const std::uint8_t* bytes, const int32_t length) const;
68 
69  // config detail: {'name': 'COMMAND_OUTPUT_FAULT', 'offset': 0.0,
70  // 'precision': 1.0, 'len': 1, 'is_signed_var': False, 'physical_range':
71  // '[0|1]', 'bit': 2, 'type': 'bool', 'order': 'motorola', 'physical_unit':
72  // ''}
73  bool command_output_fault(const std::uint8_t* bytes,
74  const int32_t length) const;
75 
76  // config detail: {'name': 'MANUAL_INPUT', 'enum': {0: 'MANUAL_INPUT_RIGHT',
77  // 1: 'MANUAL_INPUT_NONE', 2: 'MANUAL_INPUT_LEFT', 3: 'MANUAL_INPUT_HAZARD'},
78  // 'precision': 1.0, 'len': 8, 'is_signed_var': False, 'offset': 0.0,
79  // 'physical_range': '[0|3]', 'bit': 15, 'type': 'enum', 'order': 'motorola',
80  // 'physical_unit': ''}
81  Turn_rpt_230::Manual_inputType manual_input(const std::uint8_t* bytes,
82  const int32_t length) const;
83 
84  // config detail: {'name': 'COMMANDED_VALUE', 'enum': {0:
85  // 'COMMANDED_VALUE_RIGHT', 1: 'COMMANDED_VALUE_NONE', 2:
86  // 'COMMANDED_VALUE_LEFT', 3: 'COMMANDED_VALUE_HAZARD'}, 'precision': 1.0,
87  // 'len': 8, 'is_signed_var': False, 'offset': 0.0, 'physical_range': '[0|3]',
88  // 'bit': 23, 'type': 'enum', 'order': 'motorola', 'physical_unit': ''}
89  Turn_rpt_230::Commanded_valueType commanded_value(const std::uint8_t* bytes,
90  const int32_t length) const;
91 
92  // config detail: {'name': 'OUTPUT_VALUE', 'enum': {0: 'OUTPUT_VALUE_RIGHT',
93  // 1: 'OUTPUT_VALUE_NONE', 2: 'OUTPUT_VALUE_LEFT', 3: 'OUTPUT_VALUE_HAZARD'},
94  // 'precision': 1.0, 'len': 8, 'is_signed_var': False, 'offset': 0.0,
95  // 'physical_range': '[0|3]', 'bit': 31, 'type': 'enum', 'order': 'motorola',
96  // 'physical_unit': ''}
97  Turn_rpt_230::Output_valueType output_value(const std::uint8_t* bytes,
98  const int32_t length) const;
99 };
100 
101 } // namespace lexus
102 } // namespace canbus
103 } // namespace apollo
Definition: turn_rpt_230.h:26
void Parse(const std::uint8_t *bytes, int32_t length, ChassisDetail *chassis) const override
PlanningContext is the runtime context in planning. It is persistent across multiple frames...
Definition: atomic_hash_map.h:25
This is the base class of protocol data.
Definition: protocol_data.h:44
The class of ProtocolData.
static const int32_t ID
Definition: turn_rpt_230.h:29