blob: 3e7b4c77a7ac252915d2e44e4872443b0242f7d7 [file] [log] [blame]
Brian Silverman431500a2013-10-28 19:50:15 -07001#include "frc971/constants.h"
2
3#include <math.h>
4#include <stdint.h>
5#include <inttypes.h>
6
Brian Silverman0a151c92014-05-02 15:28:44 -07007#include <map>
8
9#if __has_feature(address_sanitizer)
10#include "sanitizer/lsan_interface.h"
11#endif
12
Brian Silverman431500a2013-10-28 19:50:15 -070013#include "aos/common/logging/logging.h"
14#include "aos/common/once.h"
15#include "aos/common/network/team_number.h"
Brian Silverman0a151c92014-05-02 15:28:44 -070016#include "aos/common/mutex.h"
Brian Silverman431500a2013-10-28 19:50:15 -070017
Brian Silverman2c590c32013-11-04 18:08:54 -080018#include "frc971/control_loops/drivetrain/polydrivetrain_dog_motor_plant.h"
Brian Silverman2c590c32013-11-04 18:08:54 -080019#include "frc971/control_loops/drivetrain/drivetrain_dog_motor_plant.h"
Brian Silverman2c590c32013-11-04 18:08:54 -080020
Brian Silverman431500a2013-10-28 19:50:15 -070021#ifndef M_PI
22#define M_PI 3.14159265358979323846
23#endif
24
25namespace frc971 {
26namespace constants {
27namespace {
28
Brian Silvermane5db0c62014-03-13 15:53:18 -070029const uint16_t kCompTeamNumber = 971;
Brian Silvermana20703b2014-03-20 14:29:37 -070030const uint16_t kPracticeTeamNumber = 9971;
Comran Morshed79bd3db2015-02-07 14:51:13 +000031
32// ///// Drivetrain Constants
Brian Silvermane5db0c62014-03-13 15:53:18 -070033
Daniel Pettia7827412015-02-13 20:55:57 -080034// These three constants were set by Daniel on 2/13/15.
35const double kDrivetrainEncoderRatio = 20.0 / 64.0;
36const double kLowGearRatio = kDrivetrainEncoderRatio * 20.0 / 50.0;
37const double kHighGearRatio = kLowGearRatio;
Brian Silverman1a6590d2013-11-04 14:46:46 -080038
Brian Silvermane5db0c62014-03-13 15:53:18 -070039const ShifterHallEffect kCompRightDriveShifter{555, 657, 660, 560, 0.2, 0.7};
40const ShifterHallEffect kCompLeftDriveShifter{555, 660, 644, 552, 0.2, 0.7};
Brian Silverman6eb51f12013-11-02 14:39:01 -070041
Austin Schuh010eb812014-10-25 18:06:49 -070042const ShifterHallEffect kPracticeRightDriveShifter{2.95, 3.95, 3.95, 2.95, 0.2, 0.7};
43const ShifterHallEffect kPracticeLeftDriveShifter{2.95, 4.2, 3.95, 3.0, 0.2, 0.7};
Brian Silvermane5db0c62014-03-13 15:53:18 -070044
Daniel Pettia7827412015-02-13 20:55:57 -080045// Set by Daniel on 2/13/15.
46// Distance from the center of the left wheel to the center of the right wheel.
47const double kRobotWidth = 37.806 /*inches*/ * 0.0254;
Brian Silverman6eb51f12013-11-02 14:39:01 -070048
Comran Morshed79bd3db2015-02-07 14:51:13 +000049// ///// Superstructure Constants
50
Comran Morshed79bd3db2015-02-07 14:51:13 +000051// Elevator gearbox pulley output constants.
52const int kElevatorGearboxOutputPulleyTeeth = 32; // 32 teeth
53const double kElevatorGearboxOutputPitch = 0.005; // 5 mm/tooth
Daniel Pettia7827412015-02-13 20:55:57 -080054const double kElevatorGearboxOutputRadianDistance =
55 kElevatorGearboxOutputPulleyTeeth * kElevatorGearboxOutputPitch /
56 (2.0 * M_PI);
Comran Morshed79bd3db2015-02-07 14:51:13 +000057
Austin Schuhdbd6bfa2015-02-14 21:25:16 -080058const double kMaxAllowedLeftRightArmDifference = 0.04; // radians
Austin Schuh703b8d42015-02-01 14:56:34 -080059const double kMaxAllowedLeftRightElevatorDifference = 0.01; // meters
60
Daniel Pettia7827412015-02-13 20:55:57 -080061// Gearing ratios of the pots and encoders for the elevator and arm.
62// Ratio is output shaft rotations per encoder/pot rotation
63// Checked by Daniel on 2/13/15.
64const double kArmEncoderRatio = 18.0 / 48.0 * 16.0 / 72.0;
65const double kArmPotRatio = 48.0 / 48.0 * 16.0 / 72.0;
66const double kElevatorEncoderRatio = 14.0 / 84.0;
67const double kElevatorPotRatio = 1.0;
68const double kClawEncoderRatio = 18.0 / 72.0;
69const double kClawPotRatio = 18.0 / 72.0;
70
Comran Morshed79bd3db2015-02-07 14:51:13 +000071// Number of radians between each index pulse on the arm.
Daniel Pettia7827412015-02-13 20:55:57 -080072const double kArmEncoderIndexDifference = 2.0 * M_PI * kArmEncoderRatio;
73// Number of meters between each index pulse on the elevator.
Comran Morshed79bd3db2015-02-07 14:51:13 +000074const double kElevatorEncoderIndexDifference =
Daniel Pettia7827412015-02-13 20:55:57 -080075 kElevatorEncoderRatio *
76 2.0 * M_PI * // radians
77 kElevatorGearboxOutputRadianDistance;
78// Number of radians between index pulses on the claw.
Comran Morshed79bd3db2015-02-07 14:51:13 +000079const double kClawEncoderIndexDifference = 2.0 * M_PI * kClawEncoderRatio;
80
81const int kZeroingSampleSize = 20;
Brian Silvermanedcfd2d2014-04-03 13:04:16 -070082
Ben Fredricksona9dcfa42014-02-23 02:05:59 +000083const Values *DoGetValuesForTeam(uint16_t team) {
Brian Silverman431500a2013-10-28 19:50:15 -070084 switch (team) {
Brian Silverman0d2b7cb2014-02-18 20:25:57 -080085 case 1: // for tests
86 return new Values{
Daniel Pettia7827412015-02-13 20:55:57 -080087 kDrivetrainEncoderRatio,
88 kArmEncoderRatio,
89 kArmPotRatio,
90 kElevatorEncoderRatio,
91 kElevatorPotRatio,
92 kElevatorGearboxOutputRadianDistance,
93 kClawEncoderRatio,
94 kClawPotRatio,
95 kLowGearRatio,
96 kHighGearRatio,
Brian Silverman0d2b7cb2014-02-18 20:25:57 -080097 kCompLeftDriveShifter,
98 kCompRightDriveShifter,
Austin Schuh11726212014-03-02 14:01:02 -080099 false,
Brian Silvermanad9e0002014-04-13 14:55:57 -0700100 0.5,
Austin Schuha25a0412014-03-09 00:50:04 -0800101 control_loops::MakeVelocityDrivetrainLoop,
102 control_loops::MakeDrivetrainLoop,
Comran Morshed79bd3db2015-02-07 14:51:13 +0000103 0.02, // drivetrain done delta
104 5.0, // drivetrain max speed
105
Comran Morshed79bd3db2015-02-07 14:51:13 +0000106 // Motion ranges: hard_lower_limit, hard_upper_limit,
107 // soft_lower_limit, soft_upper_limit
108 // TODO(sensors): Get actual bounds before turning on robot.
109 {
110 // Claw values, in radians.
111 // 0 is level with the ground.
112 // Positive moves in the direction of positive encoder values.
113 {0.0000000000, 1.5700000000,
Daniel Pettia7827412015-02-13 20:55:57 -0800114 0.1000000000, 1.2000000000},
115
116 // Zeroing constants for wrist.
117 // TODO(sensors): Get actual offsets for these.
118 {kZeroingSampleSize, kClawEncoderIndexDifference, 0.0},
Brian Silverman5d712fc2015-02-15 03:39:31 -0500119 0.0,
James Kuszmaul9ead1de2014-02-28 21:24:39 -0800120 },
Comran Morshed79bd3db2015-02-07 14:51:13 +0000121
122 {
123 // Elevator values, in meters.
Austin Schuh703b8d42015-02-01 14:56:34 -0800124 // TODO(austin): Fix this. Positive is up.
Comran Morshed79bd3db2015-02-07 14:51:13 +0000125 // 0 is at the top of the elevator frame.
126 // Positive is down towards the drivebase.
127 {0.0000000000, 0.6790000000,
128 0.2000000000, 0.6000000000},
129
130 // Arm values, in radians.
131 // 0 is sticking straight out horizontally over the intake/front.
132 // Positive is rotating up and into the robot (towards the back).
Austin Schuh703b8d42015-02-01 14:56:34 -0800133 {-1.570000000, 1.5700000000,
Daniel Pettia7827412015-02-13 20:55:57 -0800134 -1.200000000, 1.2000000000},
135
136 // Elevator zeroing constants: left, right.
137 // TODO(sensors): Get actual offsets for these.
138 {kZeroingSampleSize, kElevatorEncoderIndexDifference, 0.0},
139 {kZeroingSampleSize, kElevatorEncoderIndexDifference, 0.0},
140 // Arm zeroing constants: left, right.
141 {kZeroingSampleSize, kArmEncoderIndexDifference, 0.0},
142 {kZeroingSampleSize, kArmEncoderIndexDifference, 0.0},
Brian Silverman5d712fc2015-02-15 03:39:31 -0500143 0.0, 0.0, 0.0, 0.0,
Austin Schuh703b8d42015-02-01 14:56:34 -0800144 },
Comran Morshed79bd3db2015-02-07 14:51:13 +0000145 // End "sensor" values.
Austin Schuh703b8d42015-02-01 14:56:34 -0800146
147 kMaxAllowedLeftRightArmDifference,
148 kMaxAllowedLeftRightElevatorDifference,
Brian Silverman0d2b7cb2014-02-18 20:25:57 -0800149 };
150 break;
Brian Silverman431500a2013-10-28 19:50:15 -0700151 case kCompTeamNumber:
Brian Silverman756f9ff2014-01-17 23:40:23 -0800152 return new Values{
Daniel Pettia7827412015-02-13 20:55:57 -0800153 kDrivetrainEncoderRatio,
154 kArmEncoderRatio,
155 kArmPotRatio,
156 kElevatorEncoderRatio,
157 kElevatorPotRatio,
158 kElevatorGearboxOutputRadianDistance,
159 kClawEncoderRatio,
160 kClawPotRatio,
161 kLowGearRatio,
162 kHighGearRatio,
Austin Schuh288c8c32014-02-16 17:20:17 -0800163 kCompLeftDriveShifter,
164 kCompRightDriveShifter,
Brian Silvermanedcfd2d2014-04-03 13:04:16 -0700165 false,
Brian Silvermanad9e0002014-04-13 14:55:57 -0700166 kRobotWidth,
Austin Schuha25a0412014-03-09 00:50:04 -0800167 control_loops::MakeVelocityDrivetrainLoop,
168 control_loops::MakeDrivetrainLoop,
Comran Morshed79bd3db2015-02-07 14:51:13 +0000169 0.02, // drivetrain done delta
170 5.0, // drivetrain max speed
171
Comran Morshed79bd3db2015-02-07 14:51:13 +0000172 // Motion ranges: hard_lower_limit, hard_upper_limit,
173 // soft_lower_limit, soft_upper_limit
174 // TODO(sensors): Get actual bounds before turning on robot.
175 {
176 // Claw values, in radians.
177 // 0 is level with the ground.
178 // Positive moves in the direction of positive encoder values.
179 {0.0000000000, 1.5700000000,
Daniel Pettia7827412015-02-13 20:55:57 -0800180 0.1000000000, 1.2000000000},
181
182 // Zeroing constants for wrist.
183 // TODO(sensors): Get actual offsets for these.
184 {kZeroingSampleSize, kClawEncoderIndexDifference, 0.0},
Brian Silverman5d712fc2015-02-15 03:39:31 -0500185 0.0,
James Kuszmaul9ead1de2014-02-28 21:24:39 -0800186 },
Comran Morshed79bd3db2015-02-07 14:51:13 +0000187
188 {
189 // Elevator values, in meters.
190 // 0 is at the top of the elevator frame.
191 // Positive is down towards the drivebase.
192 {0.0000000000, 0.6790000000,
193 0.2000000000, 0.6000000000},
194
195 // Arm values, in radians.
196 // 0 is sticking straight out horizontally over the intake/front.
197 // Positive is rotating up and into the robot (towards the back).
Austin Schuh703b8d42015-02-01 14:56:34 -0800198 {-1.570000000, 1.5700000000,
Daniel Pettia7827412015-02-13 20:55:57 -0800199 -1.200000000, 1.2000000000},
200
201 // Elevator zeroing constants: left, right.
202 // TODO(sensors): Get actual offsets for these.
203 {kZeroingSampleSize, kElevatorEncoderIndexDifference, 0.0},
204 {kZeroingSampleSize, kElevatorEncoderIndexDifference, 0.0},
205 // Arm zeroing constants: left, right.
206 {kZeroingSampleSize, kArmEncoderIndexDifference, 0.0},
207 {kZeroingSampleSize, kArmEncoderIndexDifference, 0.0},
Brian Silverman5d712fc2015-02-15 03:39:31 -0500208 0.0, 0.0, 0.0, 0.0,
Austin Schuh703b8d42015-02-01 14:56:34 -0800209 },
Comran Morshed79bd3db2015-02-07 14:51:13 +0000210 // End "sensor" values.
Austin Schuh703b8d42015-02-01 14:56:34 -0800211
212 kMaxAllowedLeftRightArmDifference,
213 kMaxAllowedLeftRightElevatorDifference,
Brian Silverman756f9ff2014-01-17 23:40:23 -0800214 };
Brian Silverman431500a2013-10-28 19:50:15 -0700215 break;
216 case kPracticeTeamNumber:
Brian Silverman756f9ff2014-01-17 23:40:23 -0800217 return new Values{
Daniel Pettia7827412015-02-13 20:55:57 -0800218 kDrivetrainEncoderRatio,
219 kArmEncoderRatio,
220 kArmPotRatio,
221 kElevatorEncoderRatio,
222 kElevatorPotRatio,
223 kElevatorGearboxOutputRadianDistance,
224 kClawEncoderRatio,
225 kClawPotRatio,
226 kLowGearRatio,
227 kHighGearRatio,
Austin Schuh288c8c32014-02-16 17:20:17 -0800228 kPracticeLeftDriveShifter,
229 kPracticeRightDriveShifter,
230 false,
Brian Silvermanad9e0002014-04-13 14:55:57 -0700231 kRobotWidth,
Austin Schuha25a0412014-03-09 00:50:04 -0800232 control_loops::MakeVelocityDrivetrainLoop,
233 control_loops::MakeDrivetrainLoop,
Comran Morshed79bd3db2015-02-07 14:51:13 +0000234 0.02, // drivetrain done delta
235 5.0, // drivetrain max speed
236
Comran Morshed79bd3db2015-02-07 14:51:13 +0000237 // Motion ranges: hard_lower_limit, hard_upper_limit,
238 // soft_lower_limit, soft_upper_limit
239 // TODO(sensors): Get actual bounds before turning on robot.
Austin Schuhbfb8b242015-02-16 15:45:22 -0800240 {// Claw values, in radians.
241 // 0 is level with the ground.
242 // Positive moves in the direction of positive encoder values.
243 {-0.05, M_PI / 2.0 + 0.1, 0.0, M_PI / 2.0},
Daniel Pettia7827412015-02-13 20:55:57 -0800244
Austin Schuhbfb8b242015-02-16 15:45:22 -0800245 // Zeroing constants for wrist.
246 // TODO(sensors): Get actual offsets for these.
247 {kZeroingSampleSize, kClawEncoderIndexDifference, 0.977913},
248 6.1663463999999992,
James Kuszmaul9ead1de2014-02-28 21:24:39 -0800249 },
Comran Morshed79bd3db2015-02-07 14:51:13 +0000250
Austin Schuhbfb8b242015-02-16 15:45:22 -0800251 {// Elevator values, in meters.
252 // 0 is at the top of the elevator frame.
253 // Positive is down towards the drivebase.
254 {-0.00500, 0.679000, 0.010000, 0.650000},
Comran Morshed79bd3db2015-02-07 14:51:13 +0000255
Austin Schuhbfb8b242015-02-16 15:45:22 -0800256 // Arm values, in radians.
257 // 0 is sticking straight out horizontally over the intake/front.
258 // Positive is rotating up and into the robot (towards the back).
259 {-M_PI / 2 - 0.05, M_PI / 2 + 0.05, -M_PI / 2, M_PI / 2},
Daniel Pettia7827412015-02-13 20:55:57 -0800260
Austin Schuhbfb8b242015-02-16 15:45:22 -0800261 // Elevator zeroing constants: left, right.
262 // TODO(sensors): Get actual offsets for these.
263 {kZeroingSampleSize, kElevatorEncoderIndexDifference, 0.016041 + 0.001290},
264 {kZeroingSampleSize, kElevatorEncoderIndexDifference, 0.011367 + 0.003216},
265 // Arm zeroing constants: left, right.
266 {kZeroingSampleSize, kArmEncoderIndexDifference, -0.312677},
267 {kZeroingSampleSize, kArmEncoderIndexDifference, -0.40855},
268 0.72069366666666679 - 0.026008,
269 -0.078959636363636357 - 0.024646,
270 -3.4952331578947375 + 0.011776,
271 3.5263507647058816 - 0.018921 + 0.006545,
Austin Schuh703b8d42015-02-01 14:56:34 -0800272 },
Comran Morshed79bd3db2015-02-07 14:51:13 +0000273 // TODO(sensors): End "sensor" values.
Austin Schuh703b8d42015-02-01 14:56:34 -0800274
275 kMaxAllowedLeftRightArmDifference,
276 kMaxAllowedLeftRightElevatorDifference,
Brian Silverman756f9ff2014-01-17 23:40:23 -0800277 };
Brian Silverman431500a2013-10-28 19:50:15 -0700278 break;
279 default:
280 LOG(FATAL, "unknown team #%" PRIu16 "\n", team);
281 }
282}
283
Ben Fredricksona9dcfa42014-02-23 02:05:59 +0000284const Values *DoGetValues() {
285 uint16_t team = ::aos::network::GetTeamNumber();
286 LOG(INFO, "creating a Constants for team %" PRIu16 "\n", team);
287 return DoGetValuesForTeam(team);
288}
289
Brian Silverman431500a2013-10-28 19:50:15 -0700290} // namespace
291
292const Values &GetValues() {
293 static ::aos::Once<const Values> once(DoGetValues);
294 return *once.Get();
295}
296
Ben Fredricksona9dcfa42014-02-23 02:05:59 +0000297const Values &GetValuesForTeam(uint16_t team_number) {
Brian Silverman0a151c92014-05-02 15:28:44 -0700298 static ::aos::Mutex mutex;
299 ::aos::MutexLocker locker(&mutex);
300
301 // IMPORTANT: This declaration has to stay after the mutex is locked to avoid
302 // race conditions.
303 static ::std::map<uint16_t, const Values *> values;
304
305 if (values.count(team_number) == 0) {
306 values[team_number] = DoGetValuesForTeam(team_number);
307#if __has_feature(address_sanitizer)
308 __lsan_ignore_object(values[team_number]);
309#endif
310 }
311 return *values[team_number];
Ben Fredricksona9dcfa42014-02-23 02:05:59 +0000312}
313
Brian Silverman431500a2013-10-28 19:50:15 -0700314} // namespace constants
315} // namespace frc971