PlayaMatrixMarketIO.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 
00043 #ifndef PLAYA_MATRIXMARKETREADER_HPP
00044 #define PLAYA_MATRIXMARKETREADER_HPP
00045 
00046 #include <iostream>
00047 #include <iomanip>
00048 #include <vector>
00049 #include "EpetraExt_CrsMatrixIn.h"
00050 #include "EpetraExt_RowMatrixOut.h"
00051 #include "PlayaLinearOperatorImpl.hpp"
00052 #include "PlayaEpetraMatrix.hpp"
00053 #include "PlayaEpetraVectorSpace.hpp"
00054 #include "Epetra_SerialComm.h"
00055 
00056 #ifdef HAVE_MPI
00057 #include "Epetra_MpiComm.h"
00058 #endif
00059 
00060 using namespace EpetraExt;
00061 
00062 
00063 namespace Playa
00064 {
00065   /**
00066    * This function reads a real matrix from a Matrix Market file and creates
00067    * an Epetra_CrsMatrix wrapped in a Playa LinearOperator object.
00068    *
00069    * The hard work of reading the file is done by an EpetraExt function. The
00070    * rest is a matter of setting up RCPs and creating a VectorSpace for the
00071    * domain and range of the operator.
00072    */
00073   LinearOperator<double> readMatrixMarketFile(const string& fileName)
00074   {
00075     /* Call the epetraext function that reads the matrix and forms
00076      * an Epetra matrix object. */
00077 #ifdef HAVE_MPI
00078     Epetra_MpiComm comm(MPI_COMM_WORLD);
00079 #else
00080     Epetra_SerialComm comm;
00081 #endif
00082     Epetra_CrsMatrix *A;
00083     int ierr = MatrixMarketFileToCrsMatrix(fileName.c_str(),comm,A,false,true);
00084 
00085     TEUCHOS_TEST_FOR_EXCEPTION(ierr<0, std::runtime_error,
00086              "MatrixMarket reader failed with ierr=" << ierr);
00087 
00088     /* Capture the matrix pointer into an RCP */
00089     RCP<Epetra_CrsMatrix> Aptr = rcp(A);
00090 
00091     /* Get the map for the matrix's domain space */
00092     const Epetra_Map& dom = A->DomainMap();
00093 
00094     /* Form a vector space. Class EpetraVectorSpace is a subtype of class
00095      * Playa::VectorSpaceBase<double>. */
00096     EpetraVectorSpace* vs = new EpetraVectorSpace(rcp(new Epetra_Map(dom)));
00097     /* Capture into an RCP */
00098     RCP<const VectorSpaceBase<double> > vsb = rcp(vs);
00099     /* Capture into a vector space handle */
00100     VectorSpace<double> vecSpace(vsb);  
00101 
00102     /* Form the LinearOperator object. Note: the domain and range spaces are
00103      * identical here, which limits us to square matrices. This should be
00104      * fixed at some point. */
00105     RCP<LinearOperatorBase<double> > LOAb = rcp(new EpetraMatrix(Aptr,vecSpace,vecSpace));
00106     LinearOperator<double> LOA(LOAb);
00107     return LOA; 
00108   }
00109 
00110   void writeMatrixMarketFile(const string& filename,
00111            const LinearOperator<double>& A,
00112            const string& comment="")
00113   {
00114     RCP<const Epetra_CrsMatrix> crs = EpetraMatrix::getConcretePtr(A);
00115 
00116     int ierr = EpetraExt::RowMatrixToMatrixMarketFile(filename.c_str(),
00117                   *crs,
00118                   0,
00119                   comment.c_str());
00120     TEUCHOS_TEST_FOR_EXCEPT(ierr<0);
00121   }
00122 }
00123 
00124 #endif

Site Contact