Loading [MathJax]/extensions/tex2jax.js
Home
libcuml
cucim
cudf-java
cudf
cugraph
cuml
cuproj
cuspatial
cuvs
cuxfilter
dask-cuda
dask-cudf
kvikio
libcudf
libcuml
libcuproj
libcuspatial
libkvikio
librmm
libucxx
raft
rapids-cmake
rmm
nightly (25.04)
nightly (25.04)
stable (25.02)
legacy (24.12)
Main Page
Related Pages
Modules
Namespaces
Namespace List
Namespace Members
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
Functions
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
Variables
Typedefs
c
d
f
h
i
k
m
n
o
p
r
s
t
Enumerations
a
c
d
e
f
i
l
m
n
o
p
r
s
t
Enumerator
a
b
c
d
e
f
g
h
i
l
m
n
o
p
r
s
t
u
Classes
Class List
Class Index
Class Hierarchy
Class Members
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
~
Variables
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Typedefs
a
b
c
d
f
i
k
m
n
o
p
r
s
t
v
Enumerations
Enumerator
Related Functions
Files
File List
File Members
All
a
c
d
f
h
k
l
m
o
p
q
r
t
Functions
c
f
k
Typedefs
Enumerations
Enumerator
Macros
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Modules
Pages
include
cuml
experimental
forest
traversal
traversal_order.hpp
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2024-2025, NVIDIA CORPORATION.
3
*
4
* Licensed under the Apache License, Version 2.0 (the "License");
5
* you may not use this file except in compliance with the License.
6
* You may obtain a copy of the License at
7
*
8
* http://www.apache.org/licenses/LICENSE-2.0
9
*
10
* Unless required by applicable law or agreed to in writing, software
11
* distributed under the License is distributed on an "AS IS" BASIS,
12
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
* See the License for the specific language governing permissions and
14
* limitations under the License.
15
*/
16
#pragma once
17
18
namespace
ML
{
19
namespace
experimental {
20
namespace
forest {
21
22
/* A class used to specify the order in which nodes of a forest should be
23
* traversed
24
*
25
* Because the meaning of "left" and "right" vary by convention, we refer to the two children of a
26
* node as "hot" or "distant" rather than left or right. The "hot" child is the one which is
27
* traversed soonest after the parent, and the "distant" child is traversed latest.
28
*/
29
enum class
forest_order
: unsigned char {
30
// Traverse forest by proceeding depth-first through each tree
31
// consecutively
32
depth_first
= 0,
33
// Traverse forest by proceeding breadth-first through each tree
34
// consecutively
35
breadth_first
= 1,
36
// Traverse forest by proceeding through the root nodes of each tree first,
37
// followed by the hot and distant children of those root nodes for each tree,
38
// and so forth. This traversal order ensures that all nodes of a
39
// particular tree at a particular depth are traversed together.
40
layered_children_together
= 2,
41
// Traverse forest by proceeding through the root nodes of each tree first,
42
// followed by all of the hot children of those root nodes, then all of
43
// the distant children of those root nodes, and so forth. This
44
// traversal order ensures that all hot children at a particular depth
45
// are traversed together, followed by all distant children.
46
layered_children_segregated
= 3
47
};
48
49
}
// namespace forest
50
}
// namespace experimental
51
}
// namespace ML
ML::experimental::forest::forest_order
forest_order
Definition:
traversal_order.hpp:29
ML::experimental::forest::forest_order::layered_children_segregated
@ layered_children_segregated
ML::experimental::forest::forest_order::breadth_first
@ breadth_first
ML::experimental::forest::forest_order::layered_children_together
@ layered_children_together
ML::experimental::forest::forest_order::depth_first
@ depth_first
ML
Definition:
dbscan.hpp:30
Generated by
1.9.1