00001 /* *********************************************************************** 00002 // 00003 // TSFExtended: Trilinos Solver Framework Extended 00004 // Copyright (2004) Sandia Corporation 00005 // 00006 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive 00007 // license for use of this work by or on behalf of the U.S. Government. 00008 // 00009 // This library is free software; you can redistribute it and/or modify 00010 // it under the terms of the GNU Lesser General Public License as 00011 // published by the Free Software Foundation; either version 2.1 of the 00012 // License, or (at your option) any later version. 00013 // 00014 // This library is distributed in the hope that it will be useful, but 00015 // WITHOUT ANY WARRANTY; without even the implied warranty of 00016 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00017 // Lesser General Public License for more details. 00018 // 00019 // You should have received a copy of the GNU Lesser General Public 00020 // License along with this library; if not, write to the Free Software 00021 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00022 // USA 00023 // Questions? Contact Michael A. Heroux (maherou@sandia.gov) 00024 // 00025 // **********************************************************************/ 00026 00027 #ifndef TSF_SERIAL_GHOSTVIEW_HPP 00028 #define TSF_SERIAL_GHOSTVIEW_HPP 00029 00030 #include "SundanceDefs.hpp" 00031 #include "TSFGhostView.hpp" 00032 #include "TSFSerialVector.hpp" 00033 #include "Teuchos_Utils.hpp" 00034 00035 00036 00037 namespace TSFExtended 00038 { 00039 using namespace Teuchos; 00040 00041 00042 /** 00043 * Dummy ghost element viewer for serial vectors. 00044 */ 00045 class SerialGhostView : public GhostView<double> 00046 { 00047 public: 00048 /** */ 00049 SerialGhostView(const RCP<SerialVector>& vec) 00050 : vec_(vec) 00051 {;} 00052 00053 /** virtual dtor */ 00054 virtual ~SerialGhostView(){;} 00055 00056 /** Indicate whether the given global index is accessible in this view */ 00057 bool isAccessible(OrdType globalIndex) const 00058 {return true;} 00059 00060 /** get the element at the given global index */ 00061 const double& getElement(OrdType globalIndex) const 00062 {return vec_->getElement(globalIndex);} 00063 00064 /** get the batch of elements at the given global indices */ 00065 void getElements(const OrdType* globalIndices, OrdType numElems, 00066 Array<double>& elems) const 00067 { 00068 vec_->getElements(globalIndices, numElems, elems); 00069 } 00070 00071 /** */ 00072 void print(std::ostream& os) const {vec_->print(os);} 00073 private: 00074 RCP<const SerialVector> vec_; 00075 }; 00076 00077 } 00078 00079 #endif