summaryrefslogtreecommitdiffstats
path: root/thirdparty/rvo2/rvo2_3d/KdTree3d.h
blob: 900d9a2169e913fcd63bff7491446435e7c5d719 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
 * KdTree3d.h
 * RVO2-3D Library
 *
 * SPDX-FileCopyrightText: 2008 University of North Carolina at Chapel Hill
 * SPDX-License-Identifier: Apache-2.0
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 * Please send all bug reports to <geom@cs.unc.edu>.
 *
 * The authors may be contacted via:
 *
 * Jur van den Berg, Stephen J. Guy, Jamie Snape, Ming C. Lin, Dinesh Manocha
 * Dept. of Computer Science
 * 201 S. Columbia St.
 * Frederick P. Brooks, Jr. Computer Science Bldg.
 * Chapel Hill, N.C. 27599-3175
 * United States of America
 *
 * <https://gamma.cs.unc.edu/RVO2/>
 */

#ifndef RVO3D_KD_TREE_H_
#define RVO3D_KD_TREE_H_

/**
 * @file  KdTree3d.h
 * @brief Contains the KdTree3D class.
 */

#include <cstddef>
#include <vector>

namespace RVO3D {
class Agent3D;
class RVOSimulator3D;

/**
 * @brief Defines a k-D tree for agents in the simulation.
 */
class KdTree3D {
 public:
  class AgentTreeNode;

  /**
   * @brief     Constructs a k-D tree instance.
   * @param[in] sim The simulator instance.
   */
  explicit KdTree3D(RVOSimulator3D *sim);

  /**
   * @brief Destroys this k-D tree instance.
   */
  ~KdTree3D();

  /**
   * @brief Builds an agent k-D tree.
   */
  void buildAgentTree(std::vector<Agent3D *> agents);

  /**
   * @brief     Recursive function to build a k-D tree.
   * @param[in] begin The beginning k-D tree node.
   * @param[in] end   The ending k-D tree node.
   * @param[in] node  The current k-D tree node.
   */
  void buildAgentTreeRecursive(std::size_t begin, std::size_t end,
                               std::size_t node);

  /**
   * @brief     Computes the agent neighbors of the specified agent.
   * @param[in] agent   A pointer to the agent for which agent neighbors are to
   *                    be computed.
   * @param[in] rangeSq The squared range around the agent.
   */
  void computeAgentNeighbors(Agent3D *agent, float rangeSq) const;

  /**
   * @brief         Recursive function to compute the neighbors of the specified
   *                agent.
   * @param[in]     agent   A pointer to the agent for which neighbors are to be
   *                        computed.
   * @param[in,out] rangeSq The squared range around the agent.
   * @param[in]     node    The current k-D tree node.
   */

  void queryAgentTreeRecursive(Agent3D *agent,
                               float &rangeSq, /* NOLINT(runtime/references) */
                               std::size_t node) const;

  /* Not implemented. */
  KdTree3D(const KdTree3D &other);

  /* Not implemented. */
  KdTree3D &operator=(const KdTree3D &other);

  std::vector<Agent3D *> agents_;
  std::vector<AgentTreeNode> agentTree_;
  RVOSimulator3D *sim_;

  friend class Agent3D;
  friend class RVOSimulator3D;
};
} /* namespace RVO3D */

#endif /* RVO3D_KD_TREE_H_ */