mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 19:07:36 +00:00
LibPDF: Add first interpolation methods
Interpolation is needed in more than one place, and I couldn't find a central place where I could borrow a readily available interpolation routine, so I've implemented the first simple interpolation object. More will follow for more complex scenarios.
This commit is contained in:
parent
e818c955b3
commit
2331fe5e68
3 changed files with 63 additions and 0 deletions
27
Userland/Libraries/LibPDF/Interpolation.h
Normal file
27
Userland/Libraries/LibPDF/Interpolation.h
Normal file
|
@ -0,0 +1,27 @@
|
|||
/*
|
||||
* Copyright (c) 2022, Rodrigo Tobar <rtobarc@gmail.com>.
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <AK/Span.h>
|
||||
#include <AK/Vector.h>
|
||||
|
||||
namespace PDF {
|
||||
|
||||
class LinearInterpolation1D {
|
||||
|
||||
public:
|
||||
LinearInterpolation1D(float x_min, float x_max, float y_min, float y_max);
|
||||
float interpolate(float) const;
|
||||
void interpolate(Span<float> const& x, Span<float> y) const;
|
||||
|
||||
private:
|
||||
float m_x_min;
|
||||
float m_y_min;
|
||||
float m_slope;
|
||||
};
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue