blob: 6f79b6b554ef2636491407cf5eb4a1c77addea36 [file] [log] [blame]
Stephan Massaltd021f972020-01-05 20:41:23 -08001#include "y2020/constants.h"
2
3#include <inttypes.h>
4
5#include <map>
6
7#if __has_feature(address_sanitizer)
8#include "sanitizer/lsan_interface.h"
9#endif
10
11#include "absl/base/call_once.h"
12#include "aos/logging/logging.h"
13#include "aos/mutex/mutex.h"
14#include "aos/network/team_number.h"
Sabina Davisa587fbd2020-01-31 22:11:15 -080015#include "y2020/control_loops/superstructure/hood/integral_hood_plant.h"
Kai Tinkess10943cf2020-02-01 15:49:57 -080016#include "y2020/control_loops/superstructure/intake/integral_intake_plant.h"
17#include "y2020/control_loops/superstructure/turret/integral_turret_plant.h"
Sabina Davisa587fbd2020-01-31 22:11:15 -080018
Stephan Massaltd021f972020-01-05 20:41:23 -080019namespace y2020 {
20namespace constants {
21
22const int Values::kZeroingSampleSize;
23
24namespace {
25
26const uint16_t kCompTeamNumber = 971;
27const uint16_t kPracticeTeamNumber = 9971;
28const uint16_t kCodingRobotTeamNumber = 7971;
29
30const Values *DoGetValuesForTeam(uint16_t team) {
31 Values *const r = new Values();
Sabina Davisa587fbd2020-01-31 22:11:15 -080032 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
33 ::frc971::zeroing::AbsoluteEncoderZeroingEstimator> *const hood =
34 &r->hood;
35
36 // Hood constants.
37 hood->zeroing_voltage = 3.0;
38 hood->operating_voltage = 12.0;
39 hood->zeroing_profile_params = {0.5, 3.0};
40 hood->default_profile_params = {6.0, 30.0};
41 hood->range = Values::kHoodRange();
42 hood->make_integral_loop =
43 control_loops::superstructure::hood::MakeIntegralHoodLoop;
44 hood->zeroing_constants.average_filter_size = Values::kZeroingSampleSize;
45 hood->zeroing_constants.one_revolution_distance =
46 M_PI * 2.0 * constants::Values::kHoodEncoderRatio();
47 hood->zeroing_constants.zeroing_threshold = 0.0005;
48 hood->zeroing_constants.moving_buffer_size = 20;
49 hood->zeroing_constants.allowable_encoder_error = 0.9;
50 hood->zeroing_constants.middle_position = Values::kHoodRange().middle();
Stephan Massaltd021f972020-01-05 20:41:23 -080051
Sabina Davise8d38992020-02-02 15:00:31 -080052 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
53 ::frc971::zeroing::AbsoluteEncoderZeroingEstimator> *const intake =
54 &r->intake;
55
56 // Intake constants.
57 intake->zeroing_voltage = 3.0;
58 intake->operating_voltage = 12.0;
59 intake->zeroing_profile_params = {0.5, 3.0};
60 intake->default_profile_params = {6.0, 30.0};
61 intake->range = Values::kIntakeRange();
62 intake->make_integral_loop =
63 control_loops::superstructure::intake::MakeIntegralIntakeLoop;
64 intake->zeroing_constants.average_filter_size = Values::kZeroingSampleSize;
65 intake->zeroing_constants.one_revolution_distance =
66 M_PI * 2.0 * constants::Values::kIntakeEncoderRatio();
67 intake->zeroing_constants.zeroing_threshold = 0.0005;
68 intake->zeroing_constants.moving_buffer_size = 20;
69 intake->zeroing_constants.allowable_encoder_error = 0.9;
70 intake->zeroing_constants.middle_position = Values::kIntakeRange().middle();
71
Kai Tinkess10943cf2020-02-01 15:49:57 -080072 Values::PotAndAbsEncoderConstants *const turret = &r->turret;
73 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
74 ::frc971::zeroing::PotAndAbsoluteEncoderZeroingEstimator>
75 *const turret_params = &turret->subsystem_params;
76
77 //Turret Constants
78 turret_params->zeroing_voltage = 4.0;
79 turret_params->operating_voltage = 12.0;
80 // TODO(austin): Tune these.
81 turret_params->zeroing_profile_params = {0.5, 2.0};
82 turret_params->default_profile_params = {15.0, 40.0};
83 turret_params->range = Values::kTurretRange();
84 turret_params->make_integral_loop =
85 &control_loops::superstructure::turret::MakeIntegralTurretLoop;
86 turret_params->zeroing_constants.average_filter_size =
87 Values::kZeroingSampleSize;
88 turret_params->zeroing_constants.one_revolution_distance =
89 M_PI * 2.0 * constants::Values::kTurretEncoderRatio();
90 turret_params->zeroing_constants.zeroing_threshold = 0.0005;
91 turret_params->zeroing_constants.moving_buffer_size = 20;
92 turret_params->zeroing_constants.allowable_encoder_error = 0.9;
93
Stephan Massaltd021f972020-01-05 20:41:23 -080094 switch (team) {
95 // A set of constants for tests.
96 case 1:
97 break;
98
99 case kCompTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800100 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800101
Sabina Davise8d38992020-02-02 15:00:31 -0800102 intake->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800103
104 turret->potentiometer_offset = 0.0;
105 turret_params->zeroing_constants.measured_absolute_position = 0.0;
Stephan Massaltd021f972020-01-05 20:41:23 -0800106 break;
107
108 case kPracticeTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800109 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800110
Sabina Davise8d38992020-02-02 15:00:31 -0800111 intake->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800112
113 turret->potentiometer_offset = 0.0;
114 turret_params->zeroing_constants.measured_absolute_position = 0.0;
Stephan Massaltd021f972020-01-05 20:41:23 -0800115 break;
116
117 case kCodingRobotTeamNumber:
Sabina Davisa587fbd2020-01-31 22:11:15 -0800118 hood->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800119
Sabina Davise8d38992020-02-02 15:00:31 -0800120 intake->zeroing_constants.measured_absolute_position = 0.0;
Kai Tinkess10943cf2020-02-01 15:49:57 -0800121
122 turret->potentiometer_offset = 0.0;
123 turret_params->zeroing_constants.measured_absolute_position = 0.0;
Stephan Massaltd021f972020-01-05 20:41:23 -0800124 break;
125
126 default:
127 AOS_LOG(FATAL, "unknown team #%" PRIu16 "\n", team);
128 }
129
130 return r;
131}
132
133void DoGetValues(const Values **result) {
134 uint16_t team = ::aos::network::GetTeamNumber();
135 AOS_LOG(INFO, "creating a Constants for team %" PRIu16 "\n", team);
136 *result = DoGetValuesForTeam(team);
137}
138
139} // namespace
140
141const Values &GetValues() {
142 static absl::once_flag once;
143 static const Values *result;
144 absl::call_once(once, DoGetValues, &result);
145 return *result;
146}
147
148const Values &GetValuesForTeam(uint16_t team_number) {
149 static ::aos::Mutex mutex;
150 ::aos::MutexLocker locker(&mutex);
151
152 // IMPORTANT: This declaration has to stay after the mutex is locked to avoid
153 // race conditions.
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 y2020