Box.h
Go to the documentation of this file.
1 //Copyright (c) 2013-2023, The MercuryDPM Developers Team. All rights reserved.
2 //For the list of developers, see <http://www.MercuryDPM.org/Team>.
3 //
4 //Redistribution and use in source and binary forms, with or without
5 //modification, are permitted provided that the following conditions are met:
6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above copyright
9 // notice, this list of conditions and the following disclaimer in the
10 // documentation and/or other materials provided with the distribution.
11 // * Neither the name MercuryDPM nor the
12 // names of its contributors may be used to endorse or promote products
13 // derived from this software without specific prior written permission.
14 //
15 //THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16 //ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17 //WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18 //DISCLAIMED. IN NO EVENT SHALL THE MERCURYDPM DEVELOPERS TEAM BE LIABLE FOR ANY
19 //DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20 //(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21 //LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22 //ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23 //(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24 //SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 #ifndef BOX_H_
26 #define BOX_H_
27 
28 #include <vector>
29 #include "Panel.h"
30 
31 class Box
32 {
33 public:
34  Box(int maxLevel, int nTerms);
35 
36  void addPanel(int level, Panel* panel);
37 
38  void upwardPass();
39 
40  void downwardPass();
41 
42  void computeFlow(int k);
43 
45  {
46  return maxLevel_;
47  }
48 
50  int getNrPanelsOnLevel(int level)
51  {
52  return levels_[level].size();
53  }
54 
56  {
57  return p_;
58  }
59 
60 private:
61  int maxLevel_;
62  int p_; //The number of terms
63  std::vector<std::vector<Panel*>> levels_; // This is a vector containing the panels at level L
64  std::vector<Sphere*> spheres_; // This is a vector that contains all the spheres in the domain
65 };
66 
67 #endif /* BOX_H_ */
Definition: Box.h:32
int maxLevel_
Definition: Box.h:61
void downwardPass()
Definition: Box.cc:68
int getMaxLevel()
Definition: Box.h:44
Box(int maxLevel, int nTerms)
Definition: Box.cc:30
void computeFlow(int k)
Definition: Box.cc:108
int getNrPanelsOnLevel(int level)
Definition: Box.h:50
int p_
Definition: Box.h:62
void addPanel(int level, Panel *panel)
Definition: Box.cc:39
std::vector< std::vector< Panel * > > levels_
Definition: Box.h:63
void upwardPass()
Definition: Box.cc:44
int getNumberOfTerms()
Definition: Box.h:55
std::vector< Sphere * > spheres_
Definition: Box.h:64
Definition: Panel.h:43