1 //=================================================================================================
2 /*!
3 //  \file src/mathtest/operations/dmatdmatkron/MDaMUb.cpp
4 //  \brief Source file for the MDaMUb dense matrix/dense matrix Kronecker product math test
5 //
6 //  Copyright (C) 2012-2020 Klaus Iglberger - All Rights Reserved
7 //
8 //  This file is part of the Blaze library. You can redistribute it and/or modify it under
9 //  the terms of the New (Revised) BSD License. Redistribution and use in source and binary
10 //  forms, with or without modification, are permitted provided that the following conditions
11 //  are met:
12 //
13 //  1. Redistributions of source code must retain the above copyright notice, this list of
14 //     conditions and the following disclaimer.
15 //  2. Redistributions in binary form must reproduce the above copyright notice, this list
16 //     of conditions and the following disclaimer in the documentation and/or other materials
17 //     provided with the distribution.
18 //  3. Neither the names of the Blaze development group nor the names of its contributors
19 //     may be used to endorse or promote products derived from this software without specific
20 //     prior written permission.
21 //
22 //  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
23 //  EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 //  OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
25 //  SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 //  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
27 //  TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
28 //  BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 //  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
30 //  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
31 //  DAMAGE.
32 */
33 //=================================================================================================
34 
35 
36 //*************************************************************************************************
37 // Includes
38 //*************************************************************************************************
39 
40 #include <cstdlib>
41 #include <iostream>
42 #include <blaze/math/DynamicMatrix.h>
43 #include <blaze/math/UniformMatrix.h>
44 #include <blazetest/mathtest/Creator.h>
45 #include <blazetest/mathtest/operations/dmatdmatkron/OperationTest.h>
46 #include <blazetest/system/MathTest.h>
47 
48 #ifdef BLAZE_USE_HPX_THREADS
49 #  include <hpx/hpx_main.hpp>
50 #endif
51 
52 
53 //=================================================================================================
54 //
55 //  MAIN FUNCTION
56 //
57 //=================================================================================================
58 
59 //*************************************************************************************************
main()60 int main()
61 {
62    std::cout << "   Running 'MDaMUb'..." << std::endl;
63 
64    using blazetest::mathtest::TypeA;
65    using blazetest::mathtest::TypeB;
66 
67    try
68    {
69       // Matrix type definitions
70       using MDa = blaze::DynamicMatrix<TypeA>;
71       using MUb = blaze::UniformMatrix<TypeB>;
72 
73       // Creator type definitions
74       using CMDa = blazetest::Creator<MDa>;
75       using CMUb = blazetest::Creator<MUb>;
76 
77       // Running tests with small matrices
78       for( size_t i=0UL; i<=4UL; ++i ) {
79          for( size_t j=0UL; j<=4UL; ++j ) {
80             for( size_t k=0UL; k<=4UL; ++k ) {
81                for( size_t l=0UL; l<=4UL; ++l ) {
82                   RUN_DMATDMATKRON_OPERATION_TEST( CMDa( i, j ), CMUb( k, l ) );
83                }
84             }
85          }
86       }
87 
88       // Running tests with large matrices
89       RUN_DMATDMATKRON_OPERATION_TEST( CMDa(  9UL, 15UL ), CMUb( 16UL,  8UL ) );
90       RUN_DMATDMATKRON_OPERATION_TEST( CMDa(  9UL, 15UL ), CMUb(  8UL, 16UL ) );
91       RUN_DMATDMATKRON_OPERATION_TEST( CMDa( 16UL,  8UL ), CMUb(  9UL, 15UL ) );
92       RUN_DMATDMATKRON_OPERATION_TEST( CMDa( 16UL,  8UL ), CMUb( 15UL,  9UL ) );
93    }
94    catch( std::exception& ex ) {
95       std::cerr << "\n\n ERROR DETECTED during dense matrix/dense matrix Kronecker product:\n"
96                 << ex.what() << "\n";
97       return EXIT_FAILURE;
98    }
99 
100    return EXIT_SUCCESS;
101 }
102 //*************************************************************************************************
103