www.cemf.ir
PeakableRegion.hpp
Go to the documentation of this file.
1 /*------------------------------- phasicFlow ---------------------------------
2  O C enter of
3  O O E ngineering and
4  O O M ultiscale modeling of
5  OOOOOOO F luid flow
6 ------------------------------------------------------------------------------
7  Copyright (C): www.cemf.ir
8  email: hamid.r.norouzi AT gmail.com
9 ------------------------------------------------------------------------------
10 Licence:
11  This file is part of phasicFlow code. It is a free software for simulating
12  granular and multiphase flows. You can redistribute it and/or modify it under
13  the terms of GNU General Public License v3 or any other later versions.
14 
15  phasicFlow is distributed to help others in their research in the field of
16  granular and multiphase flows, but WITHOUT ANY WARRANTY; without even the
17  implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
18 
19 -----------------------------------------------------------------------------*/
20 
21 #ifndef __PeakableRegion_hpp__
22 #define __PeakableRegion_hpp__
23 
24 #include "dictionary.hpp"
25 #include "geometricRegion.hpp"
26 #include "peakableRegion.hpp"
27 
28 namespace pFlow
29 {
30 
31 template<typename GeomType>
33 {
34 public:
35 
37 
39 
40 private:
41 
43 
44 public:
45 
46  // type info
47  TypeInfoTemplate11("peakable", GeometryType);
48 
50  PeakableRegion(const word& type, const dictionary& dict);
51 
53 
54  virtual uniquePtr<peakableRegion> clone() const override
55  {
56  return makeUnique<PeakableRegion<GeomType>>(*this);
57  }
58 
59  virtual peakableRegion* clonePtr() const override
60  {
61  return new PeakableRegion<GeomType>(*this);
62  }
63 
64  virtual ~PeakableRegion() = default;
65 
67 
68  bool isInside(const realx3& point) const override;
69 
70  realx3 peek() const override;
71 
72  const realx3& minPoint()const override
73  {
74  return region_.minPoint();
75  }
76 
77  const realx3& maxPoint()const override
78  {
79  return region_.maxPoint();
80  }
81 
83 
84  virtual bool read(const dictionary& dict) override;
85 
86  virtual bool write(dictionary& dict) const override;
87 };
88 
89 } // pFlow
90 
91 #include "PeakableRegion.cpp"
92 
93 #endif
pFlow::PeakableRegion::~PeakableRegion
virtual ~PeakableRegion()=default
pFlow::PeakableRegion::read
virtual bool read(const dictionary &dict) override
Definition: PeakableRegion.cpp:52
pFlow::word
std::string word
Definition: builtinTypes.hpp:64
pFlow::geometricRegion::maxPoint
const auto & maxPoint() const
Definition: geometricRegion.hpp:70
pFlow::PeakableRegion::PeakableRegion
PeakableRegion(const word &type, const dictionary &dict)
Definition: PeakableRegion.cpp:24
pFlow::PeakableRegion::add_vCtor
add_vCtor(peakableRegion, PeakableRegion, word)
pFlow::PeakableRegion::minPoint
const realx3 & minPoint() const override
Definition: PeakableRegion.hpp:72
pFlow::geometricRegion::minPoint
const auto & minPoint() const
Definition: geometricRegion.hpp:65
pFlow
Definition: demGeometry.hpp:27
pFlow::geometricRegion::GeometryType
GeomType GeometryType
Definition: geometricRegion.hpp:37
pFlow::PeakableRegion::maxPoint
const realx3 & maxPoint() const override
Definition: PeakableRegion.hpp:77
pFlow::PeakableRegion::TypeInfoTemplate11
TypeInfoTemplate11("peakable", GeometryType)
pFlow::PeakableRegion::region_
RegionType region_
Definition: PeakableRegion.hpp:42
pFlow::PeakableRegion::GeometryType
typename RegionType::GeometryType GeometryType
Definition: PeakableRegion.hpp:38
dictionary.hpp
PeakableRegion.cpp
pFlow::PeakableRegion::clone
virtual uniquePtr< peakableRegion > clone() const override
Definition: PeakableRegion.hpp:54
geometricRegion.hpp
pFlow::PeakableRegion::clonePtr
virtual peakableRegion * clonePtr() const override
Definition: PeakableRegion.hpp:59
peakableRegion.hpp
pFlow::geometricRegion
Definition: geometricRegion.hpp:33
pFlow::PeakableRegion::isInside
bool isInside(const realx3 &point) const override
Definition: PeakableRegion.cpp:37
pFlow::uniquePtr
Definition: uniquePtr.hpp:42
pFlow::triple< real >
pFlow::PeakableRegion::write
virtual bool write(dictionary &dict) const override
Definition: PeakableRegion.cpp:58
pFlow::PeakableRegion::peek
realx3 peek() const override
Definition: PeakableRegion.cpp:46
pFlow::PeakableRegion
Definition: PeakableRegion.hpp:32
pFlow::peakableRegion
Definition: peakableRegion.hpp:32
pFlow::dictionary
Dictionary holds a set of data entries or sub-dictionaries that are enclosed in a curely braces or ar...
Definition: dictionary.hpp:67