blob: 802c57dcfd3467e4a52f11ed2696bb5837d9b4c0 [file] [log] [blame]
Tyler Chatow6107aba2017-01-22 01:39:40 +00001#include "y2017/constants.h"
2
Ed Jordan8683f432017-02-12 00:13:26 +00003#include <inttypes.h>
Tyler Chatow6107aba2017-01-22 01:39:40 +00004#include <math.h>
5#include <stdint.h>
Tyler Chatow6107aba2017-01-22 01:39:40 +00006
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"
Tyler Chatow6107aba2017-01-22 01:39:40 +000014#include "aos/common/mutex.h"
Ed Jordan8683f432017-02-12 00:13:26 +000015#include "aos/common/network/team_number.h"
16#include "aos/common/once.h"
17
18#include "y2017/control_loops/drivetrain/drivetrain_dog_motor_plant.h"
19#include "y2017/control_loops/drivetrain/polydrivetrain_dog_motor_plant.h"
Tyler Chatow6107aba2017-01-22 01:39:40 +000020
21#ifndef M_PI
22#define M_PI 3.14159265358979323846
23#endif
24
25namespace y2017 {
26namespace constants {
27
Tyler Chatow6107aba2017-01-22 01:39:40 +000028const int Values::kZeroingSampleSize;
29
Brian Silverman052e69d2017-02-12 16:19:55 -080030constexpr double Values::kDrivetrainCyclesPerRevolution,
31 Values::kDrivetrainEncoderCountsPerRevolution,
32 Values::kDrivetrainEncoderRatio,
33 Values::kMaxDrivetrainEncoderPulsesPerSecond;
Brian Silvermandb8498a2017-02-11 17:16:09 -080034
Brian Silverman052e69d2017-02-12 16:19:55 -080035constexpr double Values::kShooterEncoderCountsPerRevolution,
36 Values::kShooterEncoderRatio, Values::kMaxShooterEncoderPulsesPerSecond;
Brian Silvermandb8498a2017-02-11 17:16:09 -080037
Brian Silverman052e69d2017-02-12 16:19:55 -080038constexpr double Values::kIntakeEncoderCountsPerRevolution,
39 Values::kIntakeEncoderRatio, Values::kIntakePotRatio,
40 Values::kIntakeEncoderIndexDifference,
41 Values::kMaxIntakeEncoderPulsesPerSecond;
Brian Silvermandb8498a2017-02-11 17:16:09 -080042constexpr ::frc971::constants::Range Values::kIntakeRange;
43
Brian Silverman052e69d2017-02-12 16:19:55 -080044constexpr double Values::kHoodEncoderCountsPerRevolution,
Brian Silverman7cce2d32017-02-19 21:48:48 -080045 Values::kHoodEncoderRatio, Values::kHoodEncoderIndexDifference,
46 Values::kMaxHoodEncoderPulsesPerSecond;
Brian Silvermandb8498a2017-02-11 17:16:09 -080047constexpr ::frc971::constants::Range Values::kHoodRange;
48
Brian Silverman052e69d2017-02-12 16:19:55 -080049constexpr double Values::kTurretEncoderCountsPerRevolution,
Brianef030df2017-03-05 15:06:04 -080050 Values::kTurretEncoderRatio, Values::kMaxTurretEncoderPulsesPerSecond;
Austin Schuhd5ccb862017-03-11 22:06:36 -080051constexpr ::frc971::constants::Range Values::kTurretRange;
Brian Silvermandb8498a2017-02-11 17:16:09 -080052
Brianef030df2017-03-05 15:06:04 -080053constexpr double Values::kIndexerEncoderCountsPerRevolution,
Brian Silverman052e69d2017-02-12 16:19:55 -080054 Values::kIndexerEncoderRatio, Values::kIndexerEncoderIndexDifference,
55 Values::kMaxIndexerEncoderPulsesPerSecond;
Tyler Chatow6107aba2017-01-22 01:39:40 +000056
57namespace {
Brian Silvermandb8498a2017-02-11 17:16:09 -080058
Tyler Chatow6107aba2017-01-22 01:39:40 +000059const uint16_t kCompTeamNumber = 971;
60const uint16_t kPracticeTeamNumber = 9971;
61
Tyler Chatow6107aba2017-01-22 01:39:40 +000062const Values *DoGetValuesForTeam(uint16_t team) {
Brian Silvermandb8498a2017-02-11 17:16:09 -080063 Values *const r = new Values();
64 Values::Intake *const intake = &r->intake;
Brian Silvermandb8498a2017-02-11 17:16:09 -080065 Values::Hood *const hood = &r->hood;
Austin Schuh55934032017-03-11 12:45:27 -080066 Values::Column *const column = &r->column;
Philipp Schrader9a833362017-04-09 22:56:16 +000067 auto shot_interpolation_table = &r->shot_interpolation_table;
Brian Silvermandb8498a2017-02-11 17:16:09 -080068
69 r->drivetrain_max_speed = 5;
70
71 intake->zeroing.average_filter_size = Values::kZeroingSampleSize;
Adam Snaider79900c22017-02-08 20:23:15 -080072 intake->zeroing.one_revolution_distance = Values::kIntakeEncoderIndexDifference;
Austin Schuh0fc1e6d2017-02-21 02:04:10 -080073 intake->zeroing.zeroing_threshold = 0.0005;
74 intake->zeroing.moving_buffer_size = 20;
Austin Schuh53a2c452017-03-22 21:18:20 -070075 intake->zeroing.allowable_encoder_error = 1.9;
Brian Silvermandb8498a2017-02-11 17:16:09 -080076
Austin Schuhd5ccb862017-03-11 22:06:36 -080077 column->turret_zeroed_distance = M_PI / 2.0;
Austin Schuh55934032017-03-11 12:45:27 -080078 column->indexer_zeroing.index_difference = 2.0 * M_PI;
Austin Schuhd5ccb862017-03-11 22:06:36 -080079 column->indexer_zeroing.hall_trigger_zeroing_length = 2;
80 column->indexer_zeroing.zeroing_move_direction = true;
Austin Schuh55934032017-03-11 12:45:27 -080081 column->turret_zeroing.index_difference = 2.0 * M_PI;
Austin Schuhd5ccb862017-03-11 22:06:36 -080082 column->turret_zeroing.hall_trigger_zeroing_length = 2;
83 column->turret_zeroing.zeroing_move_direction = false;
Austin Schuh55934032017-03-11 12:45:27 -080084
Austin Schuh6a90cd92017-02-19 20:55:33 -080085 hood->zeroing.index_pulse_count = 2;
Brian Silvermandb8498a2017-02-11 17:16:09 -080086 hood->zeroing.index_difference = Values::kHoodEncoderIndexDifference;
Austin Schuh6a90cd92017-02-19 20:55:33 -080087 hood->zeroing.known_index_pulse = 0;
Brian Silvermandb8498a2017-02-11 17:16:09 -080088
Philipp Schrader9a833362017-04-09 22:56:16 +000089 // TODO(phil): Should these be different per robot?
90 *shot_interpolation_table =
Parker Schuh94d56792017-04-13 20:32:50 -070091 ::frc971::shooter_interpolation::InterpolationTable<Values::ShotParams>(
Philipp Schrader9a833362017-04-09 22:56:16 +000092 {// { distance_to_target, { shot_angle, shot_power }},
Parker Schuh94d56792017-04-13 20:32:50 -070093 {1.67, {0.31, 320.0, -2.25 * M_PI}},
94 {1.90, {0.33, 330.0, -2.25 * M_PI}},
95 {2.15, {0.33, 347.0, -2.25 * M_PI}},
96 {2.45, {0.33, 361.0, -2.25 * M_PI}},
Philipp Schrader9a833362017-04-09 22:56:16 +000097 });
98
Tyler Chatow6107aba2017-01-22 01:39:40 +000099 switch (team) {
Brian Silvermandb8498a2017-02-11 17:16:09 -0800100 // A set of constants for tests.
101 case 1:
102 intake->pot_offset = 0;
Austin Schuh6a90cd92017-02-19 20:55:33 -0800103 intake->zeroing.measured_absolute_position = 0;
104
Austin Schuhd5ccb862017-03-11 22:06:36 -0800105 // TODO(austin): Swap the turret and indexer limits and make sure the
106 // tests still pass.
107 column->indexer_zeroing.lower_hall_position = 0.1;
108 column->indexer_zeroing.upper_hall_position = 0.2;
Austin Schuh55934032017-03-11 12:45:27 -0800109
Austin Schuhd5ccb862017-03-11 22:06:36 -0800110 column->turret_zeroing.lower_hall_position = 2;
111 column->turret_zeroing.upper_hall_position = 2.1;
Austin Schuh55934032017-03-11 12:45:27 -0800112
Brian Silvermandb8498a2017-02-11 17:16:09 -0800113 hood->pot_offset = 0.1;
Austin Schuh6a90cd92017-02-19 20:55:33 -0800114 hood->zeroing.measured_index_position = 0.05;
115
Brian Silvermandb8498a2017-02-11 17:16:09 -0800116 r->down_error = 0;
117 r->vision_name = "test";
Austin Schuheb5c22e2017-04-09 18:30:28 -0700118 r->vision_error = -0.030;
Tyler Chatow6107aba2017-01-22 01:39:40 +0000119 break;
120
121 case kCompTeamNumber:
Austin Schuh52f80532017-04-05 19:22:30 -0700122 intake->pot_offset = 0.26712 + 0.0035 + 0.033 + 0.0011 -0.046872;
123 intake->zeroing.measured_absolute_position = 0.003397;
Austin Schuh23cc9ed2017-02-24 19:14:06 -0800124
Austin Schuh53a2c452017-03-22 21:18:20 -0700125 column->indexer_zeroing.lower_hall_position = 5.201948;
126 column->indexer_zeroing.upper_hall_position = 5.508744;
Austin Schuh55934032017-03-11 12:45:27 -0800127
Austin Schuh53a2c452017-03-22 21:18:20 -0700128 column->turret_zeroing.lower_hall_position = -4.861087;
129 column->turret_zeroing.upper_hall_position = -4.680861;
Austin Schuh55934032017-03-11 12:45:27 -0800130
Austin Schuh52f80532017-04-05 19:22:30 -0700131 hood->zeroing.measured_index_position = 0.234766;
Austin Schuh23cc9ed2017-02-24 19:14:06 -0800132
133 r->down_error = 0;
134 r->vision_name = "competition";
Austin Schuh25db1262017-04-05 19:39:55 -0700135 r->vision_error = 0.015;
Austin Schuh23cc9ed2017-02-24 19:14:06 -0800136 break;
137
138 case kPracticeTeamNumber:
Austin Schuhc74e9b62017-04-09 18:27:40 -0700139 intake->pot_offset = 0.2921 + 0.00039 + 0.012236 - 0.023602 + 0.010722 +
140 0.012880 - 0.01743;
141 intake->zeroing.measured_absolute_position = 0.043179;
Austin Schuh6a90cd92017-02-19 20:55:33 -0800142
Austin Schuhc74e9b62017-04-09 18:27:40 -0700143 column->indexer_zeroing.lower_hall_position = 2.594181;
144 column->indexer_zeroing.upper_hall_position = 2.886952;
Austin Schuh55934032017-03-11 12:45:27 -0800145
Austin Schuhc74e9b62017-04-09 18:27:40 -0700146 column->turret_zeroing.lower_hall_position = -4.918530;
147 column->turret_zeroing.upper_hall_position = -4.720353;
Austin Schuh55934032017-03-11 12:45:27 -0800148
Austin Schuhc74e9b62017-04-09 18:27:40 -0700149 hood->zeroing.measured_index_position = 0.124275;
Austin Schuh6a90cd92017-02-19 20:55:33 -0800150
Brian Silvermandb8498a2017-02-11 17:16:09 -0800151 r->down_error = 0;
Brian Silvermandb8498a2017-02-11 17:16:09 -0800152 r->vision_name = "practice";
Austin Schuh25db1262017-04-05 19:39:55 -0700153 r->vision_error = 0.0;
Tyler Chatow6107aba2017-01-22 01:39:40 +0000154 break;
155
156 default:
157 LOG(FATAL, "unknown team #%" PRIu16 "\n", team);
158 }
Brian Silvermandb8498a2017-02-11 17:16:09 -0800159
160 return r;
Tyler Chatow6107aba2017-01-22 01:39:40 +0000161}
162
163const Values *DoGetValues() {
164 uint16_t team = ::aos::network::GetTeamNumber();
165 LOG(INFO, "creating a Constants for team %" PRIu16 "\n", team);
166 return DoGetValuesForTeam(team);
167}
168
169} // namespace
170
171const Values &GetValues() {
172 static ::aos::Once<const Values> once(DoGetValues);
173 return *once.Get();
174}
175
176const Values &GetValuesForTeam(uint16_t team_number) {
177 static ::aos::Mutex mutex;
178 ::aos::MutexLocker locker(&mutex);
179
180 // IMPORTANT: This declaration has to stay after the mutex is locked to avoid
181 // race conditions.
182 static ::std::map<uint16_t, const Values *> values;
183
184 if (values.count(team_number) == 0) {
185 values[team_number] = DoGetValuesForTeam(team_number);
186#if __has_feature(address_sanitizer)
187 __lsan_ignore_object(values[team_number]);
188#endif
189 }
190 return *values[team_number];
191}
192
Parker Schuh94d56792017-04-13 20:32:50 -0700193Values::ShotParams Values::ShotParams::BlendY(double coefficient, Values::ShotParams a1, Values::ShotParams a2) {
194 using ::frc971::shooter_interpolation::Blend;
195 return Values::ShotParams{Blend(coefficient, a1.angle, a2.angle),
196 Blend(coefficient, a1.power, a2.power),
197 Blend(coefficient, a1.indexer_velocity, a2.indexer_velocity)};
198}
199
Tyler Chatow6107aba2017-01-22 01:39:40 +0000200} // namespace constants
201} // namespace y2017