Thyra
Version of the Day
core
src
support
operator_vector
adapter_support
Thyra_SerialVectorSpaceConverterBase.hpp
1
// @HEADER
2
// ***********************************************************************
3
//
4
// Thyra: Interfaces and Support for Abstract Numerical Algorithms
5
// Copyright (2004) 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 Roscoe A. Bartlett (bartlettra@ornl.gov)
38
//
39
// ***********************************************************************
40
// @HEADER
41
42
#ifndef THYRA_SERIAL_VECTOR_SPACE_CONVERTED_BASE_HPP
43
#define THYRA_SERIAL_VECTOR_SPACE_CONVERTED_BASE_HPP
44
45
#include "Thyra_VectorSpaceConverterBase.hpp"
46
#include "Thyra_DetachedMultiVectorView.hpp"
47
48
49
namespace
Thyra {
50
51
61
template
<
class
ScalarFrom,
class
ScalarTo>
62
class
SerialVectorSpaceConverterBase
63
:
virtual
public
VectorSpaceConverterBase
<ScalarFrom,ScalarTo>
64
{
65
public
:
66
69
71
virtual
void
convert
(
72
const
MultiVectorBase<ScalarFrom>
&mv_from,
73
MultiVectorBase<ScalarTo>
*mv_to
74
)
const
;
75
77
78
};
79
80
81
// Implementation
82
83
84
template
<
class
ScalarFrom,
class
ScalarTo>
85
void
SerialVectorSpaceConverterBase<ScalarFrom,ScalarTo>::convert
(
86
const
MultiVectorBase<ScalarFrom>
&mv_from,
87
MultiVectorBase<ScalarTo>
*mv_to
88
)
const
89
{
90
#ifdef TEUCHOS_DEBUG
91
TEUCHOS_TEST_FOR_EXCEPT
(mv_to==NULL);
92
#endif
93
ConstDetachedMultiVectorView<ScalarFrom>
emv_from(mv_from);
94
DetachedMultiVectorView<ScalarTo>
emv_to(*mv_to);
95
#ifdef TEUCHOS_DEBUG
96
TEUCHOS_TEST_FOR_EXCEPT
(emv_from.
subDim
() != emv_to.
subDim
());
97
TEUCHOS_TEST_FOR_EXCEPT
(emv_from.
numSubCols
() != emv_to.
numSubCols
());
98
#endif
99
for
(
Ordinal
j = 0; j < emv_from.
numSubCols
(); ++j ) {
100
for
(
Ordinal
i = 0; i < emv_from.
subDim
(); ++i ) {
101
emv_to(i,j) = emv_from(i,j);
// ToDo: Make this faster using optimized copy functions?
102
}
103
}
104
}
105
106
107
}
// namespace Thyra
108
109
110
#endif // THYRA_SERIAL_VECTOR_SPACE_CONVERTED_BASE_HPP
Thyra::ConstDetachedMultiVectorView::subDim
Ordinal subDim() const
Definition:
Thyra_DetachedMultiVectorView.hpp:78
TEUCHOS_TEST_FOR_EXCEPT
#define TEUCHOS_TEST_FOR_EXCEPT(throw_exception_test)
Thyra::ConstDetachedMultiVectorView::numSubCols
Ordinal numSubCols() const
Definition:
Thyra_DetachedMultiVectorView.hpp:82
Thyra::SerialVectorSpaceConverterBase::convert
virtual void convert(const MultiVectorBase< ScalarFrom > &mv_from, MultiVectorBase< ScalarTo > *mv_to) const
Definition:
Thyra_SerialVectorSpaceConverterBase.hpp:85
Thyra::Ordinal
Teuchos::Ordinal Ordinal
Type for the dimension of a vector space. `*.
Definition:
Thyra_OperatorVectorTypes.hpp:127
Thyra::SerialVectorSpaceConverterBase
Node base class for converting serial multi-vectors (and vectors) from one scalar type to another.
Definition:
Thyra_SerialVectorSpaceConverterBase.hpp:62
Thyra::MultiVectorBase
Interface for a collection of column vectors called a multi-vector.
Definition:
Thyra_MultiVectorBase_decl.hpp:493
Thyra::DetachedMultiVectorView
Create an explicit mutable (non-const) view of a MultiVectorBase object.
Definition:
Thyra_DetachedMultiVectorView.hpp:108
Thyra::ConstDetachedMultiVectorView
Create an explicit non-mutable (const) view of a MultiVectorBase object.
Definition:
Thyra_DetachedMultiVectorView.hpp:57
Thyra::DetachedMultiVectorView::numSubCols
Ordinal numSubCols() const
Definition:
Thyra_DetachedMultiVectorView.hpp:133
Thyra::VectorSpaceConverterBase
Base interface for a factory that converts vector space types and vectors and multi-vectors from one ...
Definition:
Thyra_VectorSpaceConverterBase.hpp:71
Thyra::DetachedMultiVectorView::subDim
Ordinal subDim() const
Definition:
Thyra_DetachedMultiVectorView.hpp:129
Generated by
1.8.16