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
89 MA4 *encoder; // External encoder for yaw position
90 };
91
99 ChassisSubsystem(const Config &config);
100
105 {
107 COAST
108 };
109
117
124
132
138
139 float previousRPM[4] = {0, 0, 0, 0};
140
141 static float limitAcceleration(float desiredRPM, float previousRPM, int power);
142
143 static double p_theory(int LeftFrontPower, int RightFrontPower, int LeftBackPower, int RightBackPower, int LeftFrontRpm, int RightFrontRpm, int LeftBackRpm, int RightBackRpm);
144
145 static double Bisection(int LeftFrontPower, int RightFrontPower, int LeftBackPower, int RightBackPower, int LeftFrontRpm, int RightFrontRpm, int LeftBackRpm, int RightBackRpm, float chassisPowerLimit);
146
148
154
159 float setWheelSpeeds(WheelSpeeds wheelSpeeds);
160
166
171 void setWheelPower(WheelSpeeds wheelPower);
172
178
184 float setChassisSpeeds(ChassisSpeeds desiredChassisSpeeds_, DRIVE_MODE mode = ROBOT_ORIENTED);
185
192 ChassisSpeeds rotateChassisSpeed(ChassisSpeeds speeds, double yawCurrent);
193
201
209 void setMotorSpeedPID(MotorLocation location, float kP, float kI, float kD);
210
216 void setSpeedIntegralCap(MotorLocation location, double cap);
217
223 void setSpeedFeedforward(MotorLocation location, double FF);
224
225
232
238 void setBrakeMode(BrakeMode brakeMode);
239
243 void initializeImu();
244
248 void periodic(IMU::EulerAngles *imuCurr = nullptr);
249
255 static double radiansToDegrees(double radians);
256
262 static double degreesToRadians(double degrees);
263
268 int getHeadingDegrees() const;
269
270
278 double getMotorSpeed(MotorLocation location, SPEED_UNIT unit);
279
286 void setOmniKinematicsLimits(double max_Vel, double max_vOmega);
287
291 void readImu();
292
293
299 bool setOdomReference();
300
303
307
310
313
318
319 uint32_t lastPIDTime = 0;
320
321 // int8_t isInverted[4];
322
323 double prevVel;
324
328 double yawOdom;
329 double imuOdom;
330 int testData[300][4];
332
333 static double radiansToTicks(double radians);
334 static double ticksToRadians(double ticks);
335
336 // /**
337 // * Gets the yaw position from encoder (PWM) input in degrees (0-360)
338 // * @return yaw position in degrees, or -1 if encoder not available
339 // */
340 // double getEncoderYawPosition();
341
342 // /**
343 // * A helper method to calculate the moving average of the encoder readings for yaw position
344 // * @return the moving average of the encoder readings for yaw position
345 // */
346 // double encoderMovingAverage();
347
353
354private:
355 DJIMotor LF, RF, LB, RB;
356 DJIMotor *yaw = 0;
357 MA4 *encoder = nullptr;
358 double yawPhase;
359 BrakeMode brakeMode;
360
361 // double beybladeSpeed;
362 // bool beybladeIncreasing;
363 IMU &imu;
364 IMU::EulerAngles imuAngles;
365
366 static double rpmToRadPerSecond(double RPM);
367 static double radPerSecondToRPM(double radPerSecond);
368
369 OmniKinematics m_OmniKinematics;
370 float chassis_radius;
371 void setOmniKinematics(double radius, HOLONOMIC_MODE mode = OMNI);
372 // Eigen::MatrixXd wheelSpeedsToChassisSpeeds(WheelSpeeds wheelSpeeds);
373
374 double FF_Ks;
375
376 void setMotorPower(MotorLocation location, double power);
377 void setMotorSpeedRPM(MotorLocation location, double speed);
378 // void setMotorSpeedTicksPerSecond(int index, double speed);
379
380 double getMotorSpeedRPM(MotorLocation location);
381 int motorPIDtoPower(MotorLocation location, double speed, uint32_t dt);
382
383 // ChassisKalman chassisKalman;
384 double testAngle;
385 int lastTimeMs;
386};
387
388#endif // TR_EMBEDDED_CHASSIS_SUBSYSTEM_H
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 DJIMotor.h:48
Definition IMU.h:7
Definition PID.h:138
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 IMU.h:10
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