blob: 189ea5bb8f7a54d189978fe18ebac0dfe66b90b2 [file] [log] [blame]
Austin Schuh2a3e0632018-02-19 16:24:49 -08001#include "y2018/constants.h"
2
Tyler Chatowbf0609c2021-07-31 16:13:27 -07003#include <cinttypes>
4#include <cmath>
5#include <cstdint>
Austin Schuh2a3e0632018-02-19 16:24:49 -08006#include <map>
7
8#if __has_feature(address_sanitizer)
9#include "sanitizer/lsan_interface.h"
10#endif
11
Philipp Schrader790cb542023-07-05 21:06:52 -070012#include "glog/logging.h"
13
John Park33858a32018-09-28 23:05:48 -070014#include "aos/network/team_number.h"
Brian Silverman1463c092020-10-30 17:28:24 -070015#include "aos/stl_mutex/stl_mutex.h"
Austin Schuh2a3e0632018-02-19 16:24:49 -080016#include "y2018/control_loops/drivetrain/drivetrain_dog_motor_plant.h"
17#include "y2018/control_loops/drivetrain/polydrivetrain_dog_motor_plant.h"
18
19#ifndef M_PI
20#define M_PI 3.14159265358979323846
21#endif
22
23namespace y2018 {
24namespace constants {
25namespace {
26
27const uint16_t kCompTeamNumber = 971;
28const uint16_t kPracticeTeamNumber = 9971;
29
30const Values *DoGetValuesForTeam(uint16_t team) {
31 Values *const r = new Values();
Sabina Davis8d20ca82018-02-19 13:17:45 -080032 Values::IntakeSide *const left_intake = &r->left_intake;
33 Values::IntakeSide *const right_intake = &r->right_intake;
Austin Schuhcb091712018-02-21 20:01:55 -080034 Values::Proximal *const arm_proximal = &r->arm_proximal;
35 Values::Distal *const arm_distal = &r->arm_distal;
Austin Schuh2a3e0632018-02-19 16:24:49 -080036
Sabina Davis8d20ca82018-02-19 13:17:45 -080037 left_intake->zeroing.average_filter_size = Values::kZeroingSampleSize();
38 left_intake->zeroing.one_revolution_distance =
39 M_PI * 2.0 * constants::Values::kIntakeMotorEncoderRatio();
40 left_intake->zeroing.zeroing_threshold = 0.0005;
41 left_intake->zeroing.moving_buffer_size = 20;
42 left_intake->zeroing.allowable_encoder_error = 1.9;
43
44 *right_intake = *left_intake;
45
Austin Schuhcb091712018-02-21 20:01:55 -080046 arm_proximal->zeroing.average_filter_size = Values::kZeroingSampleSize();
47 arm_proximal->zeroing.one_revolution_distance =
Sabina Davis8d20ca82018-02-19 13:17:45 -080048 M_PI * 2.0 * constants::Values::kProximalEncoderRatio();
Austin Schuhcb091712018-02-21 20:01:55 -080049 arm_proximal->zeroing.zeroing_threshold = 0.0005;
50 arm_proximal->zeroing.moving_buffer_size = 20;
51 arm_proximal->zeroing.allowable_encoder_error = 0.9;
Sabina Davis8d20ca82018-02-19 13:17:45 -080052
Austin Schuhcb091712018-02-21 20:01:55 -080053 arm_distal->zeroing.average_filter_size = Values::kZeroingSampleSize();
54 arm_distal->zeroing.one_revolution_distance =
Sabina Davis8d20ca82018-02-19 13:17:45 -080055 M_PI * 2.0 * constants::Values::kDistalEncoderRatio();
Austin Schuhcb091712018-02-21 20:01:55 -080056 arm_distal->zeroing.zeroing_threshold = 0.0005;
57 arm_distal->zeroing.moving_buffer_size = 20;
58 arm_distal->zeroing.allowable_encoder_error = 0.9;
Sabina Davis8d20ca82018-02-19 13:17:45 -080059
Austin Schuh47d74942018-03-04 01:15:59 -080060 constexpr double kDistalZeroingPosition =
61 M_PI * 3.0 / 2.0 + (28.5 / 180.0) * M_PI;
62 // 5.209807817203074
63
Austin Schuh2a3e0632018-02-19 16:24:49 -080064 switch (team) {
65 // A set of constants for tests.
66 case 1:
Austin Schuh2a3e0632018-02-19 16:24:49 -080067 r->vision_name = "test";
68 r->vision_error = -0.030;
Sabina Davis8d20ca82018-02-19 13:17:45 -080069
70 left_intake->zeroing.measured_absolute_position = 0.0;
71 left_intake->potentiometer_offset = 0.0;
72 left_intake->spring_offset = 0.0;
73
74 right_intake->zeroing.measured_absolute_position = 0.0;
75 right_intake->potentiometer_offset = 0.0;
76 right_intake->spring_offset = 0.0;
77
Austin Schuhcb091712018-02-21 20:01:55 -080078 arm_proximal->zeroing.measured_absolute_position = 0.0;
79 arm_proximal->potentiometer_offset = 0.0;
Sabina Davis8d20ca82018-02-19 13:17:45 -080080
Austin Schuhcb091712018-02-21 20:01:55 -080081 arm_distal->zeroing.measured_absolute_position = 0.0;
82 arm_distal->potentiometer_offset = 0.0;
Austin Schuh2a3e0632018-02-19 16:24:49 -080083 break;
84
85 case kCompTeamNumber:
Austin Schuh2a3e0632018-02-19 16:24:49 -080086 r->vision_name = "competition";
87 r->vision_error = 0.0;
Sabina Davis8d20ca82018-02-19 13:17:45 -080088
Sabina Davis94265042018-11-03 19:42:07 -070089 left_intake->zeroing.measured_absolute_position = 0.219024;
90 left_intake->potentiometer_offset = -5.45258 + 1.299206 - 0.525603;
Austin Schuhec310a42018-05-30 20:46:48 -070091 left_intake->spring_offset = -0.25 - 0.009 + 0.029 - 0.025;
Sabina Davis8d20ca82018-02-19 13:17:45 -080092
Austin Schuh9356ccb2018-04-04 20:12:31 -070093 right_intake->zeroing.measured_absolute_position = 0.37022 - 0.04;
94 right_intake->potentiometer_offset = 3.739919 + 1.087098 + 0.825;
Austin Schuhec310a42018-05-30 20:46:48 -070095 right_intake->spring_offset = 0.25 + 0.015 - 0.025;
Sabina Davis8d20ca82018-02-19 13:17:45 -080096
Austin Schuhef978fc2018-03-21 20:38:06 -070097 arm_proximal->zeroing.measured_absolute_position =
Austin Schuhec310a42018-05-30 20:46:48 -070098 0.067941 + 1.047 - 0.116 + 0.06 - 0.004 + 0.009 + 0.0938;
Austin Schuh9356ccb2018-04-04 20:12:31 -070099 arm_proximal->potentiometer_offset =
Austin Schuhec310a42018-05-30 20:46:48 -0700100 1.047 - 3.653298 + -0.078 + 0.9455 + 0.265 - 0.36;
Sabina Davis8d20ca82018-02-19 13:17:45 -0800101
Austin Schuhef978fc2018-03-21 20:38:06 -0700102 arm_distal->zeroing.measured_absolute_position =
Austin Schuhec310a42018-05-30 20:46:48 -0700103 -0.870445 + 5.209807817203074 + 0.118 - 0.004 + 0.407 - 0.53;
Brian Silverman1463c092020-10-30 17:28:24 -0700104 arm_distal->potentiometer_offset =
105 5.209807817203074 + 1.250476 + 0.110 + 0.52;
Austin Schuh2a3e0632018-02-19 16:24:49 -0800106 break;
107
108 case kPracticeTeamNumber:
Austin Schuh2a3e0632018-02-19 16:24:49 -0800109 r->vision_name = "practice";
110 r->vision_error = 0.0;
Sabina Davis8d20ca82018-02-19 13:17:45 -0800111
Austin Schuh47d74942018-03-04 01:15:59 -0800112 left_intake->zeroing.measured_absolute_position = 0.031709;
113 left_intake->potentiometer_offset = -10.55 - 3.621232 + 4.996959;
114 left_intake->spring_offset = -0.249 - 0.002;
Sabina Davis8d20ca82018-02-19 13:17:45 -0800115
Austin Schuh47d74942018-03-04 01:15:59 -0800116 right_intake->zeroing.measured_absolute_position = 0.351376;
117 right_intake->potentiometer_offset = 9.59 + 1.530320 - 3.620648;
Austin Schuh9356ccb2018-04-04 20:12:31 -0700118 right_intake->spring_offset = 0.255 + 0.008 - 0.09;
Sabina Davis8d20ca82018-02-19 13:17:45 -0800119
Brian Silverman1463c092020-10-30 17:28:24 -0700120 arm_proximal->zeroing.measured_absolute_position =
121 -0.253183 + 1.0652774488034022 + 0.009566448803402405;
Austin Schuh03065362018-08-18 21:29:23 -0700122 arm_proximal->potentiometer_offset = -1.242 - 0.03 - 0.1 - 1.0652;
Sabina Davis8d20ca82018-02-19 13:17:45 -0800123
Austin Schuh47d74942018-03-04 01:15:59 -0800124 arm_distal->zeroing.measured_absolute_position =
Brian Silverman1463c092020-10-30 17:28:24 -0700125 1.102987 - kDistalZeroingPosition + 0.12 + 0.0095 +
126 0.22300918279692628;
127 arm_distal->potentiometer_offset = 2.772210 + M_PI + 0.434 - 0.12 + 1.25 -
128 0.226 + 0.862067 - 0.121925182796926;
Austin Schuh2a3e0632018-02-19 16:24:49 -0800129 break;
130
131 default:
Brian Silvermanf4d329c2021-11-04 19:32:10 -0700132 LOG(FATAL) << "unknown team: " << team;
Austin Schuh2a3e0632018-02-19 16:24:49 -0800133 }
134
135 return r;
136}
137
Austin Schuh6829f762018-03-02 21:36:01 -0800138const Values &DoGetValues() {
Austin Schuha8de4a62018-09-03 18:04:28 -0700139 const uint16_t team = ::aos::network::GetTeamNumber();
Brian Silvermanf4d329c2021-11-04 19:32:10 -0700140 LOG(INFO) << "creating a Constants for team: " << team;
Austin Schuh6829f762018-03-02 21:36:01 -0800141 return GetValuesForTeam(team);
Austin Schuh2a3e0632018-02-19 16:24:49 -0800142}
143
144} // namespace
145
Brian Silverman8d727072018-03-10 19:45:25 -0800146const Values &GetValues() {
147 static const Values r = DoGetValues();
148 return r;
149}
Austin Schuh2a3e0632018-02-19 16:24:49 -0800150
151const Values &GetValuesForTeam(uint16_t team_number) {
Brian Silverman1463c092020-10-30 17:28:24 -0700152 static aos::stl_mutex mutex;
153 std::unique_lock<aos::stl_mutex> locker(mutex);
Austin Schuh2a3e0632018-02-19 16:24:49 -0800154
155 static ::std::map<uint16_t, const Values *> values;
156
157 if (values.count(team_number) == 0) {
158 values[team_number] = DoGetValuesForTeam(team_number);
159#if __has_feature(address_sanitizer)
160 __lsan_ignore_object(values[team_number]);
161#endif
162 }
163 return *values[team_number];
164}
165
166} // namespace constants
167} // namespace y2018