Zoltan2 Version of the Day
Zoltan2_TestHelpers.hpp
Go to the documentation of this file.
00001 // @HEADER
00002 //
00003 // ***********************************************************************
00004 //
00005 //   Zoltan2: A package of combinatorial algorithms for scientific computing
00006 //                  Copyright 2012 Sandia Corporation
00007 //
00008 // Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
00009 // the U.S. Government retains certain rights in this software.
00010 //
00011 // Redistribution and use in source and binary forms, with or without
00012 // modification, are permitted provided that the following conditions are
00013 // met:
00014 //
00015 // 1. Redistributions of source code must retain the above copyright
00016 // notice, this list of conditions and the following disclaimer.
00017 //
00018 // 2. Redistributions in binary form must reproduce the above copyright
00019 // notice, this list of conditions and the following disclaimer in the
00020 // documentation and/or other materials provided with the distribution.
00021 //
00022 // 3. Neither the name of the Corporation nor the names of the
00023 // contributors may be used to endorse or promote products derived from
00024 // this software without specific prior written permission.
00025 //
00026 // THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
00027 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00028 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
00029 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
00030 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
00031 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
00032 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
00033 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
00034 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
00035 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00036 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00037 //
00038 // Questions? Contact Karen Devine      (kddevin@sandia.gov)
00039 //                    Erik Boman        (egboman@sandia.gov)
00040 //                    Siva Rajamanickam (srajama@sandia.gov)
00041 //
00042 // ***********************************************************************
00043 //
00044 // @HEADER
00045 
00049 #ifndef ZOLTAN2_TESTHELPERS_HPP
00050 #define ZOLTAN2_TESTHELPERS_HPP
00051 
00052 #include <Zoltan2_Util.hpp>
00053 #include <iostream>
00054 
00055 typedef Kokkos::DefaultNode::DefaultNodeType node_t;
00056 
00057 // The path to the directory of test data
00058 
00059 #define STR_VALUE(path) #path
00060 #define PATH_NAME(path) STR_VALUE(path)
00061 
00062 #ifdef Z2_DATA_DIR
00063   std::string testDataFilePath(PATH_NAME(Z2_DATA_DIR));
00064 #else
00065   std::string testDataFilePath(".");
00066 #endif
00067 
00068 // The path to the Zoltan1 test directory.  We use
00069 // some of their data for testing.
00070 
00071 #ifdef Z1_TEST_DIR
00072   std::string zoltanTestDirectory(PATH_NAME(Z1_TEST_DIR));
00073 #else
00074   std::string zoltanTestDirectory(".");
00075 #endif
00076 
00077 //
00078 // If Tpetra is compiled with explicit instantiation,
00079 // then we will use these types in our tests.
00080 //
00081 // Epetra uses int, int, double data types.  If we
00082 // are using these data types, then we can test 
00083 // cases of Epetra user input.
00084 //
00085 
00086 
00087 #if defined HAVE_ZOLTAN2_INST_FLOAT_INT_LONG
00088 
00089 typedef int lno_t;
00090 typedef long gno_t;
00091 typedef float scalar_t;
00092 
00093 #elif defined HAVE_ZOLTAN2_INST_DOUBLE_INT_LONG
00094 
00095 typedef int lno_t;
00096 typedef long gno_t;
00097 typedef double scalar_t;
00098 
00099 #elif defined HAVE_ZOLTAN2_INST_FLOAT_INT_INT
00100 
00101 typedef int lno_t;
00102 typedef int gno_t;
00103 typedef float scalar_t;
00104 
00105 #elif defined HAVE_ZOLTAN2_INST_DOUBLE_INT_INT
00106 
00107 typedef int lno_t;
00108 typedef int gno_t;
00109 typedef double scalar_t;
00110 #define HAVE_EPETRA_DATA_TYPES
00111 
00112 #else
00113 
00114 typedef int lno_t;
00115 typedef int gno_t;
00116 typedef double scalar_t;
00117 #define HAVE_EPETRA_DATA_TYPES
00118 
00119 #endif
00120 
00121 #define MEMORY_CHECK(iPrint, msg) \
00122   if (iPrint){ \
00123     long kb = Zoltan2::getProcessKilobytes(); \
00124     std::cout.width(10); \
00125     std::cout.fill('*'); \
00126     std::cout << kb << " KB, " << msg << std::endl; \
00127     std::cout.width(0); \
00128     std::cout.fill(' '); \
00129   }
00130 
00131 #include <ErrorHandlingForTests.hpp>  
00132 #include <UserInputForTests.hpp>
00133 #include <PrintData.hpp>
00134 
00135 #endif