EpetraExt Package Browser (Single Doxygen Collection)
Development
Toggle main menu visibility
Loading...
Searching...
No Matches
src
model_evaluator
EpetraExt_PolynomialVectorTraits.h
Go to the documentation of this file.
1
//@HEADER
2
// ***********************************************************************
3
//
4
// EpetraExt: Epetra Extended - Linear Algebra Services Package
5
// Copyright (2011) Sandia Corporation
6
//
7
// Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
8
// the U.S. Government retains certain rights in this software.
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 Michael A. Heroux (maherou@sandia.gov)
38
//
39
// ***********************************************************************
40
//@HEADER
41
42
#ifndef EPETRA_EXT_POLYNOMIAL_VECTOR_TRAITS_H
43
#define EPETRA_EXT_POLYNOMIAL_VECTOR_TRAITS_H
44
45
#include "Teuchos_PolynomialTraits.hpp"
46
#include "Teuchos_RCP.hpp"
47
#include "
Epetra_Vector.h
"
48
49
namespace
Teuchos
{
50
52
57
template
<>
58
class
PolynomialTraits<
Epetra_Vector
> {
59
public
:
60
62
typedef
Epetra_Vector
coeff_type
;
63
65
typedef
double
scalar_type
;
66
68
static
inline
Teuchos::RCP<coeff_type>
clone
(
const
coeff_type
& c) {
69
return
Teuchos::rcp(
new
Epetra_Vector
(c));
70
}
71
73
static
inline
void
copy
(
const
coeff_type
& x,
coeff_type
* y) {
74
y->
Scale
(1.0, x);
75
}
76
78
static
inline
void
assign
(
coeff_type
* y,
const
scalar_type
& alpha) {
79
y->
PutScalar
(alpha);
80
}
81
83
static
inline
void
update
(
coeff_type
* y,
const
coeff_type
& x,
84
const
scalar_type
& beta) {
85
y->
Update
(1.0, x, beta);
86
}
87
88
};
// class PolynomialTraits<Epetra_Vector>
89
90
}
// namespace Teuchos
91
92
#endif
// EPETRA_EXT_POLYNOMIAL_VECTOR_TRAITS_Hx
Epetra_Vector.h
Epetra_MultiVector::Scale
int Scale(double ScalarValue)
Epetra_MultiVector::Update
int Update(double ScalarA, const Epetra_MultiVector &A, double ScalarThis)
Epetra_MultiVector::PutScalar
int PutScalar(double ScalarConstant)
Epetra_Vector
Teuchos::PolynomialTraits< Epetra_Vector >::copy
static void copy(const coeff_type &x, coeff_type *y)
Copy a coefficient.
Definition
EpetraExt_PolynomialVectorTraits.h:73
Teuchos::PolynomialTraits< Epetra_Vector >::scalar_type
double scalar_type
Typename of scalars.
Definition
EpetraExt_PolynomialVectorTraits.h:65
Teuchos::PolynomialTraits< Epetra_Vector >::clone
static Teuchos::RCP< coeff_type > clone(const coeff_type &c)
Clone a coefficient.
Definition
EpetraExt_PolynomialVectorTraits.h:68
Teuchos::PolynomialTraits< Epetra_Vector >::update
static void update(coeff_type *y, const coeff_type &x, const scalar_type &beta)
y = x + beta*y
Definition
EpetraExt_PolynomialVectorTraits.h:83
Teuchos::PolynomialTraits< Epetra_Vector >::coeff_type
Epetra_Vector coeff_type
Typename of coefficients.
Definition
EpetraExt_PolynomialVectorTraits.h:62
Teuchos::PolynomialTraits< Epetra_Vector >::assign
static void assign(coeff_type *y, const scalar_type &alpha)
Assign a scalar to a coefficient.
Definition
EpetraExt_PolynomialVectorTraits.h:78
Teuchos
Definition
EpetraExt_HDF5.h:59
Generated by
1.17.0