Commit f548d299 authored by Bryant Mairs's avatar Bryant Mairs

Added a check for a division by zero in AbstractCalibrator::logAverage(). This...

Added a check for a division by zero in AbstractCalibrator::logAverage(). This was causing a crash when attempting a calibration when there's no RC data being received.
parent dd011bc5
......@@ -14,25 +14,42 @@ AbstractCalibrator::~AbstractCalibrator()
uint16_t AbstractCalibrator::logAverage()
{
// Short-circuit here if the log is empty otherwise we get a div-by-0 error.
if (log->empty())
{
return 0;
}
uint16_t total = 0;
for (int i=0; i<log->size(); ++i)
{
total += log->value(i);
}
return total/log->size();
}
uint16_t AbstractCalibrator::logExtrema()
{
uint16_t extrema = logAverage();
if (logAverage() < 1500) {
for (int i=0; i<log->size(); ++i) {
if (logAverage() < 1500)
{
for (int i=0; i<log->size(); ++i)
{
if (log->value(i) < extrema)
extrema = log->value(i);
{
extrema = log->value(i);
}
}
extrema -= 5; // add 5us to prevent integer overflow
} else {
for (int i=0; i<log->size(); ++i) {
}
else
{
for (int i=0; i<log->size(); ++i)
{
if (log->value(i) > extrema)
{
extrema = log->value(i);
}
}
extrema += 5; // subtact 5us to prevent integer overflow
}
......@@ -44,6 +61,8 @@ void AbstractCalibrator::channelChanged(uint16_t raw)
{
pulseWidth->setText(QString::number(raw));
if (log->size() == 5)
{
log->pop_front();
}
log->push_back(raw);
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment