This file is indexed.

/usr/include/trilinos/AbstractLinAlgPack_MatrixVectorTemplateOp.hpp is in libtrilinos-dev 10.4.0.dfsg-1ubuntu2.

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
// @HEADER
// ***********************************************************************
// 
// Moocho: Multi-functional Object-Oriented arCHitecture for Optimization
//                  Copyright (2003) Sandia Corporation
// 
// Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
// license for use of this work by or on behalf of the U.S. Government.
// 
// This library is free software; 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 2.1 of the
// License, or (at your option) any later version.
//  
// This library is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
// Lesser General Public License for more details.
//  
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
// USA
// Questions? Contact Roscoe A. Bartlett (rabartl@sandia.gov) 
// 
// ***********************************************************************
// @HEADER

#ifndef MATRIX_VECTOR_TEMPLATE_OP_H
#define MATRIX_VECTOR_TEMPLATE_OP_H

#include <stdexcept>
#include "AbstractLinAlgPack_Types.hpp"

namespace AbstractLinAlgPack {

/** @name {\bf Templated Matrix-DVector Operations}.
  *
  * These are the declarations (AbstractLinAlgPack_MatrixVectorTemplateOp.hpp) for template functions for
  * performing selected matrix-vector and matrix-matrix operations.  The templated
  * matrix type must have the following interface:
  * \begin{itemize}
  * \item #T_Matrix::size_type# - Member type for the type returned by #rows# and #cols#
  * \item #T_Matrix::row_type# - Member type for the type returned by #row(i)#
  * \item #T_Matrix::col_type# - Member type for the type returned by #col(j)#
  * \item #T_Matrix::size_type T_Matrix::rows() const#
  * \item #T_Matrix::size_type T_Matrix::cols() const#
  * \item #const T_Matrix::row_type& T_Matrix::row(size_type i) const# \
  *		- Returns a reference to the ith row (1,2,...,#T_Matrix::rows()#).
  * \item #const T_Matrix::col_type& T_Matrix::col(size_type j) const# \ 
  *		- Returns a reference to the ith row (1,2,...,#T_Rect_Matrix::rows()#).
  * \end{itemize}
  *
  * In addition, the following operations (UML notation) must be accessible for the types
  * #T_Matrix::row_type# and #T_Matrix::col_type# when these template functions
  * are instantiated:
  *
  * assign(v_lhs:DVector&,v_rhs:T_Matrix::const row_type&)
  * assign(vs_lhs:DVectorSlice&,v_rhs:const T_Matrix::row_type&)
  * dot(vs_rhs1:const DVectorSlice&, vs_rhs2: const T_Matrix::row_type&):value_type 
  * dot(vs_rhs1:const DVectorSlice&, vs_rhs2: const T_Matrix::col_type&):value_type 
  */
//@{

// ////////////////////////
// assign to a dense matrix

/// gm_lhs = T_M (templated matrix type T_M)
template<class T_Matrix>
void assign(DMatrix& gm_lhs, const T_Matrix& gm_rhs, BLAS_Cpp::Transp trans_rhs);

/// gms_lhs = T_M (templated matrix type T_M)
template<class T_Matrix>
void assign(DMatrixSlice& gms_lhs, const T_Matrix& gm_rhs, BLAS_Cpp::Transp trans_rhs);

// /////////////////////////////
// Matrix-DVector multiplication

/// v_lhs = T_M * vs_lhs (templated matrix type T_M)
template<class T_Matrix>
void V_MtV(DVector& v_lhs, const T_Matrix& gm_rhs1, BLAS_Cpp::Transp trans_rhs1
  , const DVectorSlice& vs_rhs2);

/// vs_lhs = T_M * vs_lhs (templated matrix type T_M)
template<class T_Matrix>
void V_MtV(DVectorSlice& v_lhs, const T_Matrix& gm_rhs1, BLAS_Cpp::Transp trans_rhs1
  , const DVectorSlice& vs_rhs2);

//@}

}

#endif // MATRIX_VECTOR_TEMPLATE_OP_H