PlayaSerialVectorType.hpp
Go to the documentation of this file.
00001 /* @HEADER@ */
00002 // ************************************************************************
00003 // 
00004 //                 Playa: Programmable Linear Algebra
00005 //                 Copyright 2012 Sandia Corporation
00006 // 
00007 // Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
00008 // the U.S. Government retains certain rights in this software.
00009 //
00010 // Redistribution and use in source and binary forms, with or without
00011 // modification, are permitted provided that the following conditions are
00012 // met:
00013 //
00014 // 1. Redistributions of source code must retain the above copyright
00015 // notice, this list of conditions and the following disclaimer.
00016 //
00017 // 2. Redistributions in binary form must reproduce the above copyright
00018 // notice, this list of conditions and the following disclaimer in the
00019 // documentation and/or other materials provided with the distribution.
00020 //
00021 // 3. Neither the name of the Corporation nor the names of the
00022 // contributors may be used to endorse or promote products derived from
00023 // this software without specific prior written permission.
00024 //
00025 // THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
00026 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00027 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
00028 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
00029 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
00030 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
00031 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
00032 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
00033 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
00034 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00035 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00036 //
00037 // Questions? Contact Kevin Long (kevin.long@ttu.edu)
00038 // 
00039 
00040 /* @HEADER@ */
00041 
00042 #ifndef PLAYA_SERIAL_VECTORTYPE_HPP
00043 #define PLAYA_SERIAL_VECTORTYPE_HPP
00044 
00045 #include "PlayaSerialVectorSpace.hpp"
00046 #include "PlayaHandleable.hpp"
00047 #include "PlayaPrintable.hpp"
00048 #include "Teuchos_Describable.hpp"
00049 #include "PlayaVectorTypeBase.hpp"
00050 //#include "PlayaLinearOperatorDecl.hpp"
00051 
00052 
00053 namespace Playa
00054 {
00055 using namespace Teuchos;
00056   
00057 /**
00058  * \!brief Serial vector type is a factory for serial vector spaces. If used
00059 in a SPMD program the spece will be replicated on each processor. 
00060  */
00061 class SerialVectorType : public VectorTypeBase<double>,
00062                          public Handleable<VectorTypeBase<double> >,
00063                          public Printable,
00064                          public Describable
00065 {
00066 public:
00067   /** Construct a vector type */
00068   SerialVectorType();
00069       
00070   /** virtual dtor */
00071   virtual ~SerialVectorType() {;}
00072 
00073   /** create a distributed vector space.
00074    * @param dimension the dimension of the space 
00075    * @param nLocal number of indices owned by the local processor
00076    * @param locallyOwnedIndices array of indices owned by this processor  
00077    */
00078   RCP<const VectorSpaceBase<double> > 
00079   createSpace(int dimension, 
00080     int nLocal,
00081     const int* locallyOwnedIndices,
00082     const MPIComm& comm) const ;
00083 
00084 
00085   /** Default implementation creates a vector space having 
00086    * nLocal elements on each processor. Serial types should override this
00087    * to produce a replicated space. */
00088   virtual VectorSpace<double> 
00089   createEvenlyPartitionedSpace(const MPIComm& comm,
00090     int nLocal) const ;
00091 
00092 
00093   /**  
00094    * Create an importer for accessing ghost elements.
00095    * @param space the distributed vector space on which ghost elements
00096    * are to be shared
00097    * @param nGhost number of ghost elements needed by this processor
00098    * @param ghostIndices read-only C array of off-processor indices needed
00099    * by this processor.
00100    * @return A RCP to a GhostImporter object.
00101    */
00102   RCP<GhostImporter<double> > 
00103   createGhostImporter(const VectorSpace<double>& space,
00104     int nGhost,
00105     const int* ghostIndices) const ;
00106 
00107 
00108   /**
00109    * Create a matrix factory of type compatible with this vector type,
00110    * sized according to the given domain and range spaces.
00111    */
00112   RCP<MatrixFactory<double> >
00113   createMatrixFactory(const VectorSpace<double>& domain,
00114     const VectorSpace<double>& range) const ;
00115 
00116     
00117 
00118   /** \name Printable interface */
00119   //@{
00120   /** Print to stream */
00121   void print(std::ostream& os) const {os << description();}
00122   //@}
00123 
00124   GET_RCP(VectorTypeBase<double>);
00125 };
00126   
00127 }
00128 
00129 #endif

Site Contact