OpenLB 1.7
Loading...
Searching...
No Matches
latticePhysPoreSizeDistribution3D.h
Go to the documentation of this file.
1/* This file is part of the OpenLB library
2 *
3 * Copyright (C) 2012 Lukas Baron, Tim Dornieden, Mathias J. Krause,
4 * Albert Mink
5 * E-mail contact: info@openlb.net
6 * The most recent release of OpenLB can be downloaded at
7 * <http://www.openlb.net/>
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public
20 * License along with this program; if not, write to the Free
21 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
22 * Boston, MA 02110-1301, USA.
23*/
24
25#ifndef LATTICE_PHYS_PORE_SIZE_DISTRIBUTION_3D_H
26#define LATTICE_PHYS_PORE_SIZE_DISTRIBUTION_3D_H
27
28#include<vector>
29
30#include "superBaseF3D.h"
31#include "superCalcF3D.h"
33
34#include "blockBaseF3D.h"
41
42
43/* Note: Throughout the whole source code directory genericFunctions, the
44 * template parameters for i/o dimensions are:
45 * F: S^m -> T^n (S=source, T=target)
46 */
47
48namespace olb {
49
52template <typename T, typename DESCRIPTOR>
53class SuperLatticePhysPoreSizeDistribution3D final : public SuperLatticeF3D<T,DESCRIPTOR> {
54private:
55 SuperGeometry<T,3>& _superGeometry;
56public:
58 SuperGeometry<T,3>& superGeometry,
59 int material,
60 XMLreader const& xmlReader);
61};
62
65template <typename T, typename DESCRIPTOR>
66class BlockLatticePhysPoreSizeDistribution3D final : public BlockLatticeF3D<T,DESCRIPTOR> {
67private:
68 BlockGeometry<T,3>& _blockGeometry;
69 int _material;
70 std::shared_ptr<IndicatorF3D<T>> _tmpIndicator = nullptr;
71 std::vector<std::shared_ptr<IndicatorF3D<T>>> _indicatorList;
73 BlockData<3,T,T> _distanceCache;
74public:
76 BlockGeometry<T,3>& blockGeometry, int material,
77 XMLreader const& xmlReader);
78 bool operator() (T output[], const int input[]) override;
79};
80
81}
82#endif
Representation of the 2D block geometry view – header file.
Representation of a block geometry.
represents all functors that operate on a DESCRIPTOR in general, e.g. getVelocity(),...
functor returns pointwise minimum distance to boundary given by indicators
functor returns pointwise pore radius for packings of spheres given by indicators returns NAN for non...
bool operator()(T output[], const int input[]) override
has to be implemented for 'every' derived class
BlockLatticePhysPoreSizeDistribution3D(BlockLattice< T, DESCRIPTOR > &blockLattice, BlockGeometry< T, 3 > &blockGeometry, int material, XMLreader const &xmlReader)
Platform-abstracted block lattice for external access and inter-block interaction.
Representation of a statistic for a parallel 2D geometry.
represents all functors that operate on a SuperLattice in general, e.g. getVelocity(),...
functor returns pointwise pore radius (in m) for packings of spheres given by an xmlReader returns NA...
SuperLatticePhysPoreSizeDistribution3D(SuperLattice< T, DESCRIPTOR > &sLattice, SuperGeometry< T, 3 > &superGeometry, int material, XMLreader const &xmlReader)
Super class maintaining block lattices for a cuboid decomposition.
Top level namespace for all of OpenLB.
BGK Dynamics with adjusted omega – header file.