blob: 97d253ab6cd7c318ad8a825e7cf68f037ccdf9f9 [file] [log] [blame]
Comran Morshed6c6a0a92016-01-17 12:45:16 +00001#include "y2016/constants.h"
Comran Morshed9a9948c2016-01-16 15:58:04 +00002
3#include <math.h>
4#include <stdint.h>
5#include <inttypes.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/once.h"
15#include "aos/common/network/team_number.h"
16#include "aos/common/mutex.h"
17
Comran Morshed6c6a0a92016-01-17 12:45:16 +000018#include "y2016/control_loops/drivetrain/polydrivetrain_dog_motor_plant.h"
19#include "y2016/control_loops/drivetrain/drivetrain_dog_motor_plant.h"
Comran Morshed9a9948c2016-01-16 15:58:04 +000020
21#ifndef M_PI
22#define M_PI 3.14159265358979323846
23#endif
24
Comran Morshed6c6a0a92016-01-17 12:45:16 +000025namespace y2016 {
Comran Morshed9a9948c2016-01-16 15:58:04 +000026namespace constants {
Comran Morshed9a9948c2016-01-16 15:58:04 +000027
Comran Morshed225f0b92016-02-10 20:34:27 +000028// ///// Mutual constants between robots. /////
29const int Values::kZeroingSampleSize;
30
Austin Schuh33bc6842016-02-17 00:38:51 -080031constexpr double Values::kDrivetrainEncoderRatio, Values::kShooterEncoderRatio,
Comran Morshed225f0b92016-02-10 20:34:27 +000032 Values::kIntakeEncoderRatio, Values::kShoulderEncoderRatio,
33 Values::kWristEncoderRatio, Values::kIntakePotRatio,
34 Values::kShoulderPotRatio, Values::kWristPotRatio,
35 Values::kIntakeEncoderIndexDifference,
36 Values::kShoulderEncoderIndexDifference,
37 Values::kWristEncoderIndexDifference;
Brian Silvermanebca77a2016-02-14 22:14:00 -050038constexpr ::frc971::constants::Range Values::kIntakeRange,
39 Values::kShoulderRange, Values::kWristRange;
Comran Morshed225f0b92016-02-10 20:34:27 +000040
41namespace {
Comran Morshed9a9948c2016-01-16 15:58:04 +000042const uint16_t kCompTeamNumber = 971;
43const uint16_t kPracticeTeamNumber = 9971;
Comran Morshed9a9948c2016-01-16 15:58:04 +000044
Comran Morshed225f0b92016-02-10 20:34:27 +000045// ///// Dynamic constants. /////
Austin Schuh04c894e2016-02-13 23:54:42 -080046
Comran Morshed9a9948c2016-01-16 15:58:04 +000047const Values *DoGetValuesForTeam(uint16_t team) {
48 switch (team) {
Comran Morshed315cf392016-02-14 20:40:22 +000049 case 1: // for tests
50 return new Values{
51 5.0, // drivetrain max speed
52
53 // Intake
54 {
55 0.0,
56 {Values::kZeroingSampleSize, Values::kIntakeEncoderIndexDifference,
57 0.0, 0.3},
58 },
59
60 // Shoulder
61 {
62 0.0,
63 {Values::kZeroingSampleSize, Values::kShoulderEncoderIndexDifference,
64 0.0, 0.3},
65 },
66
67 // Wrist
68 {
69 0.0,
70 {Values::kZeroingSampleSize, Values::kWristEncoderIndexDifference,
71 0.0, 0.3},
72 },
73 };
74 break;
75
Comran Morshed9a9948c2016-01-16 15:58:04 +000076 case kCompTeamNumber:
77 return new Values{
Comran Morshed6c6a0a92016-01-17 12:45:16 +000078 5.0, // drivetrain max speed
Austin Schuh2fc10fa2016-02-08 00:44:34 -080079
80 // Intake
81 {
Austin Schuh9f77fd22016-02-21 02:53:58 -080082 // Value to add to the pot reading for the intake.
83 -4.550531 + 150.40906362 * M_PI / 180.0,
Comran Morshed225f0b92016-02-10 20:34:27 +000084 {Values::kZeroingSampleSize, Values::kIntakeEncoderIndexDifference,
Austin Schuh9f77fd22016-02-21 02:53:58 -080085 // Location of an index pulse.
86 -0.087413 + 150.40906362 * M_PI / 180.0, 0.3},
Austin Schuh2fc10fa2016-02-08 00:44:34 -080087 },
88
89 // Shoulder
90 {
Austin Schuh9f77fd22016-02-21 02:53:58 -080091 // Value to add to the pot reading for the shoulder.
92 -1.0 - 0.0822 + 0.06138835 * M_PI / 180.0,
Comran Morshed225f0b92016-02-10 20:34:27 +000093 {Values::kZeroingSampleSize, Values::kShoulderEncoderIndexDifference,
Austin Schuh9f77fd22016-02-21 02:53:58 -080094 0.06138835 * M_PI / 180.0 + 0.353794, 0.3},
Austin Schuh2fc10fa2016-02-08 00:44:34 -080095 },
96
97 // Wrist
98 {
Austin Schuh9f77fd22016-02-21 02:53:58 -080099 // Value to add to the pot reading for the wrist.
100 3.2390714288298668 + -0.06138835 * M_PI / 180.0,
Comran Morshed225f0b92016-02-10 20:34:27 +0000101 {Values::kZeroingSampleSize, Values::kWristEncoderIndexDifference,
Austin Schuh9f77fd22016-02-21 02:53:58 -0800102 -0.06138835 * M_PI / 180.0 - 0.260542, 0.3},
Austin Schuh2fc10fa2016-02-08 00:44:34 -0800103 },
Comran Morshed9a9948c2016-01-16 15:58:04 +0000104 };
105 break;
106 case kPracticeTeamNumber:
Comran Morshed9a9948c2016-01-16 15:58:04 +0000107 return new Values{
Comran Morshed6c6a0a92016-01-17 12:45:16 +0000108 5.0, // drivetrain max speed
Austin Schuh2fc10fa2016-02-08 00:44:34 -0800109
110 // Intake
111 {
Austin Schuh449966b2016-03-11 21:27:05 -0800112 // Hard stop is 164.2067247 degrees.
Austin Schuha3240bd2016-03-13 15:31:01 -0700113 -4.2193 + (164.2067247 * M_PI / 180.0 + 0.02 - 0.0235) + 0.0549 -
114 0.104,
Comran Morshed225f0b92016-02-10 20:34:27 +0000115 {Values::kZeroingSampleSize, Values::kIntakeEncoderIndexDifference,
Austin Schuha3240bd2016-03-13 15:31:01 -0700116 0.363074, 0.3},
Austin Schuh2fc10fa2016-02-08 00:44:34 -0800117 },
118
Austin Schuh449966b2016-03-11 21:27:05 -0800119 // Shoulder (Now calibrated at 0)
Austin Schuh2fc10fa2016-02-08 00:44:34 -0800120 {
Austin Schuh449966b2016-03-11 21:27:05 -0800121 -1.0016 - 0.0841 + 0.06138835 * M_PI / 180.0,
Comran Morshed225f0b92016-02-10 20:34:27 +0000122 {Values::kZeroingSampleSize, Values::kShoulderEncoderIndexDifference,
Austin Schuh449966b2016-03-11 21:27:05 -0800123 0.014860, 0.3},
Austin Schuh2fc10fa2016-02-08 00:44:34 -0800124 },
125
126 // Wrist
127 {
Austin Schuha3240bd2016-03-13 15:31:01 -0700128 3.326328571170133 - 0.06138835 * M_PI / 180.0 - 0.177 + 0.0323 -
129 0.023,
Comran Morshed225f0b92016-02-10 20:34:27 +0000130 {Values::kZeroingSampleSize, Values::kWristEncoderIndexDifference,
Austin Schuha3240bd2016-03-13 15:31:01 -0700131 -0.622423, 0.3},
Austin Schuh2fc10fa2016-02-08 00:44:34 -0800132 },
Comran Morshed9a9948c2016-01-16 15:58:04 +0000133 };
134 break;
135 default:
136 LOG(FATAL, "unknown team #%" PRIu16 "\n", team);
137 }
138}
139
140const Values *DoGetValues() {
141 uint16_t team = ::aos::network::GetTeamNumber();
142 LOG(INFO, "creating a Constants for team %" PRIu16 "\n", team);
143 return DoGetValuesForTeam(team);
144}
145
146} // namespace
147
148const Values &GetValues() {
149 static ::aos::Once<const Values> once(DoGetValues);
150 return *once.Get();
151}
152
153const Values &GetValuesForTeam(uint16_t team_number) {
154 static ::aos::Mutex mutex;
155 ::aos::MutexLocker locker(&mutex);
156
157 // IMPORTANT: This declaration has to stay after the mutex is locked to avoid
158 // race conditions.
159 static ::std::map<uint16_t, const Values *> values;
160
161 if (values.count(team_number) == 0) {
162 values[team_number] = DoGetValuesForTeam(team_number);
163#if __has_feature(address_sanitizer)
164 __lsan_ignore_object(values[team_number]);
165#endif
166 }
167 return *values[team_number];
168}
169
170} // namespace constants
Comran Morshed6c6a0a92016-01-17 12:45:16 +0000171} // namespace y2016