Stokhos Package Browser (Single Doxygen Collection)
Version of the Day
Toggle main menu visibility
Loading...
Searching...
No Matches
test
UnitTest
Stokhos_TpetraCrsMatrixMPVectorUnitTest_Threads.cpp
Go to the documentation of this file.
1
// @HEADER
2
// ***********************************************************************
3
//
4
// Stokhos Package
5
// Copyright (2009) Sandia Corporation
6
//
7
// Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
8
// license for use of this work by or on behalf of the U.S. Government.
9
//
10
// Redistribution and use in source and binary forms, with or without
11
// modification, are permitted provided that the following conditions are
12
// met:
13
//
14
// 1. Redistributions of source code must retain the above copyright
15
// notice, this list of conditions and the following disclaimer.
16
//
17
// 2. Redistributions in binary form must reproduce the above copyright
18
// notice, this list of conditions and the following disclaimer in the
19
// documentation and/or other materials provided with the distribution.
20
//
21
// 3. Neither the name of the Corporation nor the names of the
22
// contributors may be used to endorse or promote products derived from
23
// this software without specific prior written permission.
24
//
25
// THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
26
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
29
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
31
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
32
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
34
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
35
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36
//
37
// Questions? Contact Eric T. Phipps (etphipp@sandia.gov).
38
//
39
// ***********************************************************************
40
// @HEADER
41
42
#include "Teuchos_UnitTestHarness.hpp"
43
#include "Teuchos_UnitTestRepository.hpp"
44
#include "Teuchos_GlobalMPISession.hpp"
45
46
#include "
Stokhos_TpetraCrsMatrixMPVectorUnitTest.hpp
"
47
48
#include "Kokkos_Core.hpp"
49
#include <Tpetra_KokkosCompat_ClassicNodeAPI_Wrapper.hpp>
50
51
// Instantiate tests for threads node
52
typedef
Tpetra::KokkosCompat::KokkosDeviceWrapperNode<Kokkos::Threads>
ThreadsWrapperNode
;
53
CRSMATRIX_MP_VECTOR_TESTS_N
(
ThreadsWrapperNode
)
54
55
int
main
(
int
argc,
char
*
argv
[] ) {
56
Teuchos::GlobalMPISession mpiSession(&argc, &
argv
);
57
58
Kokkos::global_sacado_mp_vector_size
=
VectorSize
;
59
60
// Initialize threads
61
const
size_t
num_cores
=
62
Kokkos::hwloc::get_available_numa_count() *
63
Kokkos::hwloc::get_available_cores_per_numa();
64
const
size_t
num_hyper_threads
=
65
Kokkos::hwloc::get_available_threads_per_core();
66
// const size_t num_cores = 1;
67
// const size_t num_hyper_threads = 1;
68
Kokkos::InitializationSettings init_args;
69
init_args.set_num_threads(
num_cores
*
num_hyper_threads
);
70
Kokkos::initialize( init_args );
71
Kokkos::print_configuration(std::cout);
72
73
// Run tests
74
Teuchos::UnitTestRepository::setGloballyReduceTestResult(
true
);
75
int
ret = Teuchos::UnitTestRepository::runUnitTestsFromMain(argc,
argv
);
76
77
// Finish up
78
Kokkos::finalize();
79
80
return
ret;
81
}
argv
char * argv[]
Definition
Stokhos_HouseTriDiagUnitTest.cpp:286
VectorSize
const unsigned VectorSize
Definition
Stokhos_KokkosCrsMatrixMPVectorUnitTest.hpp:348
num_hyper_threads
size_t num_hyper_threads
Definition
Stokhos_KokkosCrsMatrixMPVectorUnitTest_OpenMP.cpp:76
num_cores
size_t num_cores
Definition
Stokhos_KokkosCrsMatrixMPVectorUnitTest_OpenMP.cpp:76
Stokhos_TpetraCrsMatrixMPVectorUnitTest.hpp
CRSMATRIX_MP_VECTOR_TESTS_N
#define CRSMATRIX_MP_VECTOR_TESTS_N(N)
Definition
Stokhos_TpetraCrsMatrixMPVectorUnitTest.hpp:2540
ThreadsWrapperNode
Tpetra::KokkosCompat::KokkosDeviceWrapperNode< Kokkos::Threads > ThreadsWrapperNode
Definition
Stokhos_TpetraCrsMatrixMPVectorUnitTest_Threads.cpp:52
main
int main(int argc, char *argv[])
Kokkos::global_sacado_mp_vector_size
unsigned global_sacado_mp_vector_size
Definition
Kokkos_View_MP_Vector.cpp:46
Generated by
1.17.0