blob: 44f07262e91c643dffa967adc427c7aa27ad27c4 [file] [log] [blame]
Austin Schuh2a3e0632018-02-19 16:24:49 -08001#ifndef Y2018_CONSTANTS_H_
2#define Y2018_CONSTANTS_H_
3
4#include <stdint.h>
5#include <math.h>
6
7#include "frc971/constants.h"
8
9#include "y2018/control_loops/drivetrain/drivetrain_dog_motor_plant.h"
10#include "y2018/control_loops/superstructure/arm/dynamics.h"
11#include "y2018/control_loops/superstructure/intake/intake_plant.h"
12
13namespace y2018 {
14namespace constants {
15
16// Has all of our "constants", except the ones that come from other places. The
17// ones which change between robots are put together with a workable way to
18// retrieve the values for the current robot.
19
20// Everything is in SI units (volts, radians, meters, seconds, etc).
21// Some of these values are related to the conversion between raw values
22// (encoder counts, voltage, etc) to scaled units (radians, meters, etc).
23//
24// All ratios are from the encoder shaft to the output units.
25
26struct Values {
Sabina Davis8d20ca82018-02-19 13:17:45 -080027 static constexpr size_t kZeroingSampleSize() { return 200; }
Austin Schuh2a3e0632018-02-19 16:24:49 -080028
29 static constexpr double kDrivetrainCyclesPerRevolution() { return 512.0; }
30 static constexpr double kDrivetrainEncoderCountsPerRevolution() {
31 return kDrivetrainCyclesPerRevolution() * 4;
32 }
33 static constexpr double kDrivetrainEncoderRatio() {
34 return (20.0 / 48.0) * (30.0 / 36.0);
35 }
36 static constexpr double kMaxDrivetrainEncoderPulsesPerSecond() {
37 return control_loops::drivetrain::kFreeSpeed / (2.0 * M_PI) *
38 control_loops::drivetrain::kHighOutputRatio /
39 constants::Values::kDrivetrainEncoderRatio() *
40 kDrivetrainEncoderCountsPerRevolution();
41 }
42
Austin Schuh17dd0892018-03-02 20:06:31 -080043 static constexpr double kDrivetrainShifterPotMaxVoltage() { return 3.63; }
44 static constexpr double kDrivetrainShifterPotMinVoltage() { return 1.94; }
Austin Schuh2a3e0632018-02-19 16:24:49 -080045
46 static constexpr double kProximalEncoderCountsPerRevolution() { return 4096.0; }
47 static constexpr double kProximalEncoderRatio() {
48 return (12.0 / 60.0) * (18.0 / 84.0);
49 }
50 static constexpr double kMaxProximalEncoderPulsesPerSecond() {
51 return control_loops::superstructure::arm::Dynamics::kFreeSpeed /
52 (2.0 * M_PI) / control_loops::superstructure::arm::Dynamics::kG1 /
53 kProximalEncoderRatio() * kProximalEncoderCountsPerRevolution();
54 }
55 static constexpr double kProximalPotRatio() { return (12.0 / 60.0); }
56
57 static constexpr double kDistalEncoderCountsPerRevolution() { return 4096.0; }
58 static constexpr double kDistalEncoderRatio() { return (12.0 / 60.0); }
59 static constexpr double kMaxDistalEncoderPulsesPerSecond() {
60 return control_loops::superstructure::arm::Dynamics::kFreeSpeed /
61 (2.0 * M_PI) / control_loops::superstructure::arm::Dynamics::kG2 /
62 kDistalEncoderRatio() * kProximalEncoderCountsPerRevolution();
63 }
64 static constexpr double kDistalPotRatio() {
65 return (12.0 / 60.0) * (36.0 / 40.0);
66 }
67
68 static constexpr double kIntakeSpringRatio() {
69 return (10.0 * 0.080) / (2.0 * 1.5 * M_PI);
70 }
Austin Schuh6829f762018-03-02 21:36:01 -080071 static constexpr double kIntakeMotorEncoderCountsPerRevolution() {
72 return 4096.0;
73 }
Austin Schuh2a3e0632018-02-19 16:24:49 -080074 static constexpr double kIntakeMotorEncoderRatio() {
75 return (18.0 / 68.0) * (18.0 / 50.0);
76 }
77 static constexpr double kIntakeMotorPotRatio() { return (14.0 / 68.0); }
78 static constexpr double kMaxIntakeMotorEncoderPulsesPerSecond() {
79 return control_loops::superstructure::intake::kFreeSpeed / (2.0 * M_PI) *
80 control_loops::superstructure::intake::kGearRatio /
81 kIntakeMotorEncoderRatio() *
82 kIntakeMotorEncoderCountsPerRevolution();
83 }
84
Sabina Davis8d20ca82018-02-19 13:17:45 -080085 static constexpr ::frc971::constants::Range kIntakeRange() {
Austin Schuh6829f762018-03-02 21:36:01 -080086 // TODO(austin) Sort this out.
Austin Schuhf88d3ac2018-03-05 00:26:36 -080087 return ::frc971::constants::Range{-3.7, (1.25 * M_PI),
88 -3.3, M_PI};
Sabina Davis8d20ca82018-02-19 13:17:45 -080089 }
90
91 struct IntakeSide {
92 ::frc971::constants::PotAndAbsoluteEncoderZeroingConstants zeroing;
93 double potentiometer_offset;
94 double spring_offset;
Austin Schuh2a3e0632018-02-19 16:24:49 -080095 };
Sabina Davis8d20ca82018-02-19 13:17:45 -080096 IntakeSide left_intake;
97 IntakeSide right_intake;
Austin Schuh2a3e0632018-02-19 16:24:49 -080098
99 struct Proximal {
Sabina Davis8d20ca82018-02-19 13:17:45 -0800100 ::frc971::constants::PotAndAbsoluteEncoderZeroingConstants zeroing;
101 double potentiometer_offset;
Austin Schuh2a3e0632018-02-19 16:24:49 -0800102 };
Austin Schuhcb091712018-02-21 20:01:55 -0800103 Proximal arm_proximal;
Austin Schuh2a3e0632018-02-19 16:24:49 -0800104
105 struct Distal {
Sabina Davis8d20ca82018-02-19 13:17:45 -0800106 ::frc971::constants::PotAndAbsoluteEncoderZeroingConstants zeroing;
107 double potentiometer_offset;
Austin Schuh2a3e0632018-02-19 16:24:49 -0800108 };
Austin Schuhcb091712018-02-21 20:01:55 -0800109 Distal arm_distal;
Austin Schuh2a3e0632018-02-19 16:24:49 -0800110
Austin Schuh2a3e0632018-02-19 16:24:49 -0800111 const char *vision_name;
112
113 double vision_error;
114};
115
116// Creates (once) a Values instance for ::aos::network::GetTeamNumber() and
117// returns a reference to it.
118const Values &GetValues();
119
120// Creates Values instances for each team number it is called with and returns
121// them.
122const Values &GetValuesForTeam(uint16_t team_number);
123
124} // namespace constants
125} // namespace y2018
126
127#endif // Y2018_CONSTANTS_H_