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.
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.
46 };
47 
48 } // namespace forest
49 } // namespace ML
forest_order
Definition: traversal_order.hpp:28
Definition: dbscan.hpp:29