blob: a490e2deccd9df59508a3419456fb0c0e0b4aa9a [file] [log] [blame]
Stephan Massaltd021f972020-01-05 20:41:23 -08001#include "y2020/constants.h"
2
Tyler Chatowbf0609c2021-07-31 16:13:27 -07003#include <cinttypes>
Stephan Massaltd021f972020-01-05 20:41:23 -08004#include <map>
5
6#if __has_feature(address_sanitizer)
7#include "sanitizer/lsan_interface.h"
8#endif
9
10#include "absl/base/call_once.h"
Stephan Massaltd021f972020-01-05 20:41:23 -080011#include "aos/network/team_number.h"
Brian Silverman1463c092020-10-30 17:28:24 -070012#include "aos/stl_mutex/stl_mutex.h"
Brian Silvermanf4d329c2021-11-04 19:32:10 -070013#include "glog/logging.h"
ravago901c4262020-02-16 15:33:14 -080014#include "y2020/control_loops/superstructure/control_panel/integral_control_panel_plant.h"
Sabina Davisa587fbd2020-01-31 22:11:15 -080015#include "y2020/control_loops/superstructure/hood/integral_hood_plant.h"
Kai Tinkess10943cf2020-02-01 15:49:57 -080016#include "y2020/control_loops/superstructure/intake/integral_intake_plant.h"
17#include "y2020/control_loops/superstructure/turret/integral_turret_plant.h"
Sabina Davisa587fbd2020-01-31 22:11:15 -080018
Stephan Massaltd021f972020-01-05 20:41:23 -080019namespace y2020 {
20namespace constants {
21
22const int Values::kZeroingSampleSize;
23
24namespace {
25
Stephan Massaltd021f972020-01-05 20:41:23 -080026const Values *DoGetValuesForTeam(uint16_t team) {
27 Values *const r = new Values();
Sabina Davisa587fbd2020-01-31 22:11:15 -080028 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
Ravago Jones937587c2020-12-26 17:21:09 -080029 ::frc971::zeroing::AbsoluteAndAbsoluteEncoderZeroingEstimator>
30 *const hood = &r->hood;
milind-ud53408e2021-10-21 19:43:58 -070031 Values::HoodGeometry *const hood_geometry = &r->hood_geometry;
Sabina Davisa587fbd2020-01-31 22:11:15 -080032
milind-ud53408e2021-10-21 19:43:58 -070033 // We found that the finisher velocity does not change ball velocity much,
34 // so keep it constant.
Austin Schuh4408c422021-10-16 13:56:07 -070035 r->shot_interpolation_table =
milind-uf7fadbf2021-11-07 14:10:54 -080036 InterpolationTable<Values::ShotParams>({{1.128, {0.01, 225, 170}},
37 {1.509, {0.01, 215, 160}},
38 {1.89, {0.01, 215, 155}},
39 {2.15, {0.093, 210, 170}},
40 {2.68, {0.195, 240, 190}},
41 {3.19, {0.27, 250, 220}},
42 {3.93, {0.365, 285, 250}},
43 {4.63, {0.42, 320, 280}},
44 {5.32, {0.515, 375, 330}},
45 {6, {0.565, 440, 400}},
46 {6.68, {0.58, 480, 450}},
47 {7.37, {0.645, 520, 540}},
48 {8.36, {0.645, 550, 560}},
49 {9.39, {0.66, 550, 580}},
Austin Schuhb24e9052021-11-12 19:53:33 -080050 {10.4, {0.670, 550, 600}},
51 {11.4, {0.670, 550, 600}}});
James Kuszmaul98154a22021-04-03 16:09:29 -070052
Sabina Davisa587fbd2020-01-31 22:11:15 -080053 // Hood constants.
Austin Schuh2efe1682021-03-06 22:47:15 -080054 hood->zeroing_voltage = 2.0;
Sabina Davisa587fbd2020-01-31 22:11:15 -080055 hood->operating_voltage = 12.0;
56 hood->zeroing_profile_params = {0.5, 3.0};
57 hood->default_profile_params = {6.0, 30.0};
58 hood->range = Values::kHoodRange();
59 hood->make_integral_loop =
60 control_loops::superstructure::hood::MakeIntegralHoodLoop;
61 hood->zeroing_constants.average_filter_size = Values::kZeroingSampleSize;
Sabina Davisa587fbd2020-01-31 22:11:15 -080062 hood->zeroing_constants.zeroing_threshold = 0.0005;
63 hood->zeroing_constants.moving_buffer_size = 20;
64 hood->zeroing_constants.allowable_encoder_error = 0.9;
Ravago Jones937587c2020-12-26 17:21:09 -080065 hood->zeroing_constants.one_revolution_distance =
66 M_PI * 2.0 * constants::Values::kHoodEncoderRatio();
67 hood->zeroing_constants.single_turn_middle_position =
68 Values::kHoodRange().middle();
69 hood->zeroing_constants.single_turn_one_revolution_distance =
70 M_PI * 2.0 * constants::Values::kHoodSingleTurnEncoderRatio();
71 hood->zeroing_constants.measured_absolute_position = 0;
72 hood->zeroing_constants.single_turn_measured_absolute_position = 0;
Stephan Massaltd021f972020-01-05 20:41:23 -080073
milind-ud53408e2021-10-21 19:43:58 -070074 constexpr double kDegToRad = M_PI / 180.0;
75 constexpr double kMmToM = 1.0 / 1000.0;
76 hood_geometry->theta_0 = 22.98004 * kDegToRad;
77 hood_geometry->screw_length_0 = 110.33888 * kMmToM;
78 hood_geometry->radius = 269.6262 * kMmToM;
79 hood_geometry->diagonal_length = 288.4353 * kMmToM;
80 hood_geometry->back_plate_diagonal_length = 22.86 * kMmToM;
81
Sabina Davise8d38992020-02-02 15:00:31 -080082 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
83 ::frc971::zeroing::AbsoluteEncoderZeroingEstimator> *const intake =
84 &r->intake;
85
86 // Intake constants.
87 intake->zeroing_voltage = 3.0;
88 intake->operating_voltage = 12.0;
89 intake->zeroing_profile_params = {0.5, 3.0};
90 intake->default_profile_params = {6.0, 30.0};
91 intake->range = Values::kIntakeRange();
92 intake->make_integral_loop =
93 control_loops::superstructure::intake::MakeIntegralIntakeLoop;
94 intake->zeroing_constants.average_filter_size = Values::kZeroingSampleSize;
95 intake->zeroing_constants.one_revolution_distance =
96 M_PI * 2.0 * constants::Values::kIntakeEncoderRatio();
97 intake->zeroing_constants.zeroing_threshold = 0.0005;
98 intake->zeroing_constants.moving_buffer_size = 20;
99 intake->zeroing_constants.allowable_encoder_error = 0.9;
100 intake->zeroing_constants.middle_position = Values::kIntakeRange().middle();
101
Kai Tinkess10943cf2020-02-01 15:49:57 -0800102 Values::PotAndAbsEncoderConstants *const turret = &r->turret;
103 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
104 ::frc971::zeroing::PotAndAbsoluteEncoderZeroingEstimator>
105 *const turret_params = &turret->subsystem_params;
106
ravago901c4262020-02-16 15:33:14 -0800107 // Turret Constants
Kai Tinkess10943cf2020-02-01 15:49:57 -0800108 turret_params->zeroing_voltage = 4.0;
James Kuszmaul519585d2020-03-08 22:32:48 -0700109 turret_params->operating_voltage = 8.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800110 // TODO(austin): Tune these.
111 turret_params->zeroing_profile_params = {0.5, 2.0};
112 turret_params->default_profile_params = {15.0, 40.0};
113 turret_params->range = Values::kTurretRange();
114 turret_params->make_integral_loop =
115 &control_loops::superstructure::turret::MakeIntegralTurretLoop;
116 turret_params->zeroing_constants.average_filter_size =
117 Values::kZeroingSampleSize;
118 turret_params->zeroing_constants.one_revolution_distance =
119 M_PI * 2.0 * constants::Values::kTurretEncoderRatio();
120 turret_params->zeroing_constants.zeroing_threshold = 0.0005;
121 turret_params->zeroing_constants.moving_buffer_size = 20;
122 turret_params->zeroing_constants.allowable_encoder_error = 0.9;
123
Austin Schuh9dcd5202020-02-20 20:06:04 -0800124 CHECK_LE(hood->range.range(),
Ravago Jones937587c2020-12-26 17:21:09 -0800125 hood->zeroing_constants.single_turn_one_revolution_distance);
Austin Schuh9dcd5202020-02-20 20:06:04 -0800126 CHECK_LE(intake->range.range(),
127 intake->zeroing_constants.one_revolution_distance);
128
Stephan Massaltd021f972020-01-05 20:41:23 -0800129 switch (team) {
130 // A set of constants for tests.
131 case 1:
milind-uf7fadbf2021-11-07 14:10:54 -0800132 r->shot_interpolation_table = InterpolationTable<Values::ShotParams>(
milind-udfe0bcd2021-11-07 16:23:26 -0800133 {{1, {0.01, 250, 350}}, {10, {0.67, 500, 350}}});
James Kuszmaul0a981402021-10-09 21:00:34 -0700134 case Values::kSpareRoborioTeamNumber:
Stephan Massaltd021f972020-01-05 20:41:23 -0800135 break;
136
James Kuszmaul0a981402021-10-09 21:00:34 -0700137 case Values::kCompTeamNumber:
Sabina Davisf7afd112020-02-23 13:42:14 -0800138 intake->zeroing_constants.measured_absolute_position =
Austin Schuh4dc06c72021-10-17 17:39:41 -0700139 0.433936997731885 - Values::kIntakeZero();
Kai Tinkess10943cf2020-02-01 15:49:57 -0800140
Austin Schuh2fb23642020-02-29 15:10:51 -0800141 turret->potentiometer_offset = 5.52519370141247 + 0.00853506822980376 +
James Kuszmaulf774d2d2021-10-03 08:02:35 -0700142 0.0109413725126625 - 0.223719825811759 +
Austin Schuh1216d992021-10-23 19:23:43 -0700143 0.261356551915472 - 0.0490168170767848 -
144 0.179342788816305;
Sabina Davisf7afd112020-02-23 13:42:14 -0800145 turret_params->zeroing_constants.measured_absolute_position =
Austin Schuh1216d992021-10-23 19:23:43 -0700146 2.75051496009509;
Ravago Jones937587c2020-12-26 17:21:09 -0800147
Austin Schuha2f01c62021-10-25 22:01:10 -0700148 hood->zeroing_constants.measured_absolute_position = 0.0102882878327271;
Austin Schuh2efe1682021-03-06 22:47:15 -0800149 hood->zeroing_constants.single_turn_measured_absolute_position =
Austin Schuhc09cbe02021-10-24 17:16:15 -0700150 0.302574797776192;
Stephan Massaltd021f972020-01-05 20:41:23 -0800151 break;
152
James Kuszmaul0a981402021-10-09 21:00:34 -0700153 case Values::kPracticeTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800154 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800155
Austin Schuh81c5f002021-11-06 22:59:07 -0700156 intake->zeroing_constants.measured_absolute_position = 0.205469223604347;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800157
Austin Schuh31904ee2021-03-06 23:52:08 -0800158 turret->potentiometer_offset = 5.3931926228241;
159 turret_params->zeroing_constants.measured_absolute_position = 4.22;
Stephan Massaltd021f972020-01-05 20:41:23 -0800160 break;
161
Austin Schuh83873c32020-02-22 14:58:39 -0800162 case Values::kCodingRobotTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800163 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800164
Sabina Davise8d38992020-02-02 15:00:31 -0800165 intake->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800166
167 turret->potentiometer_offset = 0.0;
168 turret_params->zeroing_constants.measured_absolute_position = 0.0;
Stephan Massaltd021f972020-01-05 20:41:23 -0800169 break;
170
171 default:
Brian Silvermanf4d329c2021-11-04 19:32:10 -0700172 LOG(FATAL) << "unknown team: " << team;
Stephan Massaltd021f972020-01-05 20:41:23 -0800173 }
174
175 return r;
176}
177
milind-u62d4a8e2021-10-11 16:08:41 -0700178const Values *values = nullptr;
179
180void DoGetValues() {
Stephan Massaltd021f972020-01-05 20:41:23 -0800181 uint16_t team = ::aos::network::GetTeamNumber();
Brian Silvermanf4d329c2021-11-04 19:32:10 -0700182 LOG(INFO) << "creating a Constants for team: " << team;
milind-u62d4a8e2021-10-11 16:08:41 -0700183 values = DoGetValuesForTeam(team);
Stephan Massaltd021f972020-01-05 20:41:23 -0800184}
185
186} // namespace
187
milind-u62d4a8e2021-10-11 16:08:41 -0700188void InitValues() {
Stephan Massaltd021f972020-01-05 20:41:23 -0800189 static absl::once_flag once;
milind-u62d4a8e2021-10-11 16:08:41 -0700190 absl::call_once(once, DoGetValues);
Stephan Massaltd021f972020-01-05 20:41:23 -0800191}
192
milind-u62d4a8e2021-10-11 16:08:41 -0700193const Values &GetValues() {
194 CHECK(values)
195 << "Values are uninitialized. Call InitValues before accessing them.";
196 return *values;
Stephan Massaltd021f972020-01-05 20:41:23 -0800197}
198
199} // namespace constants
200} // namespace y2020