/usr/include/libwildmagic/Wm5PolynomialRoots.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 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 | // 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 WM5POLYNOMIALROOTS_H
#define WM5POLYNOMIALROOTS_H
#include "Wm5MathematicsLIB.h"
#include "Wm5GMatrix.h"
#include "Wm5Vector3.h"
#include "Wm5Polynomial1.h"
namespace Wm5
{
// Methods are
//
// A: algebraic using closed-form expressions (fast, typically not robust)
// B: bisection (after root bounding, slow and robust)
// N: Newton's/bisection hybrid (after root bounding, medium and robust)
// E: eigenvalues of a companion matrix (fast and robust)
// Root bounds:
//
// For a monic polynomial
// x^n + a[n-1]*x^{n-1} + ... + a[1]*x + a[0]
// the Cauchy bound is
// M = 1 + max{|a[0]|,...,|a[n-1]|}.
// All real-value roots must lie in the interval [-M,M]. For a non-monic
// polynomial,
// b[n]*x^n + b[n-1]*x^{n-1} + ... + b[1]*x + b[0],
// if b[n] is not zero, divide through by it and calculate Cauchy's
// bound:
// 1 + max{|b[0]/b[n]|,...,|b[n-1]/b[n]|}.
template <typename Real>
class WM5_MATHEMATICS_ITEM PolynomialRoots
{
public:
// Construction and destruction.
PolynomialRoots (Real epsilon);
~PolynomialRoots ();
// Member access.
int GetCount () const;
const Real* GetRoots () const;
Real GetRoot (int i) const;
Real Epsilon;
// For FindE functions, default is 128.
int MaxIterations;
// Linear equations: c1*x+c0 = 0
bool FindA (Real c0, Real c1);
Real GetBound (Real c0, Real c1);
// Quadratic equations: c2*x^2+c1*x+c0 = 0
bool FindA (Real c0, Real c1, Real c2);
Real GetBound (Real c0, Real c1, Real c2);
// Cubic equations: c3*x^3+c2*x^2+c1*x+c0 = 0
bool FindA (Real c0, Real c1, Real c2, Real c3);
bool FindE (Real c0, Real c1, Real c2, Real c3, bool doBalancing);
Real GetBound (Real c0, Real c1, Real c2, Real c3);
// Solve A*r^3 + B*r = C where A > 0 and B > 0. This equation always has
// exactly one real-valued root.
Real SpecialCubic (Real a, Real b, Real c);
// Quartic equations: c4*x^4+c3*x^3+c2*x^2+c1*x+c0 = 0
bool FindA (Real c0, Real c1, Real c2, Real c3, Real c4);
bool FindE (Real c0, Real c1, Real c2, Real c3, Real c4,
bool doBalancing);
Real GetBound (Real c0, Real c1, Real c2, Real c3, Real c4);
// General equations: sum_{i=0}^{degree} c(i)*x^i = 0
bool FindB (const Polynomial1<Real>& poly, int digits);
bool FindN (const Polynomial1<Real>& poly, int digits);
bool FindE (const Polynomial1<Real>& poly, bool doBalancing);
Real GetBound (const Polynomial1<Real>& poly);
// Find roots on specified intervals.
bool FindB (const Polynomial1<Real>& poly, Real xMin, Real xMax,
int digits);
bool FindN (const Polynomial1<Real>& poly, Real xMin, Real xMax,
int digits);
bool AllRealPartsNegative (const Polynomial1<Real>& poly);
bool AllRealPartsPositive (const Polynomial1<Real>& poly);
// Count the number of roots on [t0,t1]. Uses Sturm sequences to do the
// counting. It is allowed to pass in t0 = -Math<Real>::MAX_REAL or
// t1 = Math<Real>::MAX_REAL. The value of mEpsilon is used as a
// threshold on the value of a Sturm polynomial at an end point. If
// smaller, that value is assumed to be zero. The return value is the
// number of roots. If there are infinitely many, -1 is returned.
int GetRootCount (const Polynomial1<Real>& poly, Real t0, Real t1);
private:
// Support for FindB.
bool Bisection (const Polynomial1<Real>& poly, Real xMin, Real xMax,
int digitsAccuracy, Real& root);
// Support for FindE.
void GetHouseholderVector (int size, const Vector3<Real>& U,
Vector3<Real>& V);
void PremultiplyHouseholder (GMatrix<Real>& mat, GVector<Real>& W,
int rMin, int rMax, int cMin, int cMax, int vSize,
const Vector3<Real>& V);
void PostmultiplyHouseholder (GMatrix<Real>& mat, GVector<Real>& W,
int rMin, int rMax, int cMin, int cMax, int vSize,
const Vector3<Real>& V);
void FrancisQRStep (GMatrix<Real>& H, GVector<Real>& W);
Real GetRowNorm (int row, GMatrix<Real>& mat);
Real GetColNorm (int col, GMatrix<Real>& mat);
void ScaleRow (int row, Real scale, GMatrix<Real>& mat);
void ScaleCol (int col, Real scale, GMatrix<Real>& mat);
void Balance3 (GMatrix<Real>& mat);
bool IsBalanced3 (GMatrix<Real>& mat);
void BalanceCompanion3 (GMatrix<Real>& mat);
bool IsBalancedCompanion3 (Real a10, Real a21, Real a02, Real a12,
Real a22);
bool QRIteration3 (GMatrix<Real>& mat);
void BalanceCompanion4 (GMatrix<Real>& mat);
bool IsBalancedCompanion4 (Real a10, Real a21, Real a32, Real a03,
Real a13, Real a23, Real a33);
bool QRIteration4 (GMatrix<Real>& mat);
// Support for testing if all roots have negative real parts.
bool AllRealPartsNegative (int degree, Real* coeff);
int mCount, mMaxRoot;
Real* mRoot;
};
typedef PolynomialRoots<float> PolynomialRootsf;
typedef PolynomialRoots<double> PolynomialRootsd;
}
#endif
|