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
rapidsmpf
rmm
stable (25.08)
nightly (25.10)
stable (25.08)
legacy (25.06)
include
cuml
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
forest {
20
21
/* A class used to specify the order in which nodes of a forest should be
22
* traversed
23
*
24
* Because the meaning of "left" and "right" vary by convention, we refer to the two children of a
25
* node as "hot" or "distant" rather than left or right. The "hot" child is the one which is
26
* traversed soonest after the parent, and the "distant" child is traversed latest.
27
*/
28
enum class
forest_order
: unsigned char {
29
// Traverse forest by proceeding depth-first through each tree
30
// consecutively
31
depth_first
= 0,
32
// Traverse forest by proceeding breadth-first through each tree
33
// consecutively
34
breadth_first
= 1,
35
// Traverse forest by proceeding through the root nodes of each tree first,
36
// followed by the hot and distant children of those root nodes for each tree,
37
// and so forth. This traversal order ensures that all nodes of a
38
// particular tree at a particular depth are traversed together.
39
layered_children_together
= 2,
40
// Traverse forest by proceeding through the root nodes of each tree first,
41
// followed by all of the hot children of those root nodes, then all of
42
// the distant children of those root nodes, and so forth. This
43
// traversal order ensures that all hot children at a particular depth
44
// are traversed together, followed by all distant children.
45
layered_children_segregated
= 3
46
};
47
48
}
// namespace forest
49
}
// namespace ML
ML::forest::forest_order
forest_order
Definition:
traversal_order.hpp:28
ML::forest::forest_order::layered_children_segregated
@ layered_children_segregated
ML::forest::forest_order::breadth_first
@ breadth_first
ML::forest::forest_order::layered_children_together
@ layered_children_together
ML::forest::forest_order::depth_first
@ depth_first
ML
Definition:
dbscan.hpp:29
Generated by
1.9.1