blob: 7f9cd2504b8fe234117663e786c40d9d4c31e1b8 [file] [log] [blame]
#include "y2022/constants.h"
#include <cinttypes>
#include <map>
#if __has_feature(address_sanitizer)
#include "sanitizer/lsan_interface.h"
#endif
#include "absl/base/call_once.h"
#include "aos/mutex/mutex.h"
#include "aos/network/team_number.h"
#include "glog/logging.h"
#include "y2022/control_loops/superstructure/catapult/integral_catapult_plant.h"
#include "y2022/control_loops/superstructure/climber/integral_climber_plant.h"
#include "y2022/control_loops/superstructure/intake/integral_intake_plant.h"
#include "y2022/control_loops/superstructure/turret/integral_turret_plant.h"
namespace y2022 {
namespace constants {
const int Values::kZeroingSampleSize;
namespace {
const uint16_t kCompTeamNumber = 971;
const uint16_t kPracticeTeamNumber = 9971;
const uint16_t kCodingRobotTeamNumber = 7971;
} // namespace
Values MakeValues(uint16_t team) {
LOG(INFO) << "creating a Constants for team: " << team;
Values r;
// Intake constants.
auto *const intake_front = &r.intake_front;
auto *const intake_back = &r.intake_back;
::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
::frc971::zeroing::PotAndAbsoluteEncoderZeroingEstimator>
intake_params;
intake_params.zeroing_voltage = 3.0;
intake_params.operating_voltage = 12.0;
intake_params.zeroing_profile_params = {0.5, 3.0};
intake_params.default_profile_params = {6.0, 30.0};
intake_params.range = Values::kIntakeRange();
intake_params.make_integral_loop =
control_loops::superstructure::intake::MakeIntegralIntakeLoop;
intake_params.zeroing_constants.average_filter_size =
Values::kZeroingSampleSize;
intake_params.zeroing_constants.one_revolution_distance =
M_PI * 2.0 * constants::Values::kIntakeEncoderRatio();
intake_params.zeroing_constants.zeroing_threshold = 0.0005;
intake_params.zeroing_constants.moving_buffer_size = 20;
intake_params.zeroing_constants.allowable_encoder_error = 0.9;
intake_params.zeroing_constants.measured_absolute_position = 0.0;
intake_front->subsystem_params = intake_params;
intake_back->subsystem_params = intake_params;
// Turret constants.
auto *const turret = &r.turret;
auto *const turret_params = &turret->subsystem_params;
auto *turret_range = &r.turret_range;
*turret_range = ::frc971::constants::Range{
.lower_hard = -7.0, // Back Hard
.upper_hard = 3.4, // Front Hard
.lower = -6.5, // Back Soft
.upper = 3.15 // Front Soft
};
turret_params->zeroing_voltage = 4.0;
turret_params->operating_voltage = 12.0;
turret_params->zeroing_profile_params = {0.5, 2.0};
turret_params->default_profile_params = {10.0, 20.0};
turret_params->default_profile_params = {15.0, 20.0};
turret_params->range = *turret_range;
turret_params->make_integral_loop =
control_loops::superstructure::turret::MakeIntegralTurretLoop;
turret_params->zeroing_constants.average_filter_size =
Values::kZeroingSampleSize;
turret_params->zeroing_constants.one_revolution_distance =
M_PI * 2.0 * constants::Values::kTurretEncoderRatio();
turret_params->zeroing_constants.zeroing_threshold = 0.0005;
turret_params->zeroing_constants.moving_buffer_size = 20;
turret_params->zeroing_constants.allowable_encoder_error = 0.9;
turret_params->zeroing_constants.measured_absolute_position = 0.0;
// Climber constants
auto *const climber = &r.climber;
climber->subsystem_params.zeroing_voltage = 3.0;
climber->subsystem_params.operating_voltage = 12.0;
climber->subsystem_params.zeroing_profile_params = {0.5, 0.1};
climber->subsystem_params.default_profile_params = {5.0, 1.0};
climber->subsystem_params.range = Values::kClimberRange();
climber->subsystem_params.make_integral_loop =
control_loops::superstructure::climber::MakeIntegralClimberLoop;
// Flipper arm constants
Values::PotConstants flipper_arms;
flipper_arms.subsystem_params.zeroing_voltage = 3.0;
flipper_arms.subsystem_params.operating_voltage = 12.0;
flipper_arms.subsystem_params.zeroing_profile_params = {0.5, 0.1};
flipper_arms.subsystem_params.default_profile_params = {6.0, 1.0};
flipper_arms.subsystem_params.range = Values::kFlipperArmRange();
auto *const flipper_arm_right = &r.flipper_arm_right;
auto *const flipper_arm_left = &r.flipper_arm_left;
*flipper_arm_right = flipper_arms;
*flipper_arm_left = flipper_arms;
// No integral loops for flipper arms
// Catapult
Values::PotAndAbsEncoderConstants *const catapult = &r.catapult;
::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
::frc971::zeroing::PotAndAbsoluteEncoderZeroingEstimator>
*const catapult_params = &catapult->subsystem_params;
catapult_params->zeroing_voltage = 4.0;
catapult_params->operating_voltage = 12.0;
catapult_params->zeroing_profile_params = {0.5, 2.0};
catapult_params->default_profile_params = {15.0, 40.0};
catapult_params->range = Values::kCatapultRange();
catapult_params->make_integral_loop =
&control_loops::superstructure::catapult::MakeIntegralCatapultLoop;
catapult_params->zeroing_constants.average_filter_size =
Values::kZeroingSampleSize;
catapult_params->zeroing_constants.one_revolution_distance =
M_PI * 2.0 * constants::Values::kCatapultEncoderRatio();
catapult_params->zeroing_constants.zeroing_threshold = 0.0005;
catapult_params->zeroing_constants.moving_buffer_size = 20;
catapult_params->zeroing_constants.allowable_encoder_error = 0.9;
// Interpolation table for comp and practice robots
r.shot_interpolation_table = InterpolationTable<Values::ShotParams>({
{1.0, {0.0, 19.0}},
{1.6, {0.0, 19.0}},
{1.9, {0.1, 19.0}},
{2.12, {0.15, 18.8}},
{2.9, {0.25, 19.2}},
{3.2, {0.28, 20.3}},
{3.60, {0.33, 20.3}},
{4.9, {0.4, 21.9}},
{5.4, {0.4, 23.9}},
{6.0, {0.40, 25.0}},
{7.0, {0.37, 27.1}},
{7.8, {0.35, 28.0}},
{10.0, {0.35, 28.0}},
});
if (false) {
// 1.5 meters -> 2.7
// 2.3 meters -> 4.7
// 4.5 meters -> 7.0
// 7.0 meters -> 9.0
constexpr double kShotVelocity = 9.0;
r.shot_velocity_interpolation_table =
InterpolationTable<Values::ShotVelocityParams>({
{1.0, {kShotVelocity}},
{10.0, {kShotVelocity}},
});
} else {
r.shot_velocity_interpolation_table =
InterpolationTable<Values::ShotVelocityParams>({
{1.0, {2.7}},
{1.5, {2.7}},
{2.3, {4.7}},
{4.5, {7.0}},
{7.0, {9.0}},
{10.0, {9.0}},
});
}
switch (team) {
// A set of constants for tests.
case 1:
r.shot_interpolation_table = InterpolationTable<Values::ShotParams>({
{2, {0.08, 8.0}},
{5, {0.6, 10.0}},
});
r.shot_velocity_interpolation_table =
InterpolationTable<Values::ShotVelocityParams>({
{2, {2.0}},
{5, {4.0}},
});
climber->potentiometer_offset = 0.0;
intake_front->potentiometer_offset = 0.0;
intake_front->subsystem_params.zeroing_constants
.measured_absolute_position = 0.0;
intake_back->potentiometer_offset = 0.0;
intake_back->subsystem_params.zeroing_constants
.measured_absolute_position = 0.0;
turret->potentiometer_offset = 0.0;
turret->subsystem_params.zeroing_constants.measured_absolute_position =
0.0;
flipper_arm_left->potentiometer_offset = 0.0;
flipper_arm_right->potentiometer_offset = 0.0;
catapult_params->zeroing_constants.measured_absolute_position = 0.0;
catapult->potentiometer_offset = 0.0;
break;
case kCompTeamNumber:
climber->potentiometer_offset = -0.0463847608752 - 0.0376876182111 +
0.0629263851579 - 0.00682128836400001 +
0.0172237531191 - 0.0172237531191;
intake_front->potentiometer_offset =
2.79628370453323 - 0.0250288114832881 + 0.577152542437606;
intake_front->subsystem_params.zeroing_constants
.measured_absolute_position = 0.26963366701647;
intake_back->potentiometer_offset = 3.1409576474047 + 0.278653334013286 +
0.00879137908308503 +
0.0837134053818833;
intake_back->subsystem_params.zeroing_constants
.measured_absolute_position = 0.15924088639178;
turret->potentiometer_offset =
-9.99970387166721 + 0.06415943 + 0.073290115367682 -
0.0634440443622909 + 0.213601224728352 + 0.0657973101027296 -
0.114726411377978 - 0.980314029089968 - 0.0266013159299456 +
0.0631240002215899 + 0.222882504808653;
turret->subsystem_params.zeroing_constants.measured_absolute_position =
1.14081767944401;
flipper_arm_left->potentiometer_offset = -6.4;
flipper_arm_right->potentiometer_offset = 5.56;
catapult_params->zeroing_constants.measured_absolute_position =
1.71723370408082;
catapult->potentiometer_offset = -2.03383240293769;
break;
case kPracticeTeamNumber:
// TODO(milind): calibrate once mounted
climber->potentiometer_offset = 0.0;
intake_front->potentiometer_offset = 3.06604378582351;
intake_front->subsystem_params.zeroing_constants
.measured_absolute_position = 0.318042402595181;
intake_back->potentiometer_offset = 3.10861174832838;
intake_back->subsystem_params.zeroing_constants
.measured_absolute_position = 0.140554083520329;
turret->potentiometer_offset = -8.14418207451834 + 0.342635491808218;
turret->subsystem_params.zeroing_constants.measured_absolute_position =
1.15423161235124;
turret_range->upper = 3.0;
turret_params->range = *turret_range;
flipper_arm_left->potentiometer_offset = -4.39536583413615;
flipper_arm_right->potentiometer_offset = 4.36264091401229;
catapult_params->zeroing_constants.measured_absolute_position =
1.62909518684227;
catapult->potentiometer_offset = -1.52951814169821 - 0.0200812009850977;
break;
case kCodingRobotTeamNumber:
r.shot_interpolation_table = InterpolationTable<Values::ShotParams>({
{2, {0.08, 8.0}},
{5, {0.6, 10.0}},
});
r.shot_velocity_interpolation_table =
InterpolationTable<Values::ShotVelocityParams>({
{2, {2.0}},
{5, {4.0}},
});
climber->potentiometer_offset = 0.0;
intake_front->potentiometer_offset = 0.0;
intake_front->subsystem_params.zeroing_constants
.measured_absolute_position = 0.0;
intake_back->potentiometer_offset = 0.0;
intake_back->subsystem_params.zeroing_constants
.measured_absolute_position = 0.0;
turret->potentiometer_offset = 0.0;
turret->subsystem_params.zeroing_constants.measured_absolute_position =
0.0;
flipper_arm_left->potentiometer_offset = 0.0;
flipper_arm_right->potentiometer_offset = 0.0;
catapult_params->zeroing_constants.measured_absolute_position = 0.0;
catapult->potentiometer_offset = 0.0;
break;
default:
LOG(FATAL) << "unknown team: " << team;
}
return r;
}
Values MakeValues() { return MakeValues(aos::network::GetTeamNumber()); }
} // namespace constants
} // namespace y2022