/usr/include/CGAL/Linear_algebraCd.h is in libcgal-dev 4.5-2.
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 | // Copyright (c) 1999
// Utrecht University (The Netherlands),
// ETH Zurich (Switzerland),
// INRIA Sophia-Antipolis (France),
// Max-Planck-Institute Saarbruecken (Germany),
// and Tel-Aviv University (Israel). All rights reserved.
//
// This file is part of CGAL (www.cgal.org); you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public License as
// published by the Free Software Foundation; either version 3 of the License,
// or (at your option) any later version.
//
// Licensees holding a valid commercial license may use this file in
// accordance with the commercial license agreement provided with the software.
//
// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
//
// $URL$
// $Id$
//
//
// Author(s) : Herve.Bronnimann@sophia.inria.fr
#ifndef CGAL_LINEAR_ALGEBRACD_H
#define CGAL_LINEAR_ALGEBRACD_H
#include <CGAL/Kernel_d/Vector__.h>
#include <CGAL/Kernel_d/Matrix__.h>
#include <memory>
#include <vector>
#include <CGAL/Kernel_d/debug.h>
//#define CGAL_LA_SELFTEST
namespace CGAL {
template < class _FT, class _AL = CGAL_ALLOCATOR(_FT) >
class Linear_algebraCd
{
public:
typedef _FT FT;
typedef _FT RT;
typedef _AL AL;
typedef Linear_algebraCd<FT,AL> Self;
typedef Linear_Algebra::Vector_<FT,AL> Vector;
typedef Linear_Algebra::Matrix_<FT,AL> Matrix;
typedef const FT* const_iterator;
typedef FT* iterator;
Linear_algebraCd() {}
protected:
// Major routines for Linear_algebra_d
static
void Gaussian_elimination(const Matrix &M,
Matrix &L, Matrix &U,
std::vector<int> &row_permutation,
std::vector<int> &column_permutation,
FT &det, int &rank, Vector &c);
static
bool Triangular_system_solver(const Matrix &U, const Matrix &L,
const Vector &b, int rank, Vector &x, FT &det);
static
void Triangular_left_inverse(const Matrix &U, Matrix &Uinv);
public:
static
std::pair<int,int> transpose(std::pair<int,int> dim)
{ std::swap(dim.first,dim.second); return dim; }
static
Matrix transpose(const Matrix &M);
static
bool inverse(const Matrix &M, Matrix &I, FT &D, Vector &c);
static
Matrix inverse(const Matrix &M, RT &D);
static
FT determinant(const Matrix &M, Matrix &L, Matrix &U,
std::vector<int> &q, Vector &c);
static
FT determinant(const Matrix &M);
static
Sign sign_of_determinant(const Matrix &M);
static
bool verify_determinant(const Matrix &M, const RT &D,
const Matrix &L, const Matrix &U,
const std::vector<int> &q, const Vector &c);
static
bool linear_solver(const Matrix &M, const Vector &b,
Vector &x, RT &D, Matrix &spanning_vectors, Vector &c);
static
bool linear_solver(const Matrix &M, const Vector &b,
Vector &x, RT &D, Vector &c);
static
bool linear_solver(const Matrix &M, const Vector &b,
Vector &x, RT &D);
static
bool is_solvable(const Matrix &M, const Vector &b);
static
bool homogeneous_linear_solver(const Matrix &M, Vector &x);
static
int homogeneous_linear_solver(const Matrix &M,
Matrix &spanning_vectors);
static
int rank(const Matrix &M);
static
int independent_columns(const Matrix& M, std::vector<int>& columns);
};
} //namespace CGAL
#include <CGAL/Kernel_d/Linear_algebraCd_impl.h>
#endif // CGAL_LINEAR_ALGEBRACD_H
|