/usr/include/libwildmagic/Wm5ApprEllipsoidFit3.h is in libwildmagic-dev 5.13-1ubuntu3.
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 | // 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 WM5APPRELLIPSOIDFIT3_H
#define WM5APPRELLIPSOIDFIT3_H
// The ellipsoid in general form is X^t A X + B^t X + C = 0 where
// A is a positive definite 3x3 matrix, B is a 3x1 vector, C is a
// scalar, and X is a 3x1 vector. Completing the square,
// (X-U)^t A (X-U) = U^t A U - C where U = -0.5 A^{-1} B. Define
// M = A/(U^t A U - C). The ellipsoid is (X-U)^t M (X-U) = 1. Factor
// M = R^t D R where R is orthonormal and D is diagonal with positive
// diagonal terms. The ellipsoid in factored form is
// (X-U)^t R^t D^t R (X-U) = 1
//
// Find the least squares fit of a set of N points P[0] through P[N-1].
// The error return value is the least-squares energy function at (U,R,D).
// Real error = EllipseFit3<Real>(numPoints,points,U,R,D);
#include "Wm5MathematicsLIB.h"
#include "Wm5Matrix3.h"
namespace Wm5
{
template <typename Real>
class WM5_MATHEMATICS_ITEM EllipsoidFit3
{
public:
EllipsoidFit3 (int numPoints, const Vector3<Real>* points,
Vector3<Real>& center, Matrix3<Real>& rotate, Real diag[3]);
// Return the error value.
operator Real ();
private:
static void InitialGuess (int numPoints, const Vector3<Real>* points,
Vector3<Real>& center, Matrix3<Real>& rotate, Real diag[3]);
static Real Energy (const Real* input, void* userData);
static void MatrixToAngles (const Matrix3<Real>& rotate, Real* angle);
static void AnglesToMatrix (const Real* angle, Matrix3<Real>& rotate);
int mNumPoints;
const Vector3<Real>* mPoints;
Vector3<Real>* mTemp;
Real mError;
};
typedef EllipsoidFit3<float> EllipsoidFit3f;
typedef EllipsoidFit3<double> EllipsoidFit3d;
}
#endif
|