41 |
|
|
42 |
|
#ifndef APPLICATION_HYDRODYNAMICS_COMPOSITESHAPE_HPP |
43 |
|
#define APPLICATION_HYDRODYNAMICS_COMPOSITESHAPE_HPP |
44 |
< |
#include "applications/hydrodynamics/Shape.hpp" |
44 |
> |
#include "hydrodynamics/Shape.hpp" |
45 |
|
#include <vector> |
46 |
|
namespace oopse { |
47 |
< |
/** |
48 |
< |
* @class CompositexShape |
49 |
< |
* Combine composite pattern and visitor pattern |
50 |
< |
*/ |
51 |
< |
class CompositeShape : public Shape { |
52 |
< |
|
53 |
< |
public: |
54 |
< |
CompositeShape() {} |
55 |
< |
virtual ~CompositeShape(); |
56 |
< |
virtual bool isInterior(Vector3d pos); |
57 |
< |
virtual std::pair<Vector3d, Vector3d> getBox(); |
58 |
< |
virtual bool hasAnalyticalSolution() { return false;} |
59 |
< |
virtual bool calcHydroProps(HydrodynamicsModel* model, double viscosity, double temperature); |
60 |
< |
void addShape(Shape* s) {shapes_.push_back(s);} |
61 |
< |
|
62 |
< |
private: |
63 |
< |
|
64 |
< |
std::vector<Shape*> shapes_; |
65 |
< |
|
47 |
> |
/** |
48 |
> |
* @class CompositeShape |
49 |
> |
* Combine composite pattern and visitor pattern |
50 |
> |
*/ |
51 |
> |
class CompositeShape : public Shape { |
52 |
> |
|
53 |
> |
public: |
54 |
> |
CompositeShape() {} |
55 |
> |
virtual ~CompositeShape(); |
56 |
> |
virtual bool isInterior(Vector3d pos); |
57 |
> |
virtual std::pair<Vector3d, Vector3d> getBoundingBox(); |
58 |
> |
virtual bool hasAnalyticalSolution() { return false;} |
59 |
> |
virtual HydroProp* getHydroProp(RealType viscosity, RealType temperature); |
60 |
> |
void addShape(Shape* s) {shapes_.push_back(s);} |
61 |
> |
|
62 |
> |
private: |
63 |
> |
|
64 |
> |
std::vector<Shape*> shapes_; |
65 |
|
}; |
66 |
|
|
67 |
|
} |