ppresult.cpp 1.18 KB
// SPDX-License-Identifier: GPL-2.0+

#include "ppresult.h"
#include <QDebug>
#include <stdexcept>

PPresult::PPresult(unsigned int channelCount) { analyzedData.resize(channelCount); }

const DataChannel *PPresult::data(ChannelID channel) const {
    if (channel >= this->analyzedData.size()) return 0;

    return &this->analyzedData[(size_t)channel];
}

DataChannel *PPresult::modifyData(ChannelID channel) { return &this->analyzedData[(size_t)channel]; }

unsigned int PPresult::sampleCount() const { return (unsigned)analyzedData[0].voltage.sample.size(); }

unsigned int PPresult::channelCount() const { return (unsigned)analyzedData.size(); }

double DataChannel::computeAmplitude() const {
    if (voltage.sample.empty()) return 0.0;
    double minimalVoltage, maximalVoltage;
    minimalVoltage = maximalVoltage = voltage.sample[0];

    for (unsigned int position = 1; position < voltage.sample.size(); ++position) {
        if (voltage.sample[position] < minimalVoltage)
            minimalVoltage = voltage.sample[position];
        else if (voltage.sample[position] > maximalVoltage)
            maximalVoltage = voltage.sample[position];
    }

    return maximalVoltage - minimalVoltage;
}