TR-mbed 1.0
Loading...
Searching...
No Matches
ChassisSubsystem.h
Go to the documentation of this file.
1#ifndef TR_EMBEDDED_CHASSIS_SUBSYSTEM_H
2#define TR_EMBEDDED_CHASSIS_SUBSYSTEM_H
3
4#include "mbed.h"
7#include "util/peripherals/encoder/MA4.h"
8
12// #include <subsystems/ChassisKalman.h>
13// #include <algorithms/WheelKalman.h>
14#include <util/algorithms/PID.h>
15// #include <algorithms/WheelSpeeds.h>
16// #include <algorithms/ChassisSpeeds.h>
17
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
22
23#define PI 3.14159265
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
29
30#define MAX_BEYBLADE_SPEED 1800
31#define BEYBLADE_ACCELERATION 0.05
32#define MAX_VEL 2.92
33
35{
36 double r1x, r1y, r2x, r2y, r3x, r3y, r4x, r4y;
37};
38
40{
41 double LF;
42 double RF;
43 double LB;
44 double RB;
45
46 void operator*=(double scalar)
47 {
48 LF *= scalar;
49 RF *= scalar;
50 LB *= scalar;
51 RB *= scalar;
52 }
53};
54
56{
57 double vX;
58 double vY;
59 double vOmega;
60};
61
63{
64 double max_Vel;
65 double max_vOmega;
66};
67
75{
76public:
77
78 struct Config {
83
84 const double radius;
85 const double speed_pid_ff_ks;
86
90 MA4 *encoder; // External encoder for yaw position
91 };
92
100 ChassisSubsystem(const Config &config);
101
106 {
108 COAST
109 };
110
118
125
133
139
140 float previousRPM[4] = {0, 0, 0, 0};
141
142 static float limitAcceleration(float desiredRPM, float previousRPM, int power);
143
144 static float p_theory(int LeftFrontPower, int RightFrontPower, int LeftBackPower, int RightBackPower, int LeftFrontRpm, int RightFrontRpm, int LeftBackRpm, int RightBackRpm);
145
146 static float Bisection(int LeftFrontPower, int RightFrontPower, int LeftBackPower, int RightBackPower, int LeftFrontRpm, int RightFrontRpm, int LeftBackRpm, int RightBackRpm, float chassisPowerLimit);
147
149
155
160 float setWheelSpeeds(WheelSpeeds wheelSpeeds);
161
167
172 void setWheelPower(WheelSpeeds wheelPower);
173
179
185 float setChassisSpeeds(ChassisSpeeds desiredChassisSpeeds_, DRIVE_MODE mode = ROBOT_ORIENTED);
186
193 ChassisSpeeds rotateChassisSpeed(ChassisSpeeds speeds, double yawCurrent);
194
202
210 void setMotorSpeedPID(MotorLocation location, float kP, float kI, float kD);
211
217 void setSpeedIntegralCap(MotorLocation location, double cap);
218
224 void setSpeedFeedforward(MotorLocation location, double FF);
225
226
233
239 void setBrakeMode(BrakeMode brakeMode);
240
244 void initializeImu();
245
249 void periodic(IMU::EulerAngles *imuCurr = nullptr);
250
256 static double radiansToDegrees(double radians);
257
263 static double degreesToRadians(double degrees);
264
269 int getHeadingDegrees() const;
270
271
279 double getMotorSpeed(MotorLocation location, SPEED_UNIT unit);
280
287 void setOmniKinematicsLimits(double max_Vel, double max_vOmega);
288
292 void readImu();
293
294
300 bool setOdomReference();
301
304
308
311
314
319
320 uint32_t lastPIDTime = 0;
321
322 // int8_t isInverted[4];
323
324 double prevVel;
325
329 double yawOdom;
330 double imuOdom;
331 int testData[300][4];
333
334 static double radiansToTicks(double radians);
335 static double ticksToRadians(double ticks);
336
337 // /**
338 // * Gets the yaw position from encoder (PWM) input in degrees (0-360)
339 // * @return yaw position in degrees, or -1 if encoder not available
340 // */
341 // double getEncoderYawPosition();
342
343 // /**
344 // * A helper method to calculate the moving average of the encoder readings for yaw position
345 // * @return the moving average of the encoder readings for yaw position
346 // */
347 // double encoderMovingAverage();
348
354
355private:
356 DJIMotor LF, RF, LB, RB;
357 DJIMotor *yaw = 0;
358 MA4 *encoder = nullptr;
359 double yawPhase;
360 BrakeMode brakeMode;
361
362 // double beybladeSpeed;
363 // bool beybladeIncreasing;
364 BNO055 &imu;
366
367 static double rpmToRadPerSecond(double RPM);
368 static double radPerSecondToRPM(double radPerSecond);
369
370 OmniKinematics m_OmniKinematics;
371 float chassis_radius;
372 void setOmniKinematics(double radius, HOLONOMIC_MODE mode = OMNI);
373 // Eigen::MatrixXd wheelSpeedsToChassisSpeeds(WheelSpeeds wheelSpeeds);
374
375 double FF_Ks;
376
377 void setMotorPower(MotorLocation location, double power);
378 void setMotorSpeedRPM(MotorLocation location, double speed);
379 // void setMotorSpeedTicksPerSecond(int index, double speed);
380
381 double getMotorSpeedRPM(MotorLocation location);
382 int motorPIDtoPower(MotorLocation location, double speed, uint32_t dt);
383
384 // ChassisKalman chassisKalman;
385 double testAngle;
386 int lastTimeMs;
387};
388
389#endif // TR_EMBEDDED_CHASSIS_SUBSYSTEM_H
Definition BNO055.h:142
Definition ChassisSubsystem.h:75
void periodic(IMU::EulerAngles *imuCurr=nullptr)
Definition ChassisSubsystem.cpp:507
double yawOdom
Definition ChassisSubsystem.h:329
PID pid_RF
Definition ChassisSubsystem.h:316
static float Bisection(int LeftFrontPower, int RightFrontPower, int LeftBackPower, int RightBackPower, int LeftFrontRpm, int RightFrontRpm, int LeftBackRpm, int RightBackRpm, float chassisPowerLimit)
Definition ChassisSubsystem.cpp:187
DRIVE_MODE
Definition ChassisSubsystem.h:127
@ REVERSE_YAW_ORIENTED
Definition ChassisSubsystem.h:129
@ ODOM_ORIENTED
Definition ChassisSubsystem.h:131
@ ROBOT_ORIENTED
Definition ChassisSubsystem.h:130
@ YAW_ORIENTED
Definition ChassisSubsystem.h:128
void setBrakeMode(BrakeMode brakeMode)
Definition ChassisSubsystem.cpp:475
uint32_t lastPIDTime
Definition ChassisSubsystem.h:320
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:106
@ BRAKE
Definition ChassisSubsystem.h:107
@ COAST
Definition ChassisSubsystem.h:108
float setChassisSpeeds(ChassisSpeeds desiredChassisSpeeds_, DRIVE_MODE mode=ROBOT_ORIENTED)
Definition ChassisSubsystem.cpp:349
static double radiansToTicks(double radians)
Definition ChassisSubsystem.cpp:751
MotorLocation
Definition ChassisSubsystem.h:112
@ RIGHT_BACK
Definition ChassisSubsystem.h:116
@ RIGHT_FRONT
Definition ChassisSubsystem.h:114
@ LEFT_BACK
Definition ChassisSubsystem.h:115
@ LEFT_FRONT
Definition ChassisSubsystem.h:113
WheelSpeeds chassisSpeedsToWheelSpeeds(ChassisSpeeds chassisSpeeds)
Definition ChassisSubsystem.cpp:590
ChassisSpeeds rotateChassisSpeed(ChassisSpeeds speeds, double yawCurrent)
Definition ChassisSubsystem.cpp:418
void setWheelPower(WheelSpeeds wheelPower)
Definition ChassisSubsystem.cpp:336
float setWheelSpeeds(WheelSpeeds wheelSpeeds)
Definition ChassisSubsystem.cpp:226
static double ticksToRadians(double ticks)
Definition ChassisSubsystem.cpp:756
OmniKinematicsLimits m_OmniKinematicsLimits
Definition ChassisSubsystem.h:305
double prevVel
Definition ChassisSubsystem.h:324
int PEAK_POWER_SINGLE
Definition ChassisSubsystem.h:313
DJIMotor & getMotor(MotorLocation location)
Definition ChassisSubsystem.cpp:427
static float p_theory(int LeftFrontPower, int RightFrontPower, int LeftBackPower, int RightBackPower, int LeftFrontRpm, int RightFrontRpm, int LeftBackRpm, int RightBackRpm)
Definition ChassisSubsystem.cpp:164
PID pid_LF
Definition ChassisSubsystem.h:315
void setSpeedFeedforward(MotorLocation location, double FF)
Definition ChassisSubsystem.cpp:455
void setSpeedIntegralCap(MotorLocation location, double cap)
Definition ChassisSubsystem.cpp:450
WheelSpeeds desiredWheelSpeeds
Definition ChassisSubsystem.h:303
void setMotorSpeedPID(MotorLocation location, float kP, float kI, float kD)
Definition ChassisSubsystem.cpp:445
SPEED_UNIT
Definition ChassisSubsystem.h:120
@ RPM
Definition ChassisSubsystem.h:122
@ METER_PER_SECOND
Definition ChassisSubsystem.h:123
@ RAD_PER_SECOND
Definition ChassisSubsystem.h:121
int getHeadingDegrees() const
Definition ChassisSubsystem.cpp:528
void initializeImu()
Definition ChassisSubsystem.cpp:480
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:59
float previousRPM[4]
Definition ChassisSubsystem.h:140
ChassisSpeeds getChassisSpeeds() const
Definition ChassisSubsystem.cpp:344
int PEAK_POWER_ALL
Definition ChassisSubsystem.h:312
void readImu()
Definition ChassisSubsystem.cpp:502
float power_limit
Definition ChassisSubsystem.h:148
HOLONOMIC_MODE
Definition ChassisSubsystem.h:135
@ MECANUM
Definition ChassisSubsystem.h:137
@ OMNI
Definition ChassisSubsystem.h:136
static double radiansToDegrees(double radians)
Definition ChassisSubsystem.cpp:523
ChassisSpeeds m_chassisSpeeds
Definition ChassisSubsystem.h:309
int testDataIndex
Definition ChassisSubsystem.h:332
ChassisSpeeds desiredChassisSpeeds
Definition ChassisSubsystem.h:302
WheelSpeeds normalizeWheelSpeeds(WheelSpeeds wheelSpeeds) const
Definition ChassisSubsystem.cpp:319
WheelSpeeds m_wheelSpeeds
Definition ChassisSubsystem.h:310
BrakeMode getBrakeMode()
Definition ChassisSubsystem.cpp:470
int testData[300][4]
Definition ChassisSubsystem.h:331
double imuOdom
Definition ChassisSubsystem.h:330
ChassisSpeeds wheelSpeedsToChassisSpeeds(WheelSpeeds wheelSpeeds)
Definition ChassisSubsystem.cpp:619
WheelSpeeds getWheelSpeeds() const
Definition ChassisSubsystem.cpp:54
PID pid_RB
Definition ChassisSubsystem.h:318
PID pid_LB
Definition ChassisSubsystem.h:317
Definition DJIMotor.h:48
Definition PID.h:138
Definition BNO055.h:89
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
DJIMotor * yaw_motor
Definition ChassisSubsystem.h:87
int left_front_can_id
Definition ChassisSubsystem.h:79
const double radius
Definition ChassisSubsystem.h:84
MA4 * encoder
Definition ChassisSubsystem.h:90
BNO055 & imu
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:88
int right_back_can_id
Definition ChassisSubsystem.h:82
int left_back_can_id
Definition ChassisSubsystem.h:81
Definition IMU.h:8
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