Loading [MathJax]/extensions/tex2jax.js
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
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.
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.
47 };
48 
49 } // namespace forest
50 } // namespace experimental
51 } // namespace ML
forest_order
Definition: traversal_order.hpp:29
Definition: dbscan.hpp:30