/* This file is part of the OpenLB library
*
* Copyright (C) 2019 Adrian Kummerländer
* E-mail contact: info@openlb.net
* The most recent release of OpenLB can be downloaded at
*
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this program; if not, write to the Free
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef REFINEMENT_GRID_2D_H
#define REFINEMENT_GRID_2D_H
#include
#include
#include "core/unitConverter.h"
#include "core/superLattice2D.h"
#include "geometry/superGeometry2D.h"
#include "geometry/cuboidGeometry2D.h"
#include "geometry/superGeometry2D.h"
#include "communication/loadBalancer.h"
#include "functors/analytical/indicator/indicatorF2D.h"
namespace olb {
template class DESCRIPTOR> class FineCoupler2D;
template class DESCRIPTOR> class CoarseCoupler2D;
template class DESCRIPTOR>
class Grid2D {
private:
std::unique_ptr> _converter;
std::unique_ptr> _cuboids;
std::unique_ptr> _balancer;
std::unique_ptr> _geometry;
std::unique_ptr> _lattice;
std::vector>> _fineGrids;
std::vector>> _fineCouplers;
std::vector>> _coarseCouplers;
public:
static std::unique_ptr> make(IndicatorF2D& domainF, int resolution, T tau, int re);
Grid2D(IndicatorF2D& domainF, int resolution, T tau, int re);
UnitConverter& getConverter();
CuboidGeometry2D& getCuboidGeometry();
LoadBalancer& getLoadBalancer();
SuperGeometry2D& getSuperGeometry();
SuperLattice2D& getSuperLattice();
T getScalingFactor();
T getInvScalingFactor();
void collideAndStream();
FineCoupler2D& addFineCoupling(
Grid2D& fineGrid, Vector origin, Vector extend);
CoarseCoupler2D& addCoarseCoupling(
Grid2D& fineGrid, Vector origin, Vector extend);
Vector alignToGrid(Vector physR) const;
Grid2D& refine(IndicatorF2D& domainF);
Grid2D& refine(Vector origin, Vector extend);
};
}
#endif