blob: a35798f7e87e27c667e388d96be73c0876df3e2f [file] [log] [blame]
Stephan Massaltd021f972020-01-05 20:41:23 -08001#include "y2020/constants.h"
2
3#include <inttypes.h>
4
5#include <map>
6
7#if __has_feature(address_sanitizer)
8#include "sanitizer/lsan_interface.h"
9#endif
10
11#include "absl/base/call_once.h"
12#include "aos/logging/logging.h"
13#include "aos/mutex/mutex.h"
14#include "aos/network/team_number.h"
ravago901c4262020-02-16 15:33:14 -080015#include "y2020/control_loops/superstructure/control_panel/integral_control_panel_plant.h"
Sabina Davisa587fbd2020-01-31 22:11:15 -080016#include "y2020/control_loops/superstructure/hood/integral_hood_plant.h"
Kai Tinkess10943cf2020-02-01 15:49:57 -080017#include "y2020/control_loops/superstructure/intake/integral_intake_plant.h"
18#include "y2020/control_loops/superstructure/turret/integral_turret_plant.h"
Sabina Davisa587fbd2020-01-31 22:11:15 -080019
Stephan Massaltd021f972020-01-05 20:41:23 -080020namespace y2020 {
21namespace constants {
22
23const int Values::kZeroingSampleSize;
24
25namespace {
26
27const uint16_t kCompTeamNumber = 971;
28const uint16_t kPracticeTeamNumber = 9971;
29const uint16_t kCodingRobotTeamNumber = 7971;
30
31const Values *DoGetValuesForTeam(uint16_t team) {
32 Values *const r = new Values();
Sabina Davisa587fbd2020-01-31 22:11:15 -080033 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
34 ::frc971::zeroing::AbsoluteEncoderZeroingEstimator> *const hood =
35 &r->hood;
36
37 // Hood constants.
38 hood->zeroing_voltage = 3.0;
39 hood->operating_voltage = 12.0;
40 hood->zeroing_profile_params = {0.5, 3.0};
41 hood->default_profile_params = {6.0, 30.0};
42 hood->range = Values::kHoodRange();
43 hood->make_integral_loop =
44 control_loops::superstructure::hood::MakeIntegralHoodLoop;
45 hood->zeroing_constants.average_filter_size = Values::kZeroingSampleSize;
46 hood->zeroing_constants.one_revolution_distance =
47 M_PI * 2.0 * constants::Values::kHoodEncoderRatio();
48 hood->zeroing_constants.zeroing_threshold = 0.0005;
49 hood->zeroing_constants.moving_buffer_size = 20;
50 hood->zeroing_constants.allowable_encoder_error = 0.9;
51 hood->zeroing_constants.middle_position = Values::kHoodRange().middle();
Stephan Massaltd021f972020-01-05 20:41:23 -080052
Sabina Davise8d38992020-02-02 15:00:31 -080053 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
54 ::frc971::zeroing::AbsoluteEncoderZeroingEstimator> *const intake =
55 &r->intake;
56
57 // Intake constants.
58 intake->zeroing_voltage = 3.0;
59 intake->operating_voltage = 12.0;
60 intake->zeroing_profile_params = {0.5, 3.0};
61 intake->default_profile_params = {6.0, 30.0};
62 intake->range = Values::kIntakeRange();
63 intake->make_integral_loop =
64 control_loops::superstructure::intake::MakeIntegralIntakeLoop;
65 intake->zeroing_constants.average_filter_size = Values::kZeroingSampleSize;
66 intake->zeroing_constants.one_revolution_distance =
67 M_PI * 2.0 * constants::Values::kIntakeEncoderRatio();
68 intake->zeroing_constants.zeroing_threshold = 0.0005;
69 intake->zeroing_constants.moving_buffer_size = 20;
70 intake->zeroing_constants.allowable_encoder_error = 0.9;
71 intake->zeroing_constants.middle_position = Values::kIntakeRange().middle();
72
Kai Tinkess10943cf2020-02-01 15:49:57 -080073 Values::PotAndAbsEncoderConstants *const turret = &r->turret;
74 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
75 ::frc971::zeroing::PotAndAbsoluteEncoderZeroingEstimator>
76 *const turret_params = &turret->subsystem_params;
77
ravago901c4262020-02-16 15:33:14 -080078 // Turret Constants
Kai Tinkess10943cf2020-02-01 15:49:57 -080079 turret_params->zeroing_voltage = 4.0;
80 turret_params->operating_voltage = 12.0;
81 // TODO(austin): Tune these.
82 turret_params->zeroing_profile_params = {0.5, 2.0};
83 turret_params->default_profile_params = {15.0, 40.0};
84 turret_params->range = Values::kTurretRange();
85 turret_params->make_integral_loop =
86 &control_loops::superstructure::turret::MakeIntegralTurretLoop;
87 turret_params->zeroing_constants.average_filter_size =
88 Values::kZeroingSampleSize;
89 turret_params->zeroing_constants.one_revolution_distance =
90 M_PI * 2.0 * constants::Values::kTurretEncoderRatio();
91 turret_params->zeroing_constants.zeroing_threshold = 0.0005;
92 turret_params->zeroing_constants.moving_buffer_size = 20;
93 turret_params->zeroing_constants.allowable_encoder_error = 0.9;
94
Austin Schuh9dcd5202020-02-20 20:06:04 -080095 CHECK_LE(hood->range.range(),
96 hood->zeroing_constants.one_revolution_distance);
97 CHECK_LE(intake->range.range(),
98 intake->zeroing_constants.one_revolution_distance);
99
Stephan Massaltd021f972020-01-05 20:41:23 -0800100 switch (team) {
101 // A set of constants for tests.
102 case 1:
103 break;
104
105 case kCompTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800106 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800107
Sabina Davise8d38992020-02-02 15:00:31 -0800108 intake->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800109
110 turret->potentiometer_offset = 0.0;
111 turret_params->zeroing_constants.measured_absolute_position = 0.0;
Stephan Massaltd021f972020-01-05 20:41:23 -0800112 break;
113
114 case kPracticeTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800115 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800116
Sabina Davise8d38992020-02-02 15:00:31 -0800117 intake->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800118
119 turret->potentiometer_offset = 0.0;
120 turret_params->zeroing_constants.measured_absolute_position = 0.0;
Stephan Massaltd021f972020-01-05 20:41:23 -0800121 break;
122
123 case kCodingRobotTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800124 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800125
Sabina Davise8d38992020-02-02 15:00:31 -0800126 intake->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800127
128 turret->potentiometer_offset = 0.0;
129 turret_params->zeroing_constants.measured_absolute_position = 0.0;
Stephan Massaltd021f972020-01-05 20:41:23 -0800130 break;
131
132 default:
133 AOS_LOG(FATAL, "unknown team #%" PRIu16 "\n", team);
134 }
135
136 return r;
137}
138
139void DoGetValues(const Values **result) {
140 uint16_t team = ::aos::network::GetTeamNumber();
141 AOS_LOG(INFO, "creating a Constants for team %" PRIu16 "\n", team);
142 *result = DoGetValuesForTeam(team);
143}
144
145} // namespace
146
147const Values &GetValues() {
148 static absl::once_flag once;
149 static const Values *result;
150 absl::call_once(once, DoGetValues, &result);
151 return *result;
152}
153
154const Values &GetValuesForTeam(uint16_t team_number) {
155 static ::aos::Mutex mutex;
156 ::aos::MutexLocker locker(&mutex);
157
ravago901c4262020-02-16 15:33:14 -0800158 // IMPORTANT: This declaration has to stay after the mutex is locked to
159 // avoid race conditions.
Stephan Massaltd021f972020-01-05 20:41:23 -0800160 static ::std::map<uint16_t, const Values *> values;
161
162 if (values.count(team_number) == 0) {
163 values[team_number] = DoGetValuesForTeam(team_number);
164#if __has_feature(address_sanitizer)
165 __lsan_ignore_object(values[team_number]);
166#endif
167 }
168 return *values[team_number];
169}
170
171} // namespace constants
172} // namespace y2020