blob: 2ad0c9701b043e9e3e8f6828a3e02c1ef65c35a1 [file] [log] [blame]
Austin Schuh2a3e0632018-02-19 16:24:49 -08001#include "y2018/constants.h"
2
3#include <inttypes.h>
4#include <math.h>
5#include <stdint.h>
6
7#include <map>
8
9#if __has_feature(address_sanitizer)
10#include "sanitizer/lsan_interface.h"
11#endif
12
13#include "aos/common/logging/logging.h"
14#include "aos/common/mutex.h"
15#include "aos/common/network/team_number.h"
16#include "aos/once.h"
17
18#include "y2018/control_loops/drivetrain/drivetrain_dog_motor_plant.h"
19#include "y2018/control_loops/drivetrain/polydrivetrain_dog_motor_plant.h"
20
21#ifndef M_PI
22#define M_PI 3.14159265358979323846
23#endif
24
25namespace y2018 {
26namespace constants {
27namespace {
28
29const uint16_t kCompTeamNumber = 971;
30const uint16_t kPracticeTeamNumber = 9971;
31
32const Values *DoGetValuesForTeam(uint16_t team) {
33 Values *const r = new Values();
Sabina Davis8d20ca82018-02-19 13:17:45 -080034 Values::IntakeSide *const left_intake = &r->left_intake;
35 Values::IntakeSide *const right_intake = &r->right_intake;
Austin Schuhcb091712018-02-21 20:01:55 -080036 Values::Proximal *const arm_proximal = &r->arm_proximal;
37 Values::Distal *const arm_distal = &r->arm_distal;
Austin Schuh2a3e0632018-02-19 16:24:49 -080038
Sabina Davis8d20ca82018-02-19 13:17:45 -080039 left_intake->zeroing.average_filter_size = Values::kZeroingSampleSize();
40 left_intake->zeroing.one_revolution_distance =
41 M_PI * 2.0 * constants::Values::kIntakeMotorEncoderRatio();
42 left_intake->zeroing.zeroing_threshold = 0.0005;
43 left_intake->zeroing.moving_buffer_size = 20;
44 left_intake->zeroing.allowable_encoder_error = 1.9;
45
46 *right_intake = *left_intake;
47
Austin Schuhcb091712018-02-21 20:01:55 -080048 arm_proximal->zeroing.average_filter_size = Values::kZeroingSampleSize();
49 arm_proximal->zeroing.one_revolution_distance =
Sabina Davis8d20ca82018-02-19 13:17:45 -080050 M_PI * 2.0 * constants::Values::kProximalEncoderRatio();
Austin Schuhcb091712018-02-21 20:01:55 -080051 arm_proximal->zeroing.zeroing_threshold = 0.0005;
52 arm_proximal->zeroing.moving_buffer_size = 20;
53 arm_proximal->zeroing.allowable_encoder_error = 0.9;
Sabina Davis8d20ca82018-02-19 13:17:45 -080054
Austin Schuhcb091712018-02-21 20:01:55 -080055 arm_distal->zeroing.average_filter_size = Values::kZeroingSampleSize();
56 arm_distal->zeroing.one_revolution_distance =
Sabina Davis8d20ca82018-02-19 13:17:45 -080057 M_PI * 2.0 * constants::Values::kDistalEncoderRatio();
Austin Schuhcb091712018-02-21 20:01:55 -080058 arm_distal->zeroing.zeroing_threshold = 0.0005;
59 arm_distal->zeroing.moving_buffer_size = 20;
60 arm_distal->zeroing.allowable_encoder_error = 0.9;
Sabina Davis8d20ca82018-02-19 13:17:45 -080061
Austin Schuh47d74942018-03-04 01:15:59 -080062 constexpr double kDistalZeroingPosition =
63 M_PI * 3.0 / 2.0 + (28.5 / 180.0) * M_PI;
64 // 5.209807817203074
65
Austin Schuh2a3e0632018-02-19 16:24:49 -080066 switch (team) {
67 // A set of constants for tests.
68 case 1:
Austin Schuh2a3e0632018-02-19 16:24:49 -080069 r->vision_name = "test";
70 r->vision_error = -0.030;
Sabina Davis8d20ca82018-02-19 13:17:45 -080071
72 left_intake->zeroing.measured_absolute_position = 0.0;
73 left_intake->potentiometer_offset = 0.0;
74 left_intake->spring_offset = 0.0;
75
76 right_intake->zeroing.measured_absolute_position = 0.0;
77 right_intake->potentiometer_offset = 0.0;
78 right_intake->spring_offset = 0.0;
79
Austin Schuhcb091712018-02-21 20:01:55 -080080 arm_proximal->zeroing.measured_absolute_position = 0.0;
81 arm_proximal->potentiometer_offset = 0.0;
Sabina Davis8d20ca82018-02-19 13:17:45 -080082
Austin Schuhcb091712018-02-21 20:01:55 -080083 arm_distal->zeroing.measured_absolute_position = 0.0;
84 arm_distal->potentiometer_offset = 0.0;
Austin Schuh2a3e0632018-02-19 16:24:49 -080085 break;
86
87 case kCompTeamNumber:
Austin Schuh2a3e0632018-02-19 16:24:49 -080088 r->vision_name = "competition";
89 r->vision_error = 0.0;
Sabina Davis8d20ca82018-02-19 13:17:45 -080090
Austin Schuhef978fc2018-03-21 20:38:06 -070091 left_intake->zeroing.measured_absolute_position = 0.213653;
Austin Schuh9356ccb2018-04-04 20:12:31 -070092 left_intake->potentiometer_offset = -5.45258 + 1.299206;
Austin Schuhec310a42018-05-30 20:46:48 -070093 left_intake->spring_offset = -0.25 - 0.009 + 0.029 - 0.025;
Sabina Davis8d20ca82018-02-19 13:17:45 -080094
Austin Schuh9356ccb2018-04-04 20:12:31 -070095 right_intake->zeroing.measured_absolute_position = 0.37022 - 0.04;
96 right_intake->potentiometer_offset = 3.739919 + 1.087098 + 0.825;
Austin Schuhec310a42018-05-30 20:46:48 -070097 right_intake->spring_offset = 0.25 + 0.015 - 0.025;
Sabina Davis8d20ca82018-02-19 13:17:45 -080098
Austin Schuhef978fc2018-03-21 20:38:06 -070099 arm_proximal->zeroing.measured_absolute_position =
Austin Schuhec310a42018-05-30 20:46:48 -0700100 0.067941 + 1.047 - 0.116 + 0.06 - 0.004 + 0.009 + 0.0938;
Austin Schuh9356ccb2018-04-04 20:12:31 -0700101 arm_proximal->potentiometer_offset =
Austin Schuhec310a42018-05-30 20:46:48 -0700102 1.047 - 3.653298 + -0.078 + 0.9455 + 0.265 - 0.36;
Sabina Davis8d20ca82018-02-19 13:17:45 -0800103
Austin Schuhef978fc2018-03-21 20:38:06 -0700104 arm_distal->zeroing.measured_absolute_position =
Austin Schuhec310a42018-05-30 20:46:48 -0700105 -0.870445 + 5.209807817203074 + 0.118 - 0.004 + 0.407 - 0.53;
106 arm_distal->potentiometer_offset = 5.209807817203074 + 1.250476 + 0.110 + 0.52;
Austin Schuh2a3e0632018-02-19 16:24:49 -0800107 break;
108
109 case kPracticeTeamNumber:
Austin Schuh2a3e0632018-02-19 16:24:49 -0800110 r->vision_name = "practice";
111 r->vision_error = 0.0;
Sabina Davis8d20ca82018-02-19 13:17:45 -0800112
Austin Schuh47d74942018-03-04 01:15:59 -0800113 left_intake->zeroing.measured_absolute_position = 0.031709;
114 left_intake->potentiometer_offset = -10.55 - 3.621232 + 4.996959;
115 left_intake->spring_offset = -0.249 - 0.002;
Sabina Davis8d20ca82018-02-19 13:17:45 -0800116
Austin Schuh47d74942018-03-04 01:15:59 -0800117 right_intake->zeroing.measured_absolute_position = 0.351376;
118 right_intake->potentiometer_offset = 9.59 + 1.530320 - 3.620648;
Austin Schuh9356ccb2018-04-04 20:12:31 -0700119 right_intake->spring_offset = 0.255 + 0.008 - 0.09;
Sabina Davis8d20ca82018-02-19 13:17:45 -0800120
Austin Schuh03065362018-08-18 21:29:23 -0700121 arm_proximal->zeroing.measured_absolute_position = -0.253183 + 1.0652774488034022 + 0.009566448803402405;
122 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 =
Austin Schuh03065362018-08-18 21:29:23 -0700125 1.102987 - kDistalZeroingPosition + 0.12 + 0.0095 + 0.22300918279692628;
Austin Schuhef978fc2018-03-21 20:38:06 -0700126 arm_distal->potentiometer_offset =
Austin Schuh03065362018-08-18 21:29:23 -0700127 2.772210 + M_PI + 0.434 - 0.12 + 1.25 - 0.226 + 0.862067 - 0.121925182796926;
Austin Schuh2a3e0632018-02-19 16:24:49 -0800128 break;
129
130 default:
131 LOG(FATAL, "unknown team #%" PRIu16 "\n", team);
132 }
133
134 return r;
135}
136
Austin Schuh6829f762018-03-02 21:36:01 -0800137const Values &DoGetValues() {
Austin Schuh2a3e0632018-02-19 16:24:49 -0800138 uint16_t team = ::aos::network::GetTeamNumber();
139 LOG(INFO, "creating a Constants for team %" PRIu16 "\n", team);
Austin Schuh6829f762018-03-02 21:36:01 -0800140 return GetValuesForTeam(team);
Austin Schuh2a3e0632018-02-19 16:24:49 -0800141}
142
143} // namespace
144
Brian Silverman8d727072018-03-10 19:45:25 -0800145const Values &GetValues() {
146 static const Values r = DoGetValues();
147 return r;
148}
Austin Schuh2a3e0632018-02-19 16:24:49 -0800149
150const Values &GetValuesForTeam(uint16_t team_number) {
151 static ::aos::Mutex mutex;
152 ::aos::MutexLocker locker(&mutex);
153
154 static ::std::map<uint16_t, const Values *> values;
155
156 if (values.count(team_number) == 0) {
157 values[team_number] = DoGetValuesForTeam(team_number);
158#if __has_feature(address_sanitizer)
159 __lsan_ignore_object(values[team_number]);
160#endif
161 }
162 return *values[team_number];
163}
164
165} // namespace constants
166} // namespace y2018