blob: b3551aab605a52c58a6958c8a639cd18d810d447 [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"
Stephan Massaltd021f972020-01-05 20:41:23 -080013#include "aos/network/team_number.h"
Brian Silverman1463c092020-10-30 17:28:24 -070014#include "aos/stl_mutex/stl_mutex.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;
James Kuszmaul6535d562020-05-09 16:58:13 -070029const uint16_t kSpareRoborioTeamNumber = 6971;
Stephan Massaltd021f972020-01-05 20:41:23 -080030
31const Values *DoGetValuesForTeam(uint16_t team) {
32 Values *const r = new Values();
Sabina Davisa587fbd2020-01-31 22:11:15 -080033 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
Ravago Jones937587c2020-12-26 17:21:09 -080034 ::frc971::zeroing::AbsoluteAndAbsoluteEncoderZeroingEstimator>
35 *const hood = &r->hood;
Sabina Davisa587fbd2020-01-31 22:11:15 -080036
37 // Hood constants.
Austin Schuh2efe1682021-03-06 22:47:15 -080038 hood->zeroing_voltage = 2.0;
Sabina Davisa587fbd2020-01-31 22:11:15 -080039 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;
Sabina Davisa587fbd2020-01-31 22:11:15 -080046 hood->zeroing_constants.zeroing_threshold = 0.0005;
47 hood->zeroing_constants.moving_buffer_size = 20;
48 hood->zeroing_constants.allowable_encoder_error = 0.9;
Ravago Jones937587c2020-12-26 17:21:09 -080049 hood->zeroing_constants.one_revolution_distance =
50 M_PI * 2.0 * constants::Values::kHoodEncoderRatio();
51 hood->zeroing_constants.single_turn_middle_position =
52 Values::kHoodRange().middle();
53 hood->zeroing_constants.single_turn_one_revolution_distance =
54 M_PI * 2.0 * constants::Values::kHoodSingleTurnEncoderRatio();
55 hood->zeroing_constants.measured_absolute_position = 0;
56 hood->zeroing_constants.single_turn_measured_absolute_position = 0;
Stephan Massaltd021f972020-01-05 20:41:23 -080057
Sabina Davise8d38992020-02-02 15:00:31 -080058 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
59 ::frc971::zeroing::AbsoluteEncoderZeroingEstimator> *const intake =
60 &r->intake;
61
62 // Intake constants.
63 intake->zeroing_voltage = 3.0;
64 intake->operating_voltage = 12.0;
65 intake->zeroing_profile_params = {0.5, 3.0};
66 intake->default_profile_params = {6.0, 30.0};
67 intake->range = Values::kIntakeRange();
68 intake->make_integral_loop =
69 control_loops::superstructure::intake::MakeIntegralIntakeLoop;
70 intake->zeroing_constants.average_filter_size = Values::kZeroingSampleSize;
71 intake->zeroing_constants.one_revolution_distance =
72 M_PI * 2.0 * constants::Values::kIntakeEncoderRatio();
73 intake->zeroing_constants.zeroing_threshold = 0.0005;
74 intake->zeroing_constants.moving_buffer_size = 20;
75 intake->zeroing_constants.allowable_encoder_error = 0.9;
76 intake->zeroing_constants.middle_position = Values::kIntakeRange().middle();
77
Kai Tinkess10943cf2020-02-01 15:49:57 -080078 Values::PotAndAbsEncoderConstants *const turret = &r->turret;
79 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
80 ::frc971::zeroing::PotAndAbsoluteEncoderZeroingEstimator>
81 *const turret_params = &turret->subsystem_params;
82
ravago901c4262020-02-16 15:33:14 -080083 // Turret Constants
Kai Tinkess10943cf2020-02-01 15:49:57 -080084 turret_params->zeroing_voltage = 4.0;
James Kuszmaul519585d2020-03-08 22:32:48 -070085 turret_params->operating_voltage = 8.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -080086 // TODO(austin): Tune these.
87 turret_params->zeroing_profile_params = {0.5, 2.0};
88 turret_params->default_profile_params = {15.0, 40.0};
89 turret_params->range = Values::kTurretRange();
90 turret_params->make_integral_loop =
91 &control_loops::superstructure::turret::MakeIntegralTurretLoop;
92 turret_params->zeroing_constants.average_filter_size =
93 Values::kZeroingSampleSize;
94 turret_params->zeroing_constants.one_revolution_distance =
95 M_PI * 2.0 * constants::Values::kTurretEncoderRatio();
96 turret_params->zeroing_constants.zeroing_threshold = 0.0005;
97 turret_params->zeroing_constants.moving_buffer_size = 20;
98 turret_params->zeroing_constants.allowable_encoder_error = 0.9;
99
Austin Schuh9dcd5202020-02-20 20:06:04 -0800100 CHECK_LE(hood->range.range(),
Ravago Jones937587c2020-12-26 17:21:09 -0800101 hood->zeroing_constants.single_turn_one_revolution_distance);
Austin Schuh9dcd5202020-02-20 20:06:04 -0800102 CHECK_LE(intake->range.range(),
103 intake->zeroing_constants.one_revolution_distance);
104
Stephan Massaltd021f972020-01-05 20:41:23 -0800105 switch (team) {
106 // A set of constants for tests.
107 case 1:
James Kuszmaul6535d562020-05-09 16:58:13 -0700108 case kSpareRoborioTeamNumber:
Stephan Massaltd021f972020-01-05 20:41:23 -0800109 break;
110
111 case kCompTeamNumber:
Sabina Davisf7afd112020-02-23 13:42:14 -0800112 intake->zeroing_constants.measured_absolute_position =
113 1.42977866919024 - Values::kIntakeZero();
Kai Tinkess10943cf2020-02-01 15:49:57 -0800114
Austin Schuh2fb23642020-02-29 15:10:51 -0800115 turret->potentiometer_offset = 5.52519370141247 + 0.00853506822980376 +
116 0.0109413725126625 - 0.223719825811759;
Sabina Davisf7afd112020-02-23 13:42:14 -0800117 turret_params->zeroing_constants.measured_absolute_position =
Austin Schuh2fb23642020-02-29 15:10:51 -0800118 0.547478339799516;
Ravago Jones937587c2020-12-26 17:21:09 -0800119
Austin Schuh2efe1682021-03-06 22:47:15 -0800120 hood->zeroing_constants.measured_absolute_position = 0.0344482433884915;
121 hood->zeroing_constants.single_turn_measured_absolute_position =
122 0.31055891442198;
Stephan Massaltd021f972020-01-05 20:41:23 -0800123 break;
124
125 case kPracticeTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800126 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800127
Austin Schuh31904ee2021-03-06 23:52:08 -0800128 intake->zeroing_constants.measured_absolute_position = 0.347;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800129
Austin Schuh31904ee2021-03-06 23:52:08 -0800130 turret->potentiometer_offset = 5.3931926228241;
131 turret_params->zeroing_constants.measured_absolute_position = 4.22;
Stephan Massaltd021f972020-01-05 20:41:23 -0800132 break;
133
Austin Schuh83873c32020-02-22 14:58:39 -0800134 case Values::kCodingRobotTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800135 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800136
Sabina Davise8d38992020-02-02 15:00:31 -0800137 intake->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800138
139 turret->potentiometer_offset = 0.0;
140 turret_params->zeroing_constants.measured_absolute_position = 0.0;
Stephan Massaltd021f972020-01-05 20:41:23 -0800141 break;
142
143 default:
144 AOS_LOG(FATAL, "unknown team #%" PRIu16 "\n", team);
145 }
146
147 return r;
148}
149
150void DoGetValues(const Values **result) {
151 uint16_t team = ::aos::network::GetTeamNumber();
152 AOS_LOG(INFO, "creating a Constants for team %" PRIu16 "\n", team);
153 *result = DoGetValuesForTeam(team);
154}
155
156} // namespace
157
158const Values &GetValues() {
159 static absl::once_flag once;
160 static const Values *result;
161 absl::call_once(once, DoGetValues, &result);
162 return *result;
163}
164
165const Values &GetValuesForTeam(uint16_t team_number) {
Brian Silverman1463c092020-10-30 17:28:24 -0700166 static aos::stl_mutex mutex;
167 std::unique_lock<aos::stl_mutex> locker(mutex);
Stephan Massaltd021f972020-01-05 20:41:23 -0800168
ravago901c4262020-02-16 15:33:14 -0800169 // IMPORTANT: This declaration has to stay after the mutex is locked to
170 // avoid race conditions.
Stephan Massaltd021f972020-01-05 20:41:23 -0800171 static ::std::map<uint16_t, const Values *> values;
172
173 if (values.count(team_number) == 0) {
174 values[team_number] = DoGetValuesForTeam(team_number);
175#if __has_feature(address_sanitizer)
176 __lsan_ignore_object(values[team_number]);
177#endif
178 }
179 return *values[team_number];
180}
181
182} // namespace constants
183} // namespace y2020