-
Notifications
You must be signed in to change notification settings - Fork 20
/
CMakeLists.txt
232 lines (201 loc) · 8.83 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
# ======================================================================== #
# Copyright 2021-2024 Ingo Wald #
# #
# Licensed under the Apache License, Version 2.0 (the "License"); #
# you may not use this file except in compliance with the License. #
# You may obtain a copy of the License at #
# #
# http://www.apache.org/licenses/LICENSE-2.0 #
# #
# Unless required by applicable law or agreed to in writing, software #
# distributed under the License is distributed on an "AS IS" BASIS, #
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #
# See the License for the specific language governing permissions and #
# limitations under the License. #
# ======================================================================== #
cmake_policy(SET CMP0048 NEW)
project(cudaKDTree VERSION 1.0.0 LANGUAGES C CXX CUDA)
cmake_minimum_required(VERSION 3.16)
#set(CMAKE_CXX_STANDARD 14)
#set(CMAKE_CXX_STANDARD_REQUIRED ON)
if(${CMAKE_VERSION} VERSION_GREATER_EQUAL 3.18)
cmake_policy(SET CMP0104 NEW)
endif()
if (NOT (${CMAKE_CURRENT_SOURCE_DIR} STREQUAL ${CMAKE_SOURCE_DIR}))
set(CUKD_IS_SUBPROJECT ON)
else()
set(CUKD_IS_SUBPROJECT OFF)
endif()
option(BUILD_ALL_TESTS "Build entire type/dimension/kernel test matrix?" OFF)
#add_subdirectory(../bitonic ext_bitonic EXCLUDE_FROM_ALL)
# ------------------------------------------------------------------
# general cmake project configs
# ------------------------------------------------------------------
set(CUKD_CUDA_ARCHITECTURES "auto" CACHE STRING "CUDA Arch(s) to build against")
mark_as_advanced(CUKD_CUDA_ARCHITECTURES)
if (NOT CUKD_IS_SUBPROJECT)
option(CUKD_ENABLE_STATS "Enable Stats tracking?" OFF)
if(NOT SET_UP_CONFIGURATIONS_DONE)
set(SET_UP_CONFIGURATIONS_DONE 1)
# No reason to set CMAKE_CONFIGURATION_TYPES if it's not a multiconfig generator
# Also no reason mess with CMAKE_BUILD_TYPE if it's a multiconfig generator.
if(CMAKE_CONFIGURATION_TYPES) # multiconfig generator?
set(CMAKE_CONFIGURATION_TYPES "Debug;Release" CACHE STRING "" FORCE)
else()
if(NOT CMAKE_BUILD_TYPE)
# message("Defaulting to release build.")
set(CMAKE_BUILD_TYPE Release CACHE STRING "" FORCE)
endif()
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY HELPSTRING "Choose the type of build")
# set the valid options for cmake-gui drop-down list
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "Debug;Release")
endif()
endif()
SET(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR})
SET(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR})
SET(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR})
endif()
# ------------------------------------------------------------------
# set cuda architectures, using following rule(s):
#
# a) if cmake_cuda_architectures is already set (from a parent project
# that included this), leave it unchanged.
#
# b) if not, but user wants to have a specific one (set via
# CUKD_CUDA_ARCHITECTURE) then use that;
#
# c) otherwise let cmake detect
# ------------------------------------------------------------------
if (DEFINED CMAKE_CUDA_ARCHITECTURES)
# somebnody else already defined it; leave it as is.
elseif (NOT (CUKD_CUDA_ARCHITECTURES STREQUAL "auto"))
# use has set this variable to something other than auto, let's use that
set(CMAKE_CUDA_ARCHITECTURES ${CUKD_CUDA_ARCHITECTURES})
else()
# not previously defined, and no wish to set an explicit one: jsut
# make sure cmake is happy:
if (NOT CMAKE_VERSION VERSION_LESS "3.17")
# newer versions of cmake need to have this to be not undefined;
# off then just menas 'autodetect'
set(CMAKE_CUDA_ARCHITECTURES OFF)
endif()
endif()
# ==================================================================
# this builds four variants of this library, that differ in how the
# k-d tree is being TRAVERSED:
#
# `cudaKDTree-default` uses a stack-based traversal, doesn't require
# the world-space bounding box
#
# `cudaKDTree-sf` uses a stack-free traversal. Can generate in more
# efficient code in some cases, but will suffer from the same issues
# as the default variant for certain combination of input point
# distributoins and query point distributions
#
# `cudaKDTree-cct` uses 'closest-corner-tracking', which can in some
# cases be faster than teh default traversal method (in particular if
# there is no good cut-off-radius, and queries can originate far from
# the data points, and/or for highly clustered data. It does however
# require to allocate and provide (a tiny amount of) memory for the
# builder to store the world-space bounding box of the input points,
# as well as to pass that pointer to the query method.
#
# ==================================================================
add_library(cudaKDTree INTERFACE)
target_sources(cudaKDTree INTERFACE
cukd/common.h
# iw, sep 22, 2024 - intentionally renamed from cukd/math.h to cukd/cukd-math.h to
# avoid name conflicts with system math.h if anybody adds cukd/ to include path
cukd/cukd-math.h
cukd/box.h
cukd/builder.h
cukd/builder_bitonic.h
cukd/builder_thrust.h
cukd/builder_inplace.h
# SPATIAL k-d tree, with planes at arbitrary locations
cukd/spatial-kdtree.h
cukd/fcp.h
cukd/knn.h
)
target_include_directories(cudaKDTree INTERFACE
${PROJECT_SOURCE_DIR}/
)
set_property(TARGET cudaKDTree PROPERTY PUBLIC CXX_STANDARD 14)
# ================================================================== a
# simple sample example of how to build a k-d tree
# ==================================================================
if (NOT CUKD_IS_SUBPROJECT)
add_executable(cukd_sample sample.cu)
target_link_libraries(cukd_sample cudaKDTree)
endif()
# ==================================================================
# create _a lot_ of test cases: this generates the whole matrix of
# traversal_method x num_dims x {fcp,knn}
# ==================================================================
if (BUILD_ALL_TESTS)
# test 2, 3, 4, and 8-dimensoinal data; the latter should - if it
# works for N=8, work for any other N>4
# set(DIMS_TO_BUILD 3)
set(DIMS_TO_BUILD 2 3 4 8)
foreach (D IN ITEMS ${DIMS_TO_BUILD})
# test all four possible traversal methosds
foreach(method stackBased stackFree cct)
# test knn queries, on regular trees (no explicit dimension per node)
add_executable(cukd_float${D}-knn-${method} testing/floatN-knn-and-fcp.cu)
target_link_libraries(cukd_float${D}-knn-${method} cudaKDTree)
target_compile_definitions(cukd_float${D}-knn-${method}
PUBLIC
-DD_FROM_CMAKE=${D}
-DUSE_KNN=1
-DTRAVERSAL_METHOD=${method})
# test knn queries, with 'explicit-dim' trees
add_executable(cukd_float${D}-knn-${method}-xd testing/floatN-knn-and-fcp.cu)
target_link_libraries(cukd_float${D}-knn-${method}-xd cudaKDTree)
target_compile_definitions(cukd_float${D}-knn-${method}-xd
PUBLIC
-DD_FROM_CMAKE=${D}
-DEXPLICIT_DIM=1
-DUSE_KNN=1
-DTRAVERSAL_METHOD=${method})
# test fcp queries, on regular trees
add_executable(cukd_float${D}-fcp-${method} testing/floatN-knn-and-fcp.cu)
target_link_libraries(cukd_float${D}-fcp-${method} cudaKDTree)
target_compile_definitions(cukd_float${D}-fcp-${method}
PUBLIC
-DD_FROM_CMAKE=${D}
-DTRAVERSAL_METHOD=${method})
# test fcp queries, with 'explicit-dim' trees
add_executable(cukd_float${D}-fcp-${method}-xd testing/floatN-knn-and-fcp.cu)
target_link_libraries(cukd_float${D}-fcp-${method}-xd cudaKDTree)
target_compile_definitions(cukd_float${D}-fcp-${method}-xd
PUBLIC
-DD_FROM_CMAKE=${D}
-DEXPLICIT_DIM=1
-DTRAVERSAL_METHOD=${method})
endforeach()
foreach(method stackBased cct)
# test knn queries, on regular trees (no explicit dimension per node)
add_executable(cukd_float${D}-knn-spatial-${method} testing/floatN-knn-and-fcp.cu)
target_link_libraries(cukd_float${D}-knn-spatial-${method} cudaKDTree)
target_compile_definitions(cukd_float${D}-knn-spatial-${method}
PUBLIC
-DD_FROM_CMAKE=${D}
-DSPATIAL=1
-DUSE_KNN=1
-DTRAVERSAL_METHOD=${method})
# test fcp queries, on regular trees
add_executable(cukd_float${D}-fcp-spatial-${method} testing/floatN-knn-and-fcp.cu)
target_link_libraries(cukd_float${D}-fcp-spatial-${method} cudaKDTree)
target_compile_definitions(cukd_float${D}-fcp-spatial-${method}
PUBLIC
-DSPATIAL=1
-DD_FROM_CMAKE=${D}
-DTRAVERSAL_METHOD=${method})
endforeach()
endforeach()
endif()
if (NOT CUKD_IS_SUBPROJECT)
# add some unit tests
include(CTest)
add_subdirectory(testing)
endif()