18#ifdef DEAL_II_WITH_TRILINOS
20# ifdef DEAL_II_WITH_MPI
21# include <Epetra_MpiComm.h>
22# include <Teuchos_DefaultComm.hpp>
24# include <Epetra_SerialComm.h>
25# include <Teuchos_RCP.hpp>
33#ifdef DEAL_II_WITH_TRILINOS
39# ifdef DEAL_II_WITH_MPI
40 static Teuchos::RCP<Epetra_MpiComm> communicator =
41 Teuchos::rcp(
new Epetra_MpiComm(MPI_COMM_WORLD),
true);
43 static Teuchos::RCP<Epetra_SerialComm> communicator =
44 Teuchos::rcp(
new Epetra_SerialComm(),
true);
52 const Teuchos::RCP<const Teuchos::Comm<int>> &
55# ifdef DEAL_II_WITH_MPI
56 static auto communicator = Teuchos::RCP<const Teuchos::Comm<int>>(
57 new Teuchos::MpiComm<int>(MPI_COMM_SELF));
59 static auto communicator =
60 Teuchos::RCP<const Teuchos::Comm<int>>(
new Teuchos::Comm<int>());
71# ifdef DEAL_II_WITH_MPI
72 static Teuchos::RCP<Epetra_MpiComm> communicator =
73 Teuchos::rcp(
new Epetra_MpiComm(MPI_COMM_SELF),
true);
75 static Teuchos::RCP<Epetra_SerialComm> communicator =
76 Teuchos::rcp(
new Epetra_SerialComm(),
true);
87# ifdef DEAL_II_WITH_MPI
92 const Epetra_MpiComm *mpi_comm =
93 dynamic_cast<const Epetra_MpiComm *
>(&communicator);
94 if (mpi_comm !=
nullptr)
95 return new Epetra_MpiComm(
103 Assert(
dynamic_cast<const Epetra_SerialComm *
>(&communicator) !=
nullptr,
105 return new Epetra_SerialComm(
106 dynamic_cast<const Epetra_SerialComm &
>(communicator));
116# ifdef DEAL_II_WITH_MPI
117 Epetra_MpiComm *mpi_comm =
dynamic_cast<Epetra_MpiComm *
>(&communicator);
118 if (mpi_comm !=
nullptr)
121 *mpi_comm = Epetra_MpiComm(MPI_COMM_SELF);
133 return mpi_communicator.NumProc();
140 return static_cast<unsigned int>(mpi_communicator.MyPID());
148 if (map.LinearMap() ==
true)
155 return Epetra_Map(map.NumGlobalElements(),
164 return Epetra_Map(map.NumGlobalElements(),
166 map.MyGlobalElements(),
175#ifdef DEAL_II_TRILINOS_WITH_TPETRA
180 const Teuchos::RCP<
const Teuchos::Comm<int>> &teuchos_comm)
183# ifdef DEAL_II_WITH_MPI
185 const Teuchos::MpiComm<int> *mpi_comm =
186 dynamic_cast<const Teuchos::MpiComm<int> *
>(teuchos_comm.get());
190 out = *(mpi_comm->getRawMpiComm())();
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_DISABLE_EXTRA_DIAGNOSTICS
#define DEAL_II_NAMESPACE_CLOSE
#define DEAL_II_ENABLE_EXTRA_DIAGNOSTICS
#define Assert(cond, exc)
static ::ExceptionBase & ExcInternalError()
MPI_Comm duplicate_communicator(const MPI_Comm mpi_communicator)
void free_communicator(MPI_Comm mpi_communicator)
void destroy_communicator(Epetra_Comm &communicator)
Epetra_Map duplicate_map(const Epetra_BlockMap &map, const Epetra_Comm &comm)
unsigned int get_this_mpi_process(const Epetra_Comm &mpi_communicator)
unsigned int get_n_mpi_processes(const Epetra_Comm &mpi_communicator)
const Epetra_Comm & comm_self()
MPI_Comm teuchos_comm_to_mpi_comm(const Teuchos::RCP< const Teuchos::Comm< int > > &teuchos_comm)
const Teuchos::RCP< const Teuchos::Comm< int > > & tpetra_comm_self()
Epetra_Comm * duplicate_communicator(const Epetra_Comm &communicator)
const Epetra_Comm & comm_world()
*braid_SplitCommworld & comm