Stokhos Package Browser (Single Doxygen Collection)
Version of the Day
Toggle main menu visibility
Loading...
Searching...
No Matches
src
epetra
Stokhos_EpetraMultiVectorOrthogPoly.hpp
Go to the documentation of this file.
1
// @HEADER
2
// ***********************************************************************
3
//
4
// Stokhos Package
5
// Copyright (2009) Sandia Corporation
6
//
7
// Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
8
// license for use of this work by or on behalf of the U.S. Government.
9
//
10
// Redistribution and use in source and binary forms, with or without
11
// modification, are permitted provided that the following conditions are
12
// met:
13
//
14
// 1. Redistributions of source code must retain the above copyright
15
// notice, this list of conditions and the following disclaimer.
16
//
17
// 2. Redistributions in binary form must reproduce the above copyright
18
// notice, this list of conditions and the following disclaimer in the
19
// documentation and/or other materials provided with the distribution.
20
//
21
// 3. Neither the name of the Corporation nor the names of the
22
// contributors may be used to endorse or promote products derived from
23
// this software without specific prior written permission.
24
//
25
// THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
26
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
29
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
31
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
32
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
34
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
35
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36
//
37
// Questions? Contact Eric T. Phipps (etphipp@sandia.gov).
38
//
39
// ***********************************************************************
40
// @HEADER
41
42
#ifndef STOKHOS_EPETRAMULTIVECTORORTHOGPOLY_HPP
43
#define STOKHOS_EPETRAMULTIVECTORORTHOGPOLY_HPP
44
45
#include "
Stokhos_VectorOrthogPoly.hpp
"
46
#include "
Stokhos_ProductEpetraMultiVector.hpp
"
47
48
namespace
Stokhos
{
49
55
class
EpetraMultiVectorOrthogPoly
:
56
public
VectorOrthogPoly
<Epetra_MultiVector>,
57
public
ProductEpetraMultiVector
{
58
public
:
59
61
typedef
double
value_type
;
62
64
typedef
int
ordinal_type
;
65
67
71
EpetraMultiVectorOrthogPoly
();
72
77
EpetraMultiVectorOrthogPoly
(
78
const
Teuchos::RCP<
const
Stokhos::OrthogPolyBasis<int, double>
>&
basis
,
79
const
Teuchos::RCP<const Epetra_BlockMap>& block_map);
80
85
EpetraMultiVectorOrthogPoly
(
86
const
Teuchos::RCP<
const
Stokhos::OrthogPolyBasis<int, double>
>&
basis
,
87
const
Teuchos::RCP<const Epetra_BlockMap>& block_map,
88
const
Teuchos::RCP<const Epetra_BlockMap>&
coeff_map
,
89
const
Teuchos::RCP<const EpetraExt::MultiComm>&
product_comm
,
90
int
num_vectors);
91
96
EpetraMultiVectorOrthogPoly
(
97
const
Teuchos::RCP<
const
Stokhos::OrthogPolyBasis<int, double>
>&
basis
,
98
const
Teuchos::RCP<const Epetra_BlockMap>& block_map,
99
const
Teuchos::RCP<const Epetra_BlockMap>&
coeff_map
,
100
const
Teuchos::RCP<const Epetra_BlockMap>&
product_map
,
101
const
Teuchos::RCP<const EpetraExt::MultiComm>&
product_comm
,
102
int
num_vectors);
103
108
EpetraMultiVectorOrthogPoly
(
109
const
Teuchos::RCP<
const
Stokhos::OrthogPolyBasis<int, double>
>&
basis
,
110
const
Teuchos::RCP<const Epetra_BlockMap>& block_map,
111
const
Teuchos::RCP<const Epetra_BlockMap>&
coeff_map
,
112
const
Teuchos::RCP<const Epetra_BlockMap>&
product_map
,
113
const
Teuchos::RCP<const EpetraExt::MultiComm>&
product_comm
,
114
Epetra_DataAccess
CV,
115
const
Epetra_MultiVector
& block_vector);
116
118
121
EpetraMultiVectorOrthogPoly
(
const
EpetraMultiVectorOrthogPoly
& v);
122
124
virtual
~EpetraMultiVectorOrthogPoly
();
125
127
130
EpetraMultiVectorOrthogPoly
&
operator=
(
const
EpetraMultiVectorOrthogPoly
& v);
131
133
136
void
reset
(
137
const
Teuchos::RCP<
const
Stokhos::OrthogPolyBasis<int, double>
>&
basis
,
138
const
Teuchos::RCP<const Epetra_BlockMap>& block_map,
139
const
Teuchos::RCP<const Epetra_BlockMap>&
coeff_map
,
140
const
Teuchos::RCP<const EpetraExt::MultiComm>&
product_comm
,
141
int
num_vectors);
142
144
147
void
reset
(
148
const
Teuchos::RCP<
const
Stokhos::OrthogPolyBasis<int, double>
>&
basis
,
149
const
Teuchos::RCP<const Epetra_BlockMap>& block_map,
150
const
Teuchos::RCP<const Epetra_BlockMap>&
coeff_map
,
151
const
Teuchos::RCP<const Epetra_BlockMap>&
product_map
,
152
const
Teuchos::RCP<const EpetraExt::MultiComm>&
product_comm
,
153
int
num_vectors);
154
156
void
computeMean
(
Epetra_MultiVector
& v)
const
;
157
159
void
computeVariance
(
Epetra_MultiVector
& v)
const
;
160
162
void
computeStandardDeviation
(
Epetra_MultiVector
& v)
const
;
163
164
};
// class EpetraMultiVectorOrthogPoly
165
166
}
// end namespace Stokhos
167
168
#endif
// STOKHOS_EPETRAMULTIVECTORORTHOGPOLY_HPP
Epetra_DataAccess
Epetra_DataAccess
Stokhos_ProductEpetraMultiVector.hpp
Stokhos_VectorOrthogPoly.hpp
Epetra_MultiVector
Stokhos::EpetraMultiVectorOrthogPoly::computeStandardDeviation
void computeStandardDeviation(Epetra_MultiVector &v) const
Compute standard deviation.
Definition
Stokhos_EpetraMultiVectorOrthogPoly.cpp:177
Stokhos::EpetraMultiVectorOrthogPoly::value_type
double value_type
Typename of values.
Definition
Stokhos_EpetraMultiVectorOrthogPoly.hpp:61
Stokhos::EpetraMultiVectorOrthogPoly::operator=
EpetraMultiVectorOrthogPoly & operator=(const EpetraMultiVectorOrthogPoly &v)
Assignment.
Definition
Stokhos_EpetraMultiVectorOrthogPoly.cpp:119
Stokhos::EpetraMultiVectorOrthogPoly::computeMean
void computeMean(Epetra_MultiVector &v) const
Compute mean.
Definition
Stokhos_EpetraMultiVectorOrthogPoly.cpp:156
Stokhos::EpetraMultiVectorOrthogPoly::~EpetraMultiVectorOrthogPoly
virtual ~EpetraMultiVectorOrthogPoly()
Destructor.
Definition
Stokhos_EpetraMultiVectorOrthogPoly.cpp:115
Stokhos::EpetraMultiVectorOrthogPoly::ordinal_type
int ordinal_type
Typename of ordinals.
Definition
Stokhos_EpetraMultiVectorOrthogPoly.hpp:64
Stokhos::EpetraMultiVectorOrthogPoly::reset
void reset(const Teuchos::RCP< const Stokhos::OrthogPolyBasis< int, double > > &basis, const Teuchos::RCP< const Epetra_BlockMap > &block_map, const Teuchos::RCP< const Epetra_BlockMap > &coeff_map, const Teuchos::RCP< const EpetraExt::MultiComm > &product_comm, int num_vectors)
Reset to a new basis.
Definition
Stokhos_EpetraMultiVectorOrthogPoly.cpp:127
Stokhos::EpetraMultiVectorOrthogPoly::computeVariance
void computeVariance(Epetra_MultiVector &v) const
Compute variance.
Definition
Stokhos_EpetraMultiVectorOrthogPoly.cpp:164
Stokhos::EpetraMultiVectorOrthogPoly::EpetraMultiVectorOrthogPoly
EpetraMultiVectorOrthogPoly()
Constructor with no basis.
Definition
Stokhos_EpetraMultiVectorOrthogPoly.cpp:45
Stokhos::OrthogPolyBasis
Abstract base class for multivariate orthogonal polynomials.
Definition
Stokhos_OrthogPolyBasis.hpp:74
Stokhos::ProductEpetraMultiVector::coeff_map
Teuchos::RCP< const Epetra_BlockMap > coeff_map
Product map of block vector.
Definition
Stokhos_ProductEpetraMultiVector.hpp:190
Stokhos::ProductEpetraMultiVector::product_map
Teuchos::RCP< const Epetra_BlockMap > product_map
Product map of block vector.
Definition
Stokhos_ProductEpetraMultiVector.hpp:196
Stokhos::ProductEpetraMultiVector::product_comm
Teuchos::RCP< const EpetraExt::MultiComm > product_comm
Product multi-level communicator.
Definition
Stokhos_ProductEpetraMultiVector.hpp:193
Stokhos::ProductEpetraMultiVector::ProductEpetraMultiVector
ProductEpetraMultiVector()
Default constructor.
Definition
Stokhos_ProductEpetraMultiVector.cpp:47
Stokhos::VectorOrthogPoly< Epetra_MultiVector >::basis
Teuchos::RCP< const Stokhos::OrthogPolyBasis< ordinal_type, value_type > > basis() const
Definition
Stokhos_VectorOrthogPolyImp.hpp:114
Stokhos::VectorOrthogPoly< Epetra_MultiVector >::VectorOrthogPoly
VectorOrthogPoly()
Definition
Stokhos_VectorOrthogPolyImp.hpp:46
Stokhos
Top-level namespace for Stokhos classes and functions.
Definition
Stokhos_AbstractPreconditionerFactory.hpp:48
Generated by
1.17.0