This file is indexed.

/usr/include/SurgSim/Math/LinearSparseSolveAndInverse.h is in libopensurgsim-dev 0.7.0-5.

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
// This file is a part of the OpenSurgSim project.
// Copyright 2013, SimQuest Solutions Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef SURGSIM_MATH_LINEARSPARSESOLVEANDINVERSE_H
#define SURGSIM_MATH_LINEARSPARSESOLVEANDINVERSE_H

#if defined(_MSC_VER)
#pragma warning(push)
#pragma warning(disable:4244)
#endif

#include <Eigen/SparseCore>
#include <unordered_map>

#include <boost/assign/list_of.hpp> // for 'map_list_of()'

#include "SurgSim/Math/Matrix.h"
#include "SurgSim/Math/SparseMatrix.h"
#include "SurgSim/Math/Vector.h"

namespace SurgSim
{

namespace Math
{

/// The linear numerical integration scheme supported
/// Each Linear Solver should have its own entry in this enum
enum LinearSolver
{
	LINEARSOLVER_LU = 0,
	LINEARSOLVER_CONJUGATEGRADIENT,
	MAX_LINEARSOLVER
};

const std::unordered_map<LinearSolver, std::string, std::hash<int>> LinearSolverNames =
			boost::assign::map_list_of
			(LINEARSOLVER_LU, "LINEARSOLVER_LU")
			(LINEARSOLVER_CONJUGATEGRADIENT, "LINEARSOLVER_CONJUGATEGRADIENT");

/// LinearSparseSolveAndInverse aims at performing an efficient linear system resolution and
/// calculating its inverse matrix at the same time.
/// This class is very useful in the OdeSolver resolution to improve performance.
/// \sa SurgSim::Math::OdeSolver
class LinearSparseSolveAndInverse
{
public:
	virtual ~LinearSparseSolveAndInverse() {}


	/// Set the linear solver matrix
	/// \param matrix the new matrix to solve/inverse for
	virtual void setMatrix(const SparseMatrix& matrix) = 0;

	/// Solve the linear system (matrix.x=b) using the matrix provided by the latest setMatrix call
	/// for all columns of the rhs matrix b.
	/// \param b The rhs matrix
	/// \return The solution matrix
	virtual Matrix solve(const Matrix& b) const = 0;

	/// \return The linear system's inverse matrix, i.e. the inverse of the matrix provided on the last setMatrix call
	virtual Matrix getInverse() const;

protected:
	/// A copy of the system matrix for use when an inverse is necessary.
	SparseMatrix m_matrix;
};

/// Derivation for sparse LU solver
class LinearSparseSolveAndInverseLU : public LinearSparseSolveAndInverse
{
public:
	void setMatrix(const SparseMatrix& matrix) override;

	Matrix solve(const Matrix& b) const override;

private:
	Eigen::SparseLU<SparseMatrix> m_solver;
};

/// Derivation for sparse CG solver
class LinearSparseSolveAndInverseCG : public LinearSparseSolveAndInverse
{
public:
	/// Set the conjugate gradient convergence tolerance
	/// \param tolerance the new convergence tolerance
	void setTolerance(double tolerance);

	/// Get the conjugate gradient convergence tolerance
	/// \return the convergence tolerance
	double getTolerance();

	/// Set the maximum number of iterations for conjugate gradient
	/// \param iterations the new maximum number of iterations
	void setMaxIterations(SparseMatrix::Index iterations);

	/// Get the conjugate gradient maximum iterations
	/// \return the maximum number of iterations allowed
	SparseMatrix::Index getMaxIterations();

	void setMatrix(const SparseMatrix& matrix) override;

	Matrix solve(const Matrix& b) const override;

private:
	Eigen::ConjugateGradient<SparseMatrix> m_solver;
};

}; // namespace Math

}; // namespace SurgSim

#if defined(_MSC_VER)
#pragma warning(pop)
#endif

#endif // SURGSIM_MATH_LINEARSPARSESOLVEANDINVERSE_H