10 #ifndef EIGEN_BVALGORITHMS_H
11 #define EIGEN_BVALGORITHMS_H
20 #ifndef EIGEN_PARSED_BY_DOXYGEN
21 template <
typename BVH,
typename Intersector>
24 typedef typename BVH::VolumeIterator VolIter;
25 typedef typename BVH::ObjectIterator ObjIter;
27 VolIter vBegin = VolIter(), vEnd = VolIter();
28 ObjIter oBegin = ObjIter(), oEnd = ObjIter();
30 std::vector<Index> todo(1, root);
32 while (!todo.empty()) {
33 tree.getChildren(todo.back(), vBegin, vEnd, oBegin, oEnd);
36 for (; vBegin != vEnd; ++vBegin)
37 if (intersector.intersectVolume(tree.getVolume(*vBegin))) todo.push_back(*vBegin);
39 for (; oBegin != oEnd; ++oBegin)
40 if (intersector.intersectObject(*oBegin))
return true;
46 template <
typename Volume1,
typename Object1,
typename Object2,
typename Intersector>
58 template <
typename Volume2,
typename Object2,
typename Object1,
typename Intersector>
78 template <
typename BVH,
typename Intersector>
91 template <
typename BVH1,
typename BVH2,
typename Intersector>
93 Intersector &intersector)
103 typedef typename BVH1::VolumeIterator VolIter1;
104 typedef typename BVH1::ObjectIterator ObjIter1;
105 typedef typename BVH2::VolumeIterator VolIter2;
106 typedef typename BVH2::ObjectIterator ObjIter2;
108 VolIter1 vBegin1 = VolIter1(), vEnd1 = VolIter1();
109 ObjIter1 oBegin1 = ObjIter1(), oEnd1 = ObjIter1();
110 VolIter2 vBegin2 = VolIter2(), vEnd2 = VolIter2(), vCur2 = VolIter2();
111 ObjIter2 oBegin2 = ObjIter2(), oEnd2 = ObjIter2(), oCur2 = ObjIter2();
113 std::vector<std::pair<Index1, Index2> > todo(1, std::make_pair(tree1.getRootIndex(), tree2.getRootIndex()));
115 while (!todo.empty()) {
116 tree1.getChildren(todo.back().first, vBegin1, vEnd1, oBegin1, oEnd1);
117 tree2.getChildren(todo.back().second, vBegin2, vEnd2, oBegin2, oEnd2);
120 for (; vBegin1 != vEnd1; ++vBegin1) {
121 const typename BVH1::Volume &vol1 = tree1.getVolume(*vBegin1);
122 for (vCur2 = vBegin2; vCur2 != vEnd2; ++vCur2) {
123 if (intersector.intersectVolumeVolume(vol1, tree2.getVolume(*vCur2)))
124 todo.push_back(std::make_pair(*vBegin1, *vCur2));
127 for (oCur2 = oBegin2; oCur2 != oEnd2; ++oCur2) {
128 Helper1 helper(*oCur2, intersector);
133 for (; oBegin1 != oEnd1; ++oBegin1) {
134 for (vCur2 = vBegin2; vCur2 != vEnd2; ++vCur2) {
135 Helper2 helper(*oBegin1, intersector);
139 for (oCur2 = oBegin2; oCur2 != oEnd2; ++oCur2) {
140 if (intersector.intersectObjectObject(*oBegin1, *oCur2))
return;
148 #ifndef EIGEN_PARSED_BY_DOXYGEN
149 template <
typename BVH,
typename Minimizer>
154 typedef std::pair<Scalar, Index> QueueElement;
155 typedef typename BVH::VolumeIterator VolIter;
156 typedef typename BVH::ObjectIterator ObjIter;
158 VolIter vBegin = VolIter(), vEnd = VolIter();
159 ObjIter oBegin = ObjIter(), oEnd = ObjIter();
160 std::priority_queue<QueueElement, std::vector<QueueElement>, std::greater<QueueElement> >
163 todo.push(std::make_pair(
Scalar(), root));
165 while (!todo.empty()) {
166 tree.getChildren(todo.top().second, vBegin, vEnd, oBegin, oEnd);
169 for (; oBegin != oEnd; ++oBegin)
170 minimum = (
std::min)(minimum, minimizer.minimumOnObject(*oBegin));
172 for (; vBegin != vEnd; ++vBegin) {
173 Scalar val = minimizer.minimumOnVolume(tree.getVolume(*vBegin));
174 if (
val < minimum) todo.push(std::make_pair(
val, *vBegin));
182 template <
typename Volume1,
typename Object1,
typename Object2,
typename Minimizer>
195 template <
typename Volume2,
typename Object2,
typename Object1,
typename Minimizer>
216 template <
typename BVH,
typename Minimizer>
231 template <
typename BVH1,
typename BVH2,
typename Minimizer>
240 typedef std::pair<Scalar, std::pair<Index1, Index2> > QueueElement;
241 typedef typename BVH1::VolumeIterator VolIter1;
242 typedef typename BVH1::ObjectIterator ObjIter1;
243 typedef typename BVH2::VolumeIterator VolIter2;
244 typedef typename BVH2::ObjectIterator ObjIter2;
246 VolIter1 vBegin1 = VolIter1(), vEnd1 = VolIter1();
247 ObjIter1 oBegin1 = ObjIter1(), oEnd1 = ObjIter1();
248 VolIter2 vBegin2 = VolIter2(), vEnd2 = VolIter2(), vCur2 = VolIter2();
249 ObjIter2 oBegin2 = ObjIter2(), oEnd2 = ObjIter2(), oCur2 = ObjIter2();
250 std::priority_queue<QueueElement, std::vector<QueueElement>, std::greater<QueueElement> >
254 todo.push(std::make_pair(
Scalar(), std::make_pair(tree1.getRootIndex(), tree2.getRootIndex())));
256 while (!todo.empty()) {
257 tree1.getChildren(todo.top().second.first, vBegin1, vEnd1, oBegin1, oEnd1);
258 tree2.getChildren(todo.top().second.second, vBegin2, vEnd2, oBegin2, oEnd2);
261 for (; oBegin1 != oEnd1; ++oBegin1) {
262 for (oCur2 = oBegin2; oCur2 != oEnd2; ++oCur2) {
263 minimum = (
std::min)(minimum, minimizer.minimumOnObjectObject(*oBegin1, *oCur2));
266 for (vCur2 = vBegin2; vCur2 != vEnd2; ++vCur2) {
267 Helper2 helper(*oBegin1, minimizer);
272 for (; vBegin1 != vEnd1; ++vBegin1) {
273 const typename BVH1::Volume &vol1 = tree1.getVolume(*vBegin1);
275 for (oCur2 = oBegin2; oCur2 != oEnd2; ++oCur2) {
276 Helper1 helper(*oCur2, minimizer);
280 for (vCur2 = vBegin2; vCur2 != vEnd2; ++vCur2) {
281 Scalar val = minimizer.minimumOnVolumeVolume(vol1, tree2.getVolume(*vCur2));
282 if (
val < minimum) todo.push(std::make_pair(
val, std::make_pair(*vBegin1, *vCur2)));
SCALAR Scalar
Definition: bench_gemm.cpp:45
#define min(a, b)
Definition: datatypes.h:22
#define max(a, b)
Definition: datatypes.h:23
int * m
Definition: level2_cplx_impl.h:294
Minimizer::Scalar minimize_helper(const BVH &tree, Minimizer &minimizer, typename BVH::Index root, typename Minimizer::Scalar minimum)
Definition: BVAlgorithms.h:150
bool intersect_helper(const BVH &tree, Intersector &intersector, typename BVH::Index root)
Definition: BVAlgorithms.h:22
Namespace containing all symbols from the Eigen library.
Definition: bench_norm.cpp:70
void BVIntersect(const BVH &tree, Intersector &intersector)
Definition: BVAlgorithms.h:79
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:83
Minimizer::Scalar BVMinimize(const BVH &tree, Minimizer &minimizer)
Definition: BVAlgorithms.h:217
double Volume
The volume of the domain.
Definition: marangoni_convection_box.cc:561
val
Definition: calibrate.py:119
Definition: Eigen_Colamd.h:49
Definition: BVAlgorithms.h:47
bool intersectObject(const Object1 &obj)
Definition: BVAlgorithms.h:50
Intersector & intersector
Definition: BVAlgorithms.h:52
bool intersectVolume(const Volume1 &vol)
Definition: BVAlgorithms.h:49
intersector_helper1(const Object2 &inStored, Intersector &in)
Definition: BVAlgorithms.h:48
Object2 stored
Definition: BVAlgorithms.h:51
intersector_helper1 & operator=(const intersector_helper1 &)
Definition: BVAlgorithms.h:59
intersector_helper2(const Object1 &inStored, Intersector &in)
Definition: BVAlgorithms.h:60
Object1 stored
Definition: BVAlgorithms.h:63
bool intersectObject(const Object2 &obj)
Definition: BVAlgorithms.h:62
intersector_helper2 & operator=(const intersector_helper2 &)
Intersector & intersector
Definition: BVAlgorithms.h:64
bool intersectVolume(const Volume2 &vol)
Definition: BVAlgorithms.h:61
Definition: BVAlgorithms.h:183
minimizer_helper1 & operator=(const minimizer_helper1 &)
Minimizer::Scalar Scalar
Definition: BVAlgorithms.h:184
Scalar minimumOnObject(const Object1 &obj)
Definition: BVAlgorithms.h:187
minimizer_helper1(const Object2 &inStored, Minimizer &m)
Definition: BVAlgorithms.h:185
Minimizer & minimizer
Definition: BVAlgorithms.h:189
Scalar minimumOnVolume(const Volume1 &vol)
Definition: BVAlgorithms.h:186
Object2 stored
Definition: BVAlgorithms.h:188
Definition: BVAlgorithms.h:196
Scalar minimumOnObject(const Object2 &obj)
Definition: BVAlgorithms.h:200
Object1 stored
Definition: BVAlgorithms.h:201
minimizer_helper2 & operator=(const minimizer_helper2 &)
Minimizer::Scalar Scalar
Definition: BVAlgorithms.h:197
minimizer_helper2(const Object1 &inStored, Minimizer &m)
Definition: BVAlgorithms.h:198
Scalar minimumOnVolume(const Volume2 &vol)
Definition: BVAlgorithms.h:199
Minimizer & minimizer
Definition: BVAlgorithms.h:202