Fermat
contrib
cugar
basic
cuda
sort.h
Go to the documentation of this file.
1
/*
2
* cugar
3
* Copyright (c) 2011-2018, NVIDIA CORPORATION. All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are met:
7
* * Redistributions of source code must retain the above copyright
8
* notice, this list of conditions and the following disclaimer.
9
* * Redistributions in binary form must reproduce the above copyright
10
* notice, this list of conditions and the following disclaimer in the
11
* documentation and/or other materials provided with the distribution.
12
* * Neither the name of the NVIDIA CORPORATION nor the
13
* names of its contributors may be used to endorse or promote products
14
* derived from this software without specific prior written permission.
15
*
16
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
17
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19
* DISCLAIMED. IN NO EVENT SHALL NVIDIA CORPORATION BE LIABLE FOR ANY
20
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
*/
27
32
#pragma once
33
34
#include <cugar/basic/types.h>
35
36
namespace
cugar
{
37
namespace
cuda {
38
89
92
95
99
102
template
<
typename
Keys,
typename
Values = null_type>
103
struct
SortBuffers
104
{
107
SortBuffers
() : selector(0) {}
108
111
Keys
current_keys
()
const
{
return
keys[ selector ]; }
112
115
Values
current_values
()
const
{
return
values[ selector ]; }
116
117
uint32 selector;
118
Keys keys[2];
119
Values values[2];
120
};
121
160
struct
SortEnactor
161
{
164
SortEnactor
();
165
168
~
SortEnactor
();
169
170
void
sort(
const
uint32 count,
SortBuffers<uint8*, uint32*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 8);
171
void
sort(
const
uint32 count,
SortBuffers<uint16*,uint32*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 16);
172
void
sort(
const
uint32 count,
SortBuffers<uint32*,uint32*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 32);
173
void
sort(
const
uint32 count,
SortBuffers<uint32*,uint64*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 32);
174
void
sort(
const
uint32 count,
SortBuffers<uint64*,uint32*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 64);
175
void
sort(
const
uint32 count,
SortBuffers<uint64*,uint64*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 64);
176
void
sort(
const
uint32 count,
SortBuffers<uint8*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 8);
177
void
sort(
const
uint32 count,
SortBuffers<uint16*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 16);
178
void
sort(
const
uint32 count,
SortBuffers<uint32*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 32);
179
void
sort(
const
uint32 count,
SortBuffers<uint64*>
& buffers,
const
uint32 begin_bit = 0,
const
uint32 end_bit = 64);
180
181
private
:
182
void
* m_impl;
183
};
184
188
189
}
// namespace cuda
190
}
// namespace cugar
cugar::cuda::SortBuffers::SortBuffers
SortBuffers()
Definition:
sort.h:107
cugar::cuda::SortBuffers
Definition:
sort.h:103
cugar::cuda::SortBuffers::current_values
Values current_values() const
Definition:
sort.h:115
cugar::cuda::SortBuffers::current_keys
Keys current_keys() const
Definition:
sort.h:111
cugar
Define a vector_view POD type and plain_view() for std::vector.
Definition:
diff.h:38
cugar::cuda::SortEnactor
Definition:
sort.h:160
Generated by
1.8.13