Tpetra parallel linear algebra
Version of the Day
Toggle main menu visibility
Loading...
Searching...
No Matches
core
src
Tpetra_EpetraRowMatrix.cpp
1
/*
2
// @HEADER
3
// ***********************************************************************
4
//
5
// Tpetra: Templated Linear Algebra Services Package
6
// Copyright (2008) Sandia Corporation
7
//
8
// Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
9
// the U.S. Government retains certain rights in this software.
10
//
11
// Redistribution and use in source and binary forms, with or without
12
// modification, are permitted provided that the following conditions are
13
// met:
14
//
15
// 1. Redistributions of source code must retain the above copyright
16
// notice, this list of conditions and the following disclaimer.
17
//
18
// 2. Redistributions in binary form must reproduce the above copyright
19
// notice, this list of conditions and the following disclaimer in the
20
// documentation and/or other materials provided with the distribution.
21
//
22
// 3. Neither the name of the Corporation nor the names of the
23
// contributors may be used to endorse or promote products derived from
24
// this software without specific prior written permission.
25
//
26
// THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
27
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
30
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
31
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
32
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
33
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
34
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
35
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
36
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37
//
38
// Questions? Contact Michael A. Heroux (maherou@sandia.gov)
39
//
40
// ************************************************************************
41
// @HEADER
42
*/
43
44
#include "Tpetra_EpetraRowMatrix.hpp"
45
#if defined(HAVE_TPETRA_EPETRA)
46
47
#ifdef HAVE_TPETRACORE_MPI
48
# include "Epetra_MpiComm.h"
49
# include "
Tpetra_Details_extractMpiCommFromTeuchos.hpp
"
50
#else
51
# include "Epetra_SerialComm.h"
52
#endif
// HAVE_TPETRACORE_MPI
53
54
namespace
Tpetra
{
55
namespace
Details
{
56
57
#ifdef HAVE_TPETRACORE_MPI
58
std::shared_ptr<Epetra_Comm>
59
makeEpetraCommFromTeuchosComm (
const
Teuchos::Comm<int>& teuchosComm)
60
{
61
using
Tpetra::Details::extractMpiCommFromTeuchos;
62
// NOTE (mfh 11 Oct 2017) Tpetra or Teuchos may free this MPI_Comm
63
// before Epetra is done with it. To ensure that this doesn't
64
// happen, best practice is not to let the Epetra_Comm outlive the
65
// input teuchosComm.
66
MPI_Comm mpiComm = extractMpiCommFromTeuchos (teuchosComm);
67
Epetra_MpiComm* epetraComm =
new
Epetra_MpiComm (mpiComm);
68
return
std::shared_ptr<Epetra_Comm> (
static_cast<
Epetra_Comm*
>
(epetraComm));
69
}
70
#else
71
std::shared_ptr<Epetra_Comm>
72
makeEpetraCommFromTeuchosComm (
const
Teuchos::Comm<int>&)
73
{
74
return
std::shared_ptr<Epetra_Comm> (
static_cast<
Epetra_Comm*
>
(
new
Epetra_SerialComm));
75
}
76
#endif
// HAVE_TPETRACORE_MPI
77
78
}
// namespace Details
79
}
// namespace Tpetra
80
81
#endif
// defined(HAVE_TPETRA_EPETRA)
Tpetra_Details_extractMpiCommFromTeuchos.hpp
Declaration of Tpetra::Details::extractMpiCommFromTeuchos.
Tpetra::Details
Nonmember function that computes a residual Computes R = B - A * X.
Definition
Tpetra_KokkosRefactor_Details_MultiVectorLocalDeepCopy.hpp:51
Tpetra
Namespace Tpetra contains the class and methods constituting the Tpetra library.
Generated by
1.17.0