ASPECT
include
aspect
particle
interpolator
bilinear_least_squares.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2017 - 2022 by the authors of the ASPECT code.
3
4
This file is part of ASPECT.
5
6
ASPECT is free software; you can redistribute it and/or modify
7
it under the terms of the GNU General Public License as published by
8
the Free Software Foundation; either version 2, or (at your option)
9
any later version.
10
11
ASPECT is distributed in the hope that it will be useful,
12
but WITHOUT ANY WARRANTY; without even the implied warranty of
13
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
GNU General Public License for more details.
15
16
You should have received a copy of the GNU General Public License
17
along with ASPECT; see the file LICENSE. If not see
18
<http://www.gnu.org/licenses/>.
19
*/
20
21
#ifndef _aspect_particle_interpolator_bilinear_least_squares_h
22
#define _aspect_particle_interpolator_bilinear_least_squares_h
23
24
#include <
aspect/particle/interpolator/interface.h
>
25
#include <
aspect/simulator_access.h
>
26
27
#include <
aspect/particle/interpolator/cell_average.h
>
28
29
namespace
aspect
30
{
31
namespace
Particle
32
{
33
namespace
Interpolator
34
{
35
namespace
internal
36
{
37
bool
string_to_bool
(
const
std::string &s);
38
}
39
47
template
<
int
dim>
48
class
BilinearLeastSquares
:
public
Interface
<dim>,
public
aspect::SimulatorAccess
<dim>
49
{
50
public
:
54
std::vector<std::vector<double>>
55
properties_at_points(
const
ParticleHandler<dim> &particle_handler,
56
const
std::vector<Point<dim>> &positions,
57
const
ComponentMask &selected_properties,
58
const
typename
parallel::distributed::Triangulation<dim>::active_cell_iterator &cell)
const override
;
59
60
// avoid -Woverloaded-virtual:
61
using
Interface<dim>::properties_at_points
;
62
66
static
67
void
68
declare_parameters
(ParameterHandler &prm);
69
73
void
74
parse_parameters (ParameterHandler &prm)
override
;
75
76
private
:
85
ComponentMask
use_linear_least_squares_limiter
;
86
96
ComponentMask
use_boundary_extrapolation
;
97
102
Interpolator::CellAverage<dim>
fallback_interpolator
;
103
};
104
}
105
}
106
}
107
108
#endif
aspect::Particle::Interpolator::internal::string_to_bool
bool string_to_bool(const std::string &s)
cell_average.h
aspect::Particle::Interpolator::Interface
Definition:
interface.h:50
aspect::Particle::Interpolator::BilinearLeastSquares::fallback_interpolator
Interpolator::CellAverage< dim > fallback_interpolator
Definition:
bilinear_least_squares.h:102
aspect::Particle::Interpolator::BilinearLeastSquares::use_linear_least_squares_limiter
ComponentMask use_linear_least_squares_limiter
Definition:
bilinear_least_squares.h:85
aspect::Particle::Interpolator::CellAverage
Definition:
cell_average.h:39
aspect::Particle::Interpolator::BilinearLeastSquares
Definition:
bilinear_least_squares.h:48
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:45
aspect
Definition:
compat.h:1094
aspect::Particle::Interpolator::declare_parameters
void declare_parameters(ParameterHandler &prm)
aspect::Particle::Interpolator::BilinearLeastSquares::use_boundary_extrapolation
ComponentMask use_boundary_extrapolation
Definition:
bilinear_least_squares.h:96
interface.h