Newer
Older
/***************************************************************************
SegmentsTest.hpp - description
-------------------
begin : Dec 6, 2019
copyright : (C) 2019 by Tomas Oberhuber et al.
email : tomas.oberhuber@fjfi.cvut.cz
***************************************************************************/
/* See Copyright Notice in tnl/Copyright */
#include <TNL/Containers/Vector.h>
#include <TNL/Containers/VectorView.h>
#include <TNL/Math.h>
#include <iostream>
#ifdef HAVE_GTEST
#include <gtest/gtest.h>
template< typename Segments >
void test_SetSegmentsSizes_EqualSizes()
{
using DeviceType = typename Segments::DeviceType;
using IndexType = typename Segments::IndexType;
const IndexType segmentsCount = 20;
const IndexType segmentSize = 5;
TNL::Containers::Vector< IndexType, DeviceType, IndexType > segmentsSizes( segmentsCount );
Segments segments( segmentsSizes );
EXPECT_EQ( segments.getSegmentsCount(), segmentsCount );
EXPECT_EQ( segments.getSize(), segmentsCount * segmentSize );
EXPECT_LE( segments.getSize(), segments.getStorageSize() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( segments.getSegmentSize( i ), segmentSize );
Segments segments2( segments );
EXPECT_EQ( segments2.getSegmentsCount(), segmentsCount );
EXPECT_EQ( segments2.getSize(), segmentsCount * segmentSize );
EXPECT_LE( segments2.getSize(), segments2.getStorageSize() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( segments2.getSegmentSize( i ), segmentSize );
Segments segments3;
segments3.setSegmentsSizes( segmentsSizes );
EXPECT_EQ( segments3.getSegmentsCount(), segmentsCount );
EXPECT_EQ( segments3.getSize(), segmentsCount * segmentSize );
EXPECT_LE( segments3.getSize(), segments3.getStorageSize() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( segments3.getSegmentSize( i ), segmentSize );
using SegmentsView = typename Segments::ViewType;
SegmentsView segmentsView = segments.getView();
EXPECT_EQ( segmentsView.getSegmentsCount(), segmentsCount );
EXPECT_EQ( segmentsView.getSize(), segmentsCount * segmentSize );
EXPECT_LE( segmentsView.getSize(), segments.getStorageSize() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( segmentsView.getSegmentSize( i ), segmentSize );
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
}
template< typename Segments >
void test_SetSegmentsSizes_EqualSizes_EllpackOnly()
{
using DeviceType = typename Segments::DeviceType;
using IndexType = typename Segments::IndexType;
const IndexType segmentsCount = 20;
const IndexType segmentSize = 5;
Segments segments( segmentsCount, segmentSize );
EXPECT_EQ( segments.getSegmentsCount(), segmentsCount );
EXPECT_EQ( segments.getSize(), segmentsCount * segmentSize );
EXPECT_LE( segments.getSize(), segments.getStorageSize() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( segments.getSegmentSize( i ), segmentSize );
Segments segments2( segments );
EXPECT_EQ( segments2.getSegmentsCount(), segmentsCount );
EXPECT_EQ( segments2.getSize(), segmentsCount * segmentSize );
EXPECT_LE( segments2.getSize(), segments2.getStorageSize() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( segments2.getSegmentSize( i ), segmentSize );
Segments segments3;
segments3.setSegmentsSizes( segmentsCount, segmentSize );
EXPECT_EQ( segments3.getSegmentsCount(), segmentsCount );
EXPECT_EQ( segments3.getSize(), segmentsCount * segmentSize );
EXPECT_LE( segments3.getSize(), segments3.getStorageSize() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( segments3.getSegmentSize( i ), segmentSize );
using SegmentsView = typename Segments::ViewType;
SegmentsView segmentsView = segments.getView();
EXPECT_EQ( segmentsView.getSegmentsCount(), segmentsCount );
EXPECT_EQ( segmentsView.getSize(), segmentsCount * segmentSize );
EXPECT_LE( segmentsView.getSize(), segments.getStorageSize() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( segmentsView.getSegmentSize( i ), segmentSize );
void test_AllReduction_MaximumInSegments()
{
using DeviceType = typename Segments::DeviceType;
using IndexType = typename Segments::IndexType;
const IndexType segmentsCount = 20;
const IndexType segmentSize = 5;
TNL::Containers::Vector< IndexType, DeviceType, IndexType > segmentsSizes( segmentsCount );
segmentsSizes = segmentSize;
Segments segments( segmentsSizes );
TNL::Containers::Vector< IndexType, DeviceType, IndexType > v( segments.getStorageSize() );
auto init = [=] __cuda_callable__ ( const IndexType segmentIdx, const IndexType localIdx, const IndexType globalIdx, bool& compute ) mutable -> bool {
segments.forEachElement( init );
TNL::Containers::Vector< IndexType, DeviceType, IndexType >result( segmentsCount );
const auto v_view = v.getConstView();
auto result_view = result.getView();
auto fetch = [=] __cuda_callable__ ( IndexType segmentIdx, IndexType localIdx, IndexType globalIdx, bool& compute ) -> IndexType {
return v_view[ globalIdx ];
};
Tomáš Oberhuber
committed
auto reduce = [] __cuda_callable__ ( IndexType& a, const IndexType b ) -> IndexType {
return TNL::max( a, b );
};
auto keep = [=] __cuda_callable__ ( const IndexType i, const IndexType a ) mutable {
};
segments.allReduction( fetch, reduce, keep, std::numeric_limits< IndexType >::min() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( result.getElement( i ), ( i + 1 ) * segmentSize );
result_view = 0;
segments.getView().allReduction( fetch, reduce, keep, std::numeric_limits< IndexType >::min() );
for( IndexType i = 0; i < segmentsCount; i++ )
EXPECT_EQ( result.getElement( i ), ( i + 1 ) * segmentSize );