Merge pull request #3017 from rav-rav/sharper_rc_response
Sharper rc response / ninja-mode
This commit is contained in:
commit
ebbfda2f6c
|
@ -173,11 +173,11 @@ static void scaleRcCommandToFpvCamAngle(void) {
|
||||||
|
|
||||||
void processRcCommand(void)
|
void processRcCommand(void)
|
||||||
{
|
{
|
||||||
static int16_t lastCommand[4] = { 0, 0, 0, 0 };
|
static float rcCommandInterp[4] = { 0, 0, 0, 0 };
|
||||||
static int16_t deltaRC[4] = { 0, 0, 0, 0 };
|
static float rcStepSize[4] = { 0, 0, 0, 0 };
|
||||||
static int16_t factor, rcInterpolationFactor;
|
static int16_t rcInterpolationStepCount;
|
||||||
static uint16_t currentRxRefreshRate;
|
static uint16_t currentRxRefreshRate;
|
||||||
const uint8_t interpolationChannels = rxConfig()->rcInterpolationChannels + 2;
|
const uint8_t interpolationChannels = rxConfig()->rcInterpolationChannels + 2; //"RP", "RPY", "RPYT"
|
||||||
uint16_t rxRefreshRate;
|
uint16_t rxRefreshRate;
|
||||||
bool readyToCalculateRate = false;
|
bool readyToCalculateRate = false;
|
||||||
uint8_t readyToCalculateRateAxisCnt = 0;
|
uint8_t readyToCalculateRateAxisCnt = 0;
|
||||||
|
@ -204,36 +204,34 @@ void processRcCommand(void)
|
||||||
rxRefreshRate = rxGetRefreshRate();
|
rxRefreshRate = rxGetRefreshRate();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isRXDataNew) {
|
if (isRXDataNew && rxRefreshRate > 0) {
|
||||||
rcInterpolationFactor = rxRefreshRate / targetPidLooptime + 1;
|
rcInterpolationStepCount = rxRefreshRate / targetPidLooptime;
|
||||||
|
|
||||||
if (debugMode == DEBUG_RC_INTERPOLATION) {
|
|
||||||
for(int axis = 0; axis < 2; axis++) debug[axis] = rcCommand[axis];
|
|
||||||
debug[3] = rxRefreshRate;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int channel=ROLL; channel < interpolationChannels; channel++) {
|
for (int channel=ROLL; channel < interpolationChannels; channel++) {
|
||||||
deltaRC[channel] = rcCommand[channel] - (lastCommand[channel] - deltaRC[channel] * factor / rcInterpolationFactor);
|
rcStepSize[channel] = (rcCommand[channel] - rcCommandInterp[channel]) / (float)rcInterpolationStepCount;
|
||||||
lastCommand[channel] = rcCommand[channel];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
factor = rcInterpolationFactor - 1;
|
if (debugMode == DEBUG_RC_INTERPOLATION) {
|
||||||
|
debug[0] = lrintf(rcCommand[0]);
|
||||||
|
debug[1] = lrintf(getTaskDeltaTime(TASK_RX) / 1000);
|
||||||
|
//debug[1] = lrintf(rcCommandInterp[0]);
|
||||||
|
//debug[1] = lrintf(rcStepSize[0]*100);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
factor--;
|
rcInterpolationStepCount--;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Interpolate steps of rcCommand
|
// Interpolate steps of rcCommand
|
||||||
if (factor > 0) {
|
if (rcInterpolationStepCount > 0) {
|
||||||
for (int channel=ROLL; channel < interpolationChannels; channel++) {
|
for (int channel=ROLL; channel < interpolationChannels; channel++) {
|
||||||
rcCommand[channel] = lastCommand[channel] - deltaRC[channel] * factor/rcInterpolationFactor;
|
rcCommandInterp[channel] += rcStepSize[channel];
|
||||||
readyToCalculateRateAxisCnt = MAX(channel,FD_YAW); // throttle channel doesn't require rate calculation
|
rcCommand[channel] = rcCommandInterp[channel];
|
||||||
|
readyToCalculateRateAxisCnt = MAX(channel, FD_YAW); // throttle channel doesn't require rate calculation
|
||||||
|
}
|
||||||
readyToCalculateRate = true;
|
readyToCalculateRate = true;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
factor = 0;
|
rcInterpolationStepCount = 0; // reset factor in case of level modes flip flopping
|
||||||
}
|
|
||||||
} else {
|
|
||||||
factor = 0; // reset factor in case of level modes flip flopping
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (readyToCalculateRate || isRXDataNew) {
|
if (readyToCalculateRate || isRXDataNew) {
|
||||||
|
@ -243,6 +241,10 @@ void processRcCommand(void)
|
||||||
for (int axis = 0; axis <= readyToCalculateRateAxisCnt; axis++)
|
for (int axis = 0; axis <= readyToCalculateRateAxisCnt; axis++)
|
||||||
calculateSetpointRate(axis);
|
calculateSetpointRate(axis);
|
||||||
|
|
||||||
|
if (debugMode == DEBUG_RC_INTERPOLATION) {
|
||||||
|
debug[2] = rcInterpolationStepCount;
|
||||||
|
debug[3] = setpointRate[0];
|
||||||
|
}
|
||||||
// Scaling of AngleRate to camera angle (Mixing Roll and Yaw)
|
// Scaling of AngleRate to camera angle (Mixing Roll and Yaw)
|
||||||
if (rxConfig()->fpvCamAngleDegrees && IS_RC_MODE_ACTIVE(BOXFPVANGLEMIX) && !FLIGHT_MODE(HEADFREE_MODE))
|
if (rxConfig()->fpvCamAngleDegrees && IS_RC_MODE_ACTIVE(BOXFPVANGLEMIX) && !FLIGHT_MODE(HEADFREE_MODE))
|
||||||
scaleRcCommandToFpvCamAngle();
|
scaleRcCommandToFpvCamAngle();
|
||||||
|
@ -311,7 +313,7 @@ void updateRcCommands(void)
|
||||||
const float radDiff = degreesToRadians(DECIDEGREES_TO_DEGREES(attitude.values.yaw) - headFreeModeHold);
|
const float radDiff = degreesToRadians(DECIDEGREES_TO_DEGREES(attitude.values.yaw) - headFreeModeHold);
|
||||||
const float cosDiff = cos_approx(radDiff);
|
const float cosDiff = cos_approx(radDiff);
|
||||||
const float sinDiff = sin_approx(radDiff);
|
const float sinDiff = sin_approx(radDiff);
|
||||||
const int16_t rcCommand_PITCH = rcCommand[PITCH] * cosDiff + rcCommand[ROLL] * sinDiff;
|
const float rcCommand_PITCH = rcCommand[PITCH] * cosDiff + rcCommand[ROLL] * sinDiff;
|
||||||
rcCommand[ROLL] = rcCommand[ROLL] * cosDiff - rcCommand[PITCH] * sinDiff;
|
rcCommand[ROLL] = rcCommand[ROLL] * cosDiff - rcCommand[PITCH] * sinDiff;
|
||||||
rcCommand[PITCH] = rcCommand_PITCH;
|
rcCommand[PITCH] = rcCommand_PITCH;
|
||||||
}
|
}
|
||||||
|
|
|
@ -65,7 +65,7 @@ static pidProfile_t *pidProfile;
|
||||||
// true if arming is done via the sticks (as opposed to a switch)
|
// true if arming is done via the sticks (as opposed to a switch)
|
||||||
static bool isUsingSticksToArm = true;
|
static bool isUsingSticksToArm = true;
|
||||||
|
|
||||||
int16_t rcCommand[4]; // interval [1000;2000] for THROTTLE and [-500;+500] for ROLL/PITCH/YAW
|
float rcCommand[4]; // interval [1000;2000] for THROTTLE and [-500;+500] for ROLL/PITCH/YAW
|
||||||
|
|
||||||
uint32_t rcModeActivationMask; // one bit per mode defined in boxId_e
|
uint32_t rcModeActivationMask; // one bit per mode defined in boxId_e
|
||||||
|
|
||||||
|
|
|
@ -151,7 +151,7 @@ typedef struct modeActivationProfile_s {
|
||||||
|
|
||||||
#define IS_RANGE_USABLE(range) ((range)->startStep < (range)->endStep)
|
#define IS_RANGE_USABLE(range) ((range)->startStep < (range)->endStep)
|
||||||
|
|
||||||
extern int16_t rcCommand[4];
|
extern float rcCommand[4];
|
||||||
|
|
||||||
typedef struct rcControlsConfig_s {
|
typedef struct rcControlsConfig_s {
|
||||||
uint8_t deadband; // introduce a deadband around the stick center for pitch and roll axis. Must be greater than zero.
|
uint8_t deadband; // introduce a deadband around the stick center for pitch and roll axis. Must be greater than zero.
|
||||||
|
|
|
@ -421,13 +421,18 @@ void pidController(const pidProfile_t *pidProfile, const rollAndPitchTrims_t *an
|
||||||
|
|
||||||
// -----calculate D component
|
// -----calculate D component
|
||||||
if (axis != FD_YAW) {
|
if (axis != FD_YAW) {
|
||||||
|
// apply filters
|
||||||
|
float gyroRateFiltered = dtermNotchFilterApplyFn(dtermFilterNotch[axis], gyroRate);
|
||||||
|
gyroRateFiltered = dtermLpfApplyFn(dtermFilterLpf[axis], gyroRateFiltered);
|
||||||
|
|
||||||
float dynC = dtermSetpointWeight;
|
float dynC = dtermSetpointWeight;
|
||||||
if (pidProfile->setpointRelaxRatio < 100) {
|
if (pidProfile->setpointRelaxRatio < 100) {
|
||||||
dynC *= MIN(getRcDeflectionAbs(axis) * relaxFactor, 1.0f);
|
dynC *= MIN(getRcDeflectionAbs(axis) * relaxFactor, 1.0f);
|
||||||
}
|
}
|
||||||
const float rD = dynC * currentPidSetpoint - gyroRate; // cr - y
|
const float rD = dynC * currentPidSetpoint - gyroRateFiltered; // cr - y
|
||||||
// Divide rate change by dT to get differential (ie dr/dt)
|
// Divide rate change by dT to get differential (ie dr/dt)
|
||||||
float delta = (rD - previousRateError[axis]) / dT;
|
float delta = (rD - previousRateError[axis]) / dT;
|
||||||
|
|
||||||
previousRateError[axis] = rD;
|
previousRateError[axis] = rD;
|
||||||
|
|
||||||
// if crash recovery is on check for a crash
|
// if crash recovery is on check for a crash
|
||||||
|
@ -441,10 +446,6 @@ void pidController(const pidProfile_t *pidProfile, const rollAndPitchTrims_t *an
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// apply filters
|
|
||||||
delta = dtermNotchFilterApplyFn(dtermFilterNotch[axis], delta);
|
|
||||||
delta = dtermLpfApplyFn(dtermFilterLpf[axis], delta);
|
|
||||||
|
|
||||||
axisPID_D[axis] = Kd[axis] * delta * tpaFactor;
|
axisPID_D[axis] = Kd[axis] * delta * tpaFactor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -133,7 +133,7 @@ TEST(AltitudeHoldTest, TestCalculateTiltAngle)
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
uint32_t rcModeActivationMask;
|
uint32_t rcModeActivationMask;
|
||||||
int16_t rcCommand[4];
|
float rcCommand[4];
|
||||||
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
||||||
|
|
||||||
uint32_t accTimeSum ; // keep track for integration of acc
|
uint32_t accTimeSum ; // keep track for integration of acc
|
||||||
|
|
|
@ -270,7 +270,7 @@ TEST(BatteryTest, RollOverPattern2)
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
|
||||||
uint8_t armingFlags = 0;
|
uint8_t armingFlags = 0;
|
||||||
int16_t rcCommand[4] = {0,0,0,0};
|
float rcCommand[4] = {0,0,0,0};
|
||||||
|
|
||||||
|
|
||||||
bool feature(uint32_t mask)
|
bool feature(uint32_t mask)
|
||||||
|
|
|
@ -406,7 +406,7 @@ TEST(FlightFailsafeTest, TestFailsafeNotActivatedWhenDisarmedAndRXLossIsDetected
|
||||||
extern "C" {
|
extern "C" {
|
||||||
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
||||||
uint8_t armingFlags;
|
uint8_t armingFlags;
|
||||||
int16_t rcCommand[4];
|
float rcCommand[4];
|
||||||
uint32_t rcModeActivationMask;
|
uint32_t rcModeActivationMask;
|
||||||
int16_t debug[DEBUG16_VALUE_COUNT];
|
int16_t debug[DEBUG16_VALUE_COUNT];
|
||||||
bool isUsingSticksToArm = true;
|
bool isUsingSticksToArm = true;
|
||||||
|
|
|
@ -76,7 +76,7 @@ TEST(FlightImuTest, TestCalculateHeading)
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
uint32_t rcModeActivationMask;
|
uint32_t rcModeActivationMask;
|
||||||
int16_t rcCommand[4];
|
float rcCommand[4];
|
||||||
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
||||||
|
|
||||||
acc_t acc;
|
acc_t acc;
|
||||||
|
|
|
@ -380,7 +380,7 @@ rollAndPitchInclination_t inclination;
|
||||||
rxRuntimeConfig_t rxRuntimeConfig;
|
rxRuntimeConfig_t rxRuntimeConfig;
|
||||||
|
|
||||||
int16_t axisPID[XYZ_AXIS_COUNT];
|
int16_t axisPID[XYZ_AXIS_COUNT];
|
||||||
int16_t rcCommand[4];
|
float rcCommand[4];
|
||||||
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
||||||
|
|
||||||
uint32_t rcModeActivationMask;
|
uint32_t rcModeActivationMask;
|
||||||
|
|
|
@ -351,7 +351,7 @@ extern "C" {
|
||||||
|
|
||||||
uint8_t armingFlags = 0;
|
uint8_t armingFlags = 0;
|
||||||
uint16_t flightModeFlags = 0;
|
uint16_t flightModeFlags = 0;
|
||||||
int16_t rcCommand[4];
|
float rcCommand[4];
|
||||||
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
int16_t rcData[MAX_SUPPORTED_RC_CHANNEL_COUNT];
|
||||||
uint32_t rcModeActivationMask;
|
uint32_t rcModeActivationMask;
|
||||||
|
|
||||||
|
|
|
@ -38,7 +38,7 @@ extern "C" {
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
uint8_t batteryCellCount = 3;
|
uint8_t batteryCellCount = 3;
|
||||||
int16_t rcCommand[4] = {0, 0, 0, 0};
|
float rcCommand[4] = {0, 0, 0, 0};
|
||||||
int16_t telemTemperature1 = 0;
|
int16_t telemTemperature1 = 0;
|
||||||
baro_t baro = { .baroTemperature = 50 };
|
baro_t baro = { .baroTemperature = 50 };
|
||||||
telemetryConfig_t telemetryConfig_System;
|
telemetryConfig_t telemetryConfig_System;
|
||||||
|
|
|
@ -38,7 +38,7 @@ extern "C" {
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
uint8_t testBatteryCellCount =3;
|
uint8_t testBatteryCellCount =3;
|
||||||
int16_t rcCommand[4] = {0, 0, 0, 0};
|
float rcCommand[4] = {0, 0, 0, 0};
|
||||||
telemetryConfig_t telemetryConfig_System;
|
telemetryConfig_t telemetryConfig_System;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue