/usr/include/libwildmagic/Wm5IntpBSplineUniform.h is in libwildmagic-dev 5.13-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 | // Geometric Tools, LLC
// Copyright (c) 1998-2014
// Distributed under the Boost Software License, Version 1.0.
// http://www.boost.org/LICENSE_1_0.txt
// http://www.geometrictools.com/License/Boost/LICENSE_1_0.txt
//
// File Version: 5.0.1 (2010/10/01)
#ifndef WM5INTPBSPLINEUNIFORM_H
#define WM5INTPBSPLINEUNIFORM_H
#include "Wm5MathematicsLIB.h"
namespace Wm5
{
template <typename Real>
class WM5_MATHEMATICS_ITEM IntpBSplineUniform
{
public:
// Construction and destruction. IntpBSplineUniform accepts
// responsibility for deleting the input array data. The input array
// dim is copied.
IntpBSplineUniform (int dims, int degree, const int* dim, Real* data);
virtual ~IntpBSplineUniform ();
int GetDimension () const;
int GetDegree () const;
Real GetDomainMin (int i) const;
Real GetDomainMax (int i) const;
int GetGridMin (int i) const;
int GetGridMax (int i) const;
// spline evaluation for function interpolation (no derivatives)
virtual Real operator() (Real* X) = 0;
// spline evaluation, derivative counts given in dx[]
virtual Real operator() (int* dx, Real* X) = 0;
protected:
int mDims; // N, number of dimensions
int mDegree; // D, degree of polynomial spline
int mDp1; // D+1
int mDp1ToN; // power(D+1,N)
int mDp1To2N; // power(D+1,2N)
int* mDim; // dimension sizes dim[0] through dim[N-1]
Real* mData; // N-dimensional array of data
Real* mDomMin; // minimum allowed value of spline input vector
Real* mDomMax; // maximum allowed value of spline input vector
int* mGridMin; // minimum allowed value for current local grid
int* mGridMax; // maximum allowed value for current local grid
int* mBase; // base indices for grid of local control points
int* mOldBase; // old base indices for grid of local control points
Real** mMatrix; // (D+1)x(D+1) blending matrix
Real* mCache; // cache for subblock of data
Real* mInter; // intermediate product of data with blending matrix
Real** mPoly; // poly[N][D+1], store polynomials and derivatives
Real** mCoeff; // coefficients for polynomial construction
Real* mProduct; // outer tensor product of m with itself N times
int* mSkip; // for skipping zero values of mtensor
Real (*mEvaluateCallback)(int);
virtual void EvaluateUnknownData () = 0;
virtual void ComputeIntermediate () = 0;
void SetPolynomial (int order, Real diff, Real* poly);
static int Choose (int n, int k); // n choose k
static Real** BlendMatrix (int degree);
};
typedef IntpBSplineUniform<float> IntpBSplineUniformf;
typedef IntpBSplineUniform<double> IntpBSplineUniformd;
}
#endif
|