1#ifndef TR_EMBEDDED_CHASSIS_SUBSYSTEM_H
2#define TR_EMBEDDED_CHASSIS_SUBSYSTEM_H
7#include "util/peripherals/encoder/MA4.h"
18#define CAN_BUS_TYPE CANHandler::CANBUS_1
19#define MOTOR_TYPE M3508
20#define M3508_POST_MAX_RPM 469
21#define INPUT_THRESHOLD 0.01
24#define SECONDS_PER_MINUTE 60
25#define TICKS_PER_ROTATION 8192.0
26#define WHEEL_DIAMETER_METERS 0.146
27#define WHEEL_TO_CHASSIS_CENTER_LX 0.21
28#define WHEEL_TO_CHASSIS_CENTER_LY 0.14
30#define MAX_BEYBLADE_SPEED 1800
31#define BEYBLADE_ACCELERATION 0.05
143 static double p_theory(
int LeftFrontPower,
int RightFrontPower,
int LeftBackPower,
int RightBackPower,
int LeftFrontRpm,
int RightFrontRpm,
int LeftBackRpm,
int RightBackRpm);
145 static double Bisection(
int LeftFrontPower,
int RightFrontPower,
int LeftBackPower,
int RightBackPower,
int LeftFrontRpm,
int RightFrontRpm,
int LeftBackRpm,
int RightBackRpm,
float chassisPowerLimit);
357 MA4 *encoder =
nullptr;
366 static double rpmToRadPerSecond(
double RPM);
367 static double radPerSecondToRPM(
double radPerSecond);
370 float chassis_radius;
381 int motorPIDtoPower(
MotorLocation location,
double speed, uint32_t dt);
Definition ChassisSubsystem.h:75
void periodic(IMU::EulerAngles *imuCurr=nullptr)
Definition ChassisSubsystem.cpp:507
double yawOdom
Definition ChassisSubsystem.h:328
PID pid_RF
Definition ChassisSubsystem.h:315
DRIVE_MODE
Definition ChassisSubsystem.h:126
@ REVERSE_YAW_ORIENTED
Definition ChassisSubsystem.h:128
@ ODOM_ORIENTED
Definition ChassisSubsystem.h:130
@ ROBOT_ORIENTED
Definition ChassisSubsystem.h:129
@ YAW_ORIENTED
Definition ChassisSubsystem.h:127
void setBrakeMode(BrakeMode brakeMode)
Definition ChassisSubsystem.cpp:474
uint32_t lastPIDTime
Definition ChassisSubsystem.h:319
static double degreesToRadians(double degrees)
Definition ChassisSubsystem.cpp:518
void setOmniKinematicsLimits(double max_Vel, double max_vOmega)
Definition ChassisSubsystem.cpp:533
BrakeMode
Definition ChassisSubsystem.h:105
@ BRAKE
Definition ChassisSubsystem.h:106
@ COAST
Definition ChassisSubsystem.h:107
float setChassisSpeeds(ChassisSpeeds desiredChassisSpeeds_, DRIVE_MODE mode=ROBOT_ORIENTED)
Definition ChassisSubsystem.cpp:348
static double Bisection(int LeftFrontPower, int RightFrontPower, int LeftBackPower, int RightBackPower, int LeftFrontRpm, int RightFrontRpm, int LeftBackRpm, int RightBackRpm, float chassisPowerLimit)
Definition ChassisSubsystem.cpp:186
static double radiansToTicks(double radians)
Definition ChassisSubsystem.cpp:751
MotorLocation
Definition ChassisSubsystem.h:111
@ RIGHT_BACK
Definition ChassisSubsystem.h:115
@ RIGHT_FRONT
Definition ChassisSubsystem.h:113
@ LEFT_BACK
Definition ChassisSubsystem.h:114
@ LEFT_FRONT
Definition ChassisSubsystem.h:112
WheelSpeeds chassisSpeedsToWheelSpeeds(ChassisSpeeds chassisSpeeds)
Definition ChassisSubsystem.cpp:590
ChassisSpeeds rotateChassisSpeed(ChassisSpeeds speeds, double yawCurrent)
Definition ChassisSubsystem.cpp:417
void setWheelPower(WheelSpeeds wheelPower)
Definition ChassisSubsystem.cpp:335
float setWheelSpeeds(WheelSpeeds wheelSpeeds)
Definition ChassisSubsystem.cpp:225
static double ticksToRadians(double ticks)
Definition ChassisSubsystem.cpp:756
OmniKinematicsLimits m_OmniKinematicsLimits
Definition ChassisSubsystem.h:304
double prevVel
Definition ChassisSubsystem.h:323
int PEAK_POWER_SINGLE
Definition ChassisSubsystem.h:312
DJIMotor & getMotor(MotorLocation location)
Definition ChassisSubsystem.cpp:426
PID pid_LF
Definition ChassisSubsystem.h:314
void setSpeedFeedforward(MotorLocation location, double FF)
Definition ChassisSubsystem.cpp:454
void setSpeedIntegralCap(MotorLocation location, double cap)
Definition ChassisSubsystem.cpp:449
WheelSpeeds desiredWheelSpeeds
Definition ChassisSubsystem.h:302
void setMotorSpeedPID(MotorLocation location, float kP, float kI, float kD)
Definition ChassisSubsystem.cpp:444
SPEED_UNIT
Definition ChassisSubsystem.h:119
@ RPM
Definition ChassisSubsystem.h:121
@ METER_PER_SECOND
Definition ChassisSubsystem.h:122
@ RAD_PER_SECOND
Definition ChassisSubsystem.h:120
int getHeadingDegrees() const
Definition ChassisSubsystem.cpp:528
void initializeImu()
Definition ChassisSubsystem.cpp:479
static double p_theory(int LeftFrontPower, int RightFrontPower, int LeftBackPower, int RightBackPower, int LeftFrontRpm, int RightFrontRpm, int LeftBackRpm, int RightBackRpm)
Definition ChassisSubsystem.cpp:163
double getMotorSpeed(MotorLocation location, SPEED_UNIT unit)
Definition ChassisSubsystem.cpp:485
void updateYawPhaseFromEncoder()
Definition ChassisSubsystem.cpp:738
bool setOdomReference()
Definition ChassisSubsystem.cpp:677
static float limitAcceleration(float desiredRPM, float previousRPM, int power)
Definition ChassisSubsystem.cpp:58
float previousRPM[4]
Definition ChassisSubsystem.h:139
ChassisSpeeds getChassisSpeeds() const
Definition ChassisSubsystem.cpp:343
int PEAK_POWER_ALL
Definition ChassisSubsystem.h:311
void readImu()
Definition ChassisSubsystem.cpp:502
float power_limit
Definition ChassisSubsystem.h:147
HOLONOMIC_MODE
Definition ChassisSubsystem.h:134
@ MECANUM
Definition ChassisSubsystem.h:136
@ OMNI
Definition ChassisSubsystem.h:135
static double radiansToDegrees(double radians)
Definition ChassisSubsystem.cpp:523
ChassisSpeeds m_chassisSpeeds
Definition ChassisSubsystem.h:308
int testDataIndex
Definition ChassisSubsystem.h:331
ChassisSpeeds desiredChassisSpeeds
Definition ChassisSubsystem.h:301
WheelSpeeds normalizeWheelSpeeds(WheelSpeeds wheelSpeeds) const
Definition ChassisSubsystem.cpp:318
WheelSpeeds m_wheelSpeeds
Definition ChassisSubsystem.h:309
BrakeMode getBrakeMode()
Definition ChassisSubsystem.cpp:469
int testData[300][4]
Definition ChassisSubsystem.h:330
double imuOdom
Definition ChassisSubsystem.h:329
ChassisSpeeds wheelSpeedsToChassisSpeeds(WheelSpeeds wheelSpeeds)
Definition ChassisSubsystem.cpp:619
WheelSpeeds getWheelSpeeds() const
Definition ChassisSubsystem.cpp:53
PID pid_RB
Definition ChassisSubsystem.h:317
PID pid_LB
Definition ChassisSubsystem.h:316
Definition ChassisSubsystem.h:56
double vY
Definition ChassisSubsystem.h:58
double vX
Definition ChassisSubsystem.h:57
double vOmega
Definition ChassisSubsystem.h:59
Definition ChassisSubsystem.h:78
int left_front_can_id
Definition ChassisSubsystem.h:79
const double radius
Definition ChassisSubsystem.h:84
IMU & imu
Definition ChassisSubsystem.h:88
MA4 * encoder
Definition ChassisSubsystem.h:89
int right_front_can_id
Definition ChassisSubsystem.h:80
const double speed_pid_ff_ks
Definition ChassisSubsystem.h:85
float yaw_initial_offset_ticks
Definition ChassisSubsystem.h:87
int right_back_can_id
Definition ChassisSubsystem.h:82
int left_back_can_id
Definition ChassisSubsystem.h:81
Definition ChassisSubsystem.h:63
double max_Vel
Definition ChassisSubsystem.h:64
double max_vOmega
Definition ChassisSubsystem.h:65
Definition ChassisSubsystem.h:35
double r1y
Definition ChassisSubsystem.h:36
double r1x
Definition ChassisSubsystem.h:36
double r3y
Definition ChassisSubsystem.h:36
double r2x
Definition ChassisSubsystem.h:36
double r2y
Definition ChassisSubsystem.h:36
double r4x
Definition ChassisSubsystem.h:36
double r3x
Definition ChassisSubsystem.h:36
double r4y
Definition ChassisSubsystem.h:36
Definition ChassisSubsystem.h:40
double RB
Definition ChassisSubsystem.h:44
void operator*=(double scalar)
Definition ChassisSubsystem.h:46
double RF
Definition ChassisSubsystem.h:42
double LF
Definition ChassisSubsystem.h:41
double LB
Definition ChassisSubsystem.h:43