/*
  Copyright © 2018 Hasan Yavuz Özderya
  This file is part of serialplot.
  serialplot is free software: you can redistribute it and/or modify
  it under the terms of the GNU General Public License as published by
  the Free Software Foundation, either version 3 of the License, or
  (at your option) any later version.
  serialplot is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License for more details.
  You should have received a copy of the GNU General Public License
  along with serialplot.  If not, see <http://www.gnu.org/licenses/>.
*/
#include <QtGlobal>
#include <algorithm>
#include "linindexbuffer.h"
LinIndexBuffer::LinIndexBuffer(unsigned n, Range lim)
{
    // Note that calculation of _step would cause divide by 0
    Q_ASSERT(n > 1);
    _size = n;
    setLimits(lim);
}
unsigned LinIndexBuffer::size() const
{
    return _size;
}
double LinIndexBuffer::sample(unsigned i) const
{
    return _limits.start + i * _step;
}
Range LinIndexBuffer::limits() const
{
    return _limits;
}
void LinIndexBuffer::resize(unsigned n)
{
    _size = n;
    setLimits(_limits);         // called to update `_step`
}
int LinIndexBuffer::findIndex(double value) const
{
    if (value < _limits.start || value > _limits.end)
    {
        return OUT_OF_RANGE;
    }
    int r = (value - _limits.start) / _step;
    // Note: we are limiting return value because of floating point in-accuracies
    return std::min<int>(std::max<int>(r, 0), (_size-1));
}
void LinIndexBuffer::setLimits(Range lim)
{
    _limits = lim;
    _step = (lim.end - lim.start) / (_size-1);
}