15#include <libcamera/base/span.h>
31 double k1 = 0.0,
double k2 = 0.0,
double k3 = 0.0,
33 : cx_(cx), cy_(cy), cnx_(0), cny_(0),
34 coefficients_({ k0, k1, k2, k3, k4 })
42 double r = sqrt(dx * dx + dy * dy);
44 for (
unsigned int i = 0; i < coefficients_.size(); i++) {
45 res += coefficients_[i] * std::pow(r, (i + 1) * 2);
52 double cpx = imageSize_.
width * cx_;
53 double cpy = imageSize_.
height * cy_;
54 double mx = std::max(cpx, std::fabs(imageSize_.
width - cpx));
55 double my = std::max(cpy, std::fabs(imageSize_.
height - cpy));
57 return sqrt(mx * mx + my * my);
67 cnx_ = (size.
width * cx_) / m;
68 cny_ = (size.
height * cy_) / m;
76 std::array<double, 5> coefficients_;
86struct ValueNode::Accessor<ipa::LscPolynomial> {
87 std::optional<ipa::LscPolynomial>
get(
const ValueNode &
obj)
const
89 std::optional<double>
cx =
obj[
"cx"].get<
double>();
90 std::optional<double>
cy =
obj[
"cy"].get<
double>();
91 std::optional<double>
k0 =
obj[
"k0"].get<
double>();
92 std::optional<double>
k1 =
obj[
"k1"].get<
double>();
93 std::optional<double>
k2 =
obj[
"k2"].get<
double>();
94 std::optional<double>
k3 =
obj[
"k3"].get<
double>();
95 std::optional<double>
k4 =
obj[
"k4"].get<
double>();
99 <<
"Polynomial is missing a parameter";
Describe a two-dimensional size.
Definition geometry.h:51
unsigned int width
The Size width.
Definition geometry.h:63
bool isNull() const
Check if the size is null.
Definition geometry.h:66
unsigned int height
The Size height.
Definition geometry.h:64
std::optional< T > get() const
Parse the ValueNode as a T value.
Definition value_node.h:211
Class for handling even polynomials used in lens shading correction.
Definition lsc_polynomial.h:28
void setReferenceImageSize(const Size &size)
Set the reference image size.
Definition lsc_polynomial.h:60
double getM() const
Get the value m as described in the dng specification.
Definition lsc_polynomial.h:50
LscPolynomial(double cx=0.0, double cy=0.0, double k0=0.0, double k1=0.0, double k2=0.0, double k3=0.0, double k4=0.0)
Construct a polynomial using the given coefficients.
Definition lsc_polynomial.h:30
double sampleAtNormalizedPixelPos(double x, double y) const
Sample the polynomial at the given normalized pixel position.
Definition lsc_polynomial.h:38
Data structures related to geometric objects.
#define LOG_DECLARE_CATEGORY(name)
Declare a category of log messages.
Definition log.h:51
#define LOG(category, severity)
Log a message.
Definition log.h:129
Top-level libcamera namespace.
Definition backtrace.h:17
Data structure to manage tree of values.