summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibPDF/Interpolation.cpp
blob: d42016cc6e1f7555d2012e2378e5920327116854 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/*
 * Copyright (c) 2022, Rodrigo Tobar <rtobarc@gmail.com>.
 *
 * SPDX-License-Identifier: BSD-2-Clause
 */

#include <LibPDF/Interpolation.h>

namespace PDF {

static float slope(float x_min, float x_max, float y_min, float y_max)
{
    return (y_max - y_min) / (x_max - x_min);
}

LinearInterpolation1D::LinearInterpolation1D(float x_min, float x_max, float y_min, float y_max)
    : m_x_min(x_min)
    , m_y_min(y_min)
    , m_slope(slope(x_min, x_max, y_min, y_max))
{
}

float LinearInterpolation1D::interpolate(float x) const
{
    return m_y_min + ((x - m_x_min) * m_slope);
}

void LinearInterpolation1D::interpolate(Span<float> const& x, Span<float> y) const
{
    for (size_t i = 0; i < x.size(); ++i) {
        y[i] = interpolate(x[i]);
    }
}

}