forest.hpp
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2023-2024, 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
20 
21 #include <stddef.h>
22 
23 #include <type_traits>
24 
25 namespace ML {
26 namespace experimental {
27 namespace fil {
28 
29 /* A collection of trees which together form a forest model
30  */
31 template <tree_layout layout_v,
32  typename threshold_t,
33  typename index_t,
34  typename metadata_storage_t,
35  typename offset_t>
36 struct forest {
38  using io_type = threshold_t;
39  template <typename vector_output_t>
40  using raw_output_type = std::conditional_t<!std::is_same_v<vector_output_t, std::nullptr_t>,
41  std::remove_pointer_t<vector_output_t>,
42  typename node_type::threshold_type>;
43 
44  HOST DEVICE forest(node_type* forest_nodes,
45  index_type* forest_root_indexes,
46  index_type* node_id_mapping,
47  index_type num_trees,
49  : nodes_{forest_nodes},
50  root_node_indexes_{forest_root_indexes},
51  node_id_mapping_{node_id_mapping},
52  num_trees_{num_trees},
53  num_outputs_{num_outputs}
54  {
55  }
56 
57  /* Return pointer to the root node of the indicated tree */
58  HOST DEVICE auto* get_tree_root(index_type tree_index) const
59  {
60  return nodes_ + root_node_indexes_[tree_index];
61  }
62 
63  /* Return pointer to the mapping from internal node IDs to final node ID outputs.
64  * Only used when infer_type == infer_kind::leaf_id */
65  HOST DEVICE const auto* get_node_id_mapping() const { return node_id_mapping_; }
66 
67  /* Return the number of trees in this forest */
68  HOST DEVICE auto tree_count() const { return num_trees_; }
69 
70  /* Return the number of outputs per row for default evaluation of this
71  * forest */
72  HOST DEVICE auto num_outputs() const { return num_outputs_; }
73 
74  private:
75  node_type* nodes_;
76  index_type* root_node_indexes_;
77  index_type* node_id_mapping_;
78  index_type num_trees_;
79  index_type num_outputs_;
80 };
81 
82 } // namespace fil
83 } // namespace experimental
84 } // namespace ML
#define DEVICE
Definition: gpu_support.hpp:35
#define HOST
Definition: gpu_support.hpp:34
tree_layout
Definition: tree_layout.hpp:20
uint32_t index_type
Definition: index_type.hpp:21
Definition: dbscan.hpp:30
Definition: forest.hpp:36
HOST DEVICE forest(node_type *forest_nodes, index_type *forest_root_indexes, index_type *node_id_mapping, index_type num_trees, index_type num_outputs)
Definition: forest.hpp:44
threshold_t io_type
Definition: forest.hpp:38
std::conditional_t<!std::is_same_v< vector_output_t, std::nullptr_t >, std::remove_pointer_t< vector_output_t >, typename node_type::threshold_type > raw_output_type
Definition: forest.hpp:42
HOST DEVICE auto tree_count() const
Definition: forest.hpp:68
HOST DEVICE auto * get_tree_root(index_type tree_index) const
Definition: forest.hpp:58
HOST DEVICE const auto * get_node_id_mapping() const
Definition: forest.hpp:65
node< layout_v, threshold_t, index_t, metadata_storage_t, offset_t > node_type
Definition: forest.hpp:37
HOST DEVICE auto num_outputs() const
Definition: forest.hpp:72
Definition: node.hpp:93
threshold_t threshold_type
Definition: node.hpp:97