Skip to content
Snippets Groups Projects
TemplateWeightedPoint.h 981 B
Newer Older
  • Learn to ignore specific revisions
  •  * \file
     * \date Sep 3, 2013
     * \brief Weighted point class.
    
     * 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
    
    
    #include "TemplatePoint.h"
    
    namespace MathLib
    {
    
    template <typename FP_T, typename W_T, std::size_t DIM>
    class TemplateWeightedPoint : public TemplatePoint<FP_T, DIM>
    {
    public:
    
        TemplateWeightedPoint(std::array<FP_T, DIM> const& x, W_T weight) :
            TemplatePoint<FP_T, DIM>(x), _weight(weight)
        {}
    
        W_T getWeight() const
        {
            return _weight;
        }
    
        W_T const _weight;
    
    using WeightedPoint1D = TemplateWeightedPoint<double, double, 1>;
    using WeightedPoint2D = TemplateWeightedPoint<double, double, 2>;
    using WeightedPoint3D = TemplateWeightedPoint<double, double, 3>;
    
    
    } // end namespace MathLib