$extrastylesheet
dtk_solution_transfer.h
Go to the documentation of this file.
00001 // The libMesh Finite Element Library.
00002 // Copyright (C) 2002-2014 Benjamin S. Kirk, John W. Peterson, Roy H. Stogner
00003 
00004 // This library is free software; you can redistribute it and/or
00005 // modify it under the terms of the GNU Lesser General Public
00006 // License as published by the Free Software Foundation; either
00007 // version 2.1 of the License, or (at your option) any later version.
00008 
00009 // This library is distributed in the hope that it will be useful,
00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00012 // Lesser General Public License for more details.
00013 
00014 // You should have received a copy of the GNU Lesser General Public
00015 // License along with this library; if not, write to the Free Software
00016 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00017 
00018 
00019 
00020 #ifndef DTKSOLUTIONTRANSFER_H
00021 #define DTKSOLUTIONTRANSFER_H
00022 
00023 #include "libmesh/libmesh_config.h"
00024 
00025 #ifdef LIBMESH_HAVE_DTK
00026 
00027 #include "libmesh/solution_transfer.h"
00028 #include "libmesh/dtk_adapter.h"
00029 
00030 // Trilinos
00031 #include <Teuchos_CommHelpers.hpp>
00032 #include <Teuchos_DefaultComm.hpp>
00033 
00034 // DTK
00035 #include <DTK_SharedDomainMap.hpp>
00036 
00037 #include <string>
00038 
00039 namespace libMesh {
00040 
00044 class DTKSolutionTransfer : public SolutionTransfer
00045 {
00046 public:
00047   DTKSolutionTransfer(const libMesh::Parallel::Communicator &comm
00048                       LIBMESH_CAN_DEFAULT_TO_COMMWORLD);
00049   virtual ~DTKSolutionTransfer();
00050 
00061   virtual void transfer(const Variable & from_var, const Variable & to_var);
00062 
00063 protected:
00064   typedef DataTransferKit::SharedDomainMap<DTKAdapter::MeshContainerType,DTKAdapter::MeshContainerType> shared_domain_map_type;
00065 
00067   Teuchos::RCP<const Teuchos::Comm<int> > comm_default;
00068 
00070   std::map<EquationSystems *, DTKAdapter *> adapters;
00071 
00073   std::map<std::pair<EquationSystems *, EquationSystems *>, shared_domain_map_type * > dtk_maps;
00074 };
00075 
00076 } // namespace libMesh
00077 
00078 #endif // #ifdef LIBMESH_HAVE_DTK
00079 
00080 #endif // #define DTKSOLUTIONTRANSFER_H