1#include "velocityController.h"
4int VoltageController::sign(
double x) {
5 return (x > 0) - (x < 0);
8VoltageController::VoltageController(
double kv,
double kaStraight,
double kaTurn,
double ksStraight,
double ksTurn,
double kp,
9 double ki,
double integralThreshold,
double trackWidth)
10 : kV(kv), kaStraight(kaStraight), kaTurn(kaTurn), ksStraight(ksStraight), ksTurn(ksTurn), kP(kp), kI(ki),
11 integralThreshold(integralThreshold), trackWidth(trackWidth) {}
13DrivetrainVoltages VoltageController::update(
double targetLinearVelocity,
double targetAngularVelocity,
double measuredLeftVelocity,
14 double measuredRightVelocity) {
17 double deltaW = (targetAngularVelocity - prevAngularVelocity) / 0.01;
19 double deltaV = (targetLinearVelocity - prevLinearVelocity) / 0.01;
21 prevAngularVelocity = targetAngularVelocity;
22 prevLinearVelocity = targetLinearVelocity;
25 double leftVelocity = targetLinearVelocity - targetAngularVelocity * (trackWidth / 2.0);
26 double rightVelocity = targetLinearVelocity + targetAngularVelocity * (trackWidth / 2.0);
29 double leftError = leftVelocity - measuredLeftVelocity;
30 double rightError = rightVelocity - measuredRightVelocity;
33 if ((leftError < 0) != (prevLeftError < 0)) {
36 if (std::abs(leftError) < integralThreshold) {
37 leftIntegral += leftError * 0.01;
39 if ((rightError < 0) != (prevRightError < 0)) {
42 if (std::abs(rightError) < integralThreshold) {
43 rightIntegral += rightError * 0.01;
48 double kaLeft = (kaStraight * deltaV) - (kaTurn * deltaW);
49 double kaRight = (kaStraight * deltaV) + (kaTurn * deltaW);
52 double ksLeft = (ksStraight * sign(leftVelocity)) - (ksTurn * sign(targetAngularVelocity));
53 double ksRight = (ksStraight * sign(rightVelocity)) + (ksTurn * sign(targetAngularVelocity));
60 (kV * leftVelocity) + (kaLeft) + (ksLeft) + (kP * leftError) + (kI * leftIntegral);
62 (kV * rightVelocity) + (kaRight) + (ksRight) + (kP * rightError) + (kI * rightIntegral);
63 double ratio = std::max(fabs(leftVoltage), fabs(rightVoltage)) / 12000.0;
66 rightVoltage /= ratio;
69 return {leftVoltage, rightVoltage};