vspline 1.1.0
Generic C++11 Code for Uniform B-Splines
|
precalculated prefilter poles and basis function values More...
#include "common.h"
Go to the source code of this file.
Namespaces | |
namespace | vspline_constants |
Macros | |
#define | XLF(arg) (arg##L) |
#define | VSPLINE_POLES_H |
precalculated prefilter poles and basis function values
The contents of this file below the comments can be generated using bootstrap.cc
both the precalculated basis function values and the prefilter poles can be generated in arbitrary precision, so the constants below are given as 'xlf_type' - concrete splines will downcast them to whatever precision they use for prefiltering (usually the same type as the data type's elementary type).
The values defined here are used in several places in vspline. They are precomputed because calculating them when needed can be (potentially very) expensive, and providing them by definitions evaluated at compile time slows compilation. Great care is taken to provide very exact values. The code in bootstrap.cc goes beyond simply calculating polynomial roots with gsl/blas, adding a polishing stage done in arbitrary precision arithmetic. The basis function values are done as GMP fractions, and only divided out before the result is printed out.
The set of values provided here is sufficient to calculate the b-spline basis function for all spline degrees for arbitrary arguments (including the spline's derivatives) - see basis.h. The poles are needed for prefiltering.
Note: I have calculated the basis function values and prefilter poles using arbitrary-precision library GNU GMP. The precision of these values is way beyond long double and well sufficient to initialize quad floats (__float128) up to their precision, which is only 80bit mantissa or so. So now I express the literals below with a macro which adds a suffix to them so they can be interpreted as literals of the precision wanted for the given compile.
Definition in file poles.h.