This file is indexed.

/usr/include/trilinos/Rythmos_extractStateAndSens.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
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
//@HEADER
// ***********************************************************************
//
//                     Rythmos Package
//                 Copyright (2006) 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 Todd S. Coffey (tscoffe@sandia.gov)
//
// ***********************************************************************
//@HEADER

#ifndef RYTHMOS_EXTRACT_STATE_AND_SENS_HPP
#define RYTHMOS_EXTRACT_STATE_AND_SENS_HPP


#include "Rythmos_Types.hpp"
#include "Thyra_DefaultMultiVectorProductVector.hpp"
#include "Thyra_ProductVectorBase.hpp"


namespace Rythmos {


/** \brief Extract the state and sensitivities from x_bar and x_bar_dot.
 *

 \verbatim

  x_bar = [ x ; s_bar ]

  x_bar_dot = [ x_dot; s_bar_dot ]

  s_bar = ..

  s_bar_dot = ...

 \endverbatim


 */
template<class Scalar>
void extractStateAndSens(
  const RCP<const Thyra::VectorBase<Scalar> > &x_bar,
  const RCP<const Thyra::VectorBase<Scalar> > &x_bar_dot,
  RCP<const Thyra::VectorBase<Scalar> > *x,
  RCP<const Thyra::MultiVectorBase<Scalar> > *S,
  RCP<const Thyra::VectorBase<Scalar> >  *x_dot,
  RCP<const Thyra::MultiVectorBase<Scalar> > *S_dot
  );


} // namespace Rythmos


//
// Implementations
//


template<class Scalar>
void Rythmos::extractStateAndSens(
  const RCP<const Thyra::VectorBase<Scalar> > &x_bar,
  const RCP<const Thyra::VectorBase<Scalar> > &x_bar_dot,
  RCP<const Thyra::VectorBase<Scalar> > *x,
  RCP<const Thyra::MultiVectorBase<Scalar> > *S,
  RCP<const Thyra::VectorBase<Scalar> >  *x_dot,
  RCP<const Thyra::MultiVectorBase<Scalar> > *S_dot
  )
{

  using Teuchos::rcp_dynamic_cast;

  TEST_FOR_EXCEPT(is_null(x_bar));
  TEST_FOR_EXCEPT(is_null(x_bar_dot));
  TEST_FOR_EXCEPT(0==x);
  TEST_FOR_EXCEPT(0==S);
  TEST_FOR_EXCEPT(0==x_dot);
  TEST_FOR_EXCEPT(0==S_dot);

  RCP<const Thyra::ProductVectorBase<Scalar> >
    x_bar_pv = Thyra::productVectorBase<Scalar>(x_bar),
    x_bar_dot_pv = Thyra::productVectorBase<Scalar>(x_bar_dot);
  RCP<const Thyra::DefaultMultiVectorProductVector<Scalar> >
    s_bar = rcp_dynamic_cast<const Thyra::DefaultMultiVectorProductVector<Scalar> >(
      x_bar_pv->getVectorBlock(1).assert_not_null(), true
      ),
    s_bar_dot = rcp_dynamic_cast<const Thyra::DefaultMultiVectorProductVector<Scalar> >(
      x_bar_dot_pv->getVectorBlock(1).assert_not_null(), true
      );
  *x = x_bar_pv->getVectorBlock(0);
  *S = s_bar->getMultiVector();
  *x_dot = x_bar_dot_pv->getVectorBlock(0);
  *S_dot = s_bar_dot->getMultiVector();

}


#endif //RYTHMOS_EXTRACT_STATE_AND_SENS_HPP