https://gitlab.opengeosys.org/ogs/ogs.git
Tip revision: f75a2268c1436e98efe6502b38e5cfc390ddd806 authored by Dmitry Yu. Naumov on 09 March 2021, 19:59:20 UTC
Merge branch 'ReaddCleanCoverageTarget' into 'master'
Merge branch 'ReaddCleanCoverageTarget' into 'master'
Tip revision: f75a226
Subdivision.h
/**
* \file
* \copyright
* Copyright (c) 2012-2021, OpenGeoSys Community (http://www.opengeosys.org)
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*
*/
#pragma once
#include <vector>
namespace BaseLib
{
/**
* Interface class for subdivision operators
*/
class ISubdivision
{
public:
/// Returns a vector of subdivided points
virtual std::vector<double> operator()() const = 0;
virtual ~ISubdivision() = default;
};
/**
* Uniform subdivision operator
*/
class UniformSubdivision : public ISubdivision
{
public:
/**
* Configuration
* @param length total length to be subdivided
* @param n_subdivision the number of subdivision
*/
UniformSubdivision(double length, std::size_t n_subdivision)
: _length(length), _n_subdivision(n_subdivision) {}
/// Returns a vector of subdivided points
std::vector<double> operator()() const override
{
std::vector<double> x;
x.reserve(_n_subdivision+1);
const double dL = _length/static_cast<double>(_n_subdivision);
for (std::size_t i = 0; i < _n_subdivision + 1; i++)
{
x.push_back(i * dL);
}
return x;
}
private:
const double _length;
const std::size_t _n_subdivision;
};
/**
* Gradual subdivision operator with a constant _multiplier
*/
class GradualSubdivision : public ISubdivision
{
public:
/**
* Constructor
* @param L total length to be subdivided
* @param dL0 initial cell length
* @param max_dL maximum cell length
* @param multiplier multiplier to cell length
*/
GradualSubdivision(
const double L,
const double dL0,
const double max_dL,
const double multiplier);
/// Returns a vector of subdivided points
std::vector<double> operator()() const override;
private:
const double _length;
const double _dL0;
const double _max_dL;
const double _multiplier;
};
/**
* Gradual subdivision operator with a constant _multiplier.
*
* In this class the number of subdivisions is known a priori.
*/
class GradualSubdivisionFixedNum : public ISubdivision
{
public:
/**
* Constructor
* @param L total length to be subdivided
* @param num_subdivisions number of subdivisions to generate
* @param multiplier multiplier to cell length
*/
GradualSubdivisionFixedNum(const double L,
const std::size_t num_subdivisions,
const double multiplier);
/// Returns a vector of subdivided points
std::vector<double> operator()() const override;
private:
const double _length;
const std::size_t _num_subdivisions;
const double _multiplier;
};
} // namespace BaseLib