https://gitlab.opengeosys.org/ogs/ogs.git
Raw File
Tip revision: ecc1d0561b0d9a8005011b2e64e9f53b43862c74 authored by Christoph Lehmann on 23 September 2021, 12:54:49 UTC
link to gmock
Tip revision: ecc1d05
TemplateWeightedPoint.h
/**
 * \file
 * \date Sep 3, 2013
 * \brief Weighted point class.
 *
 * \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 "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_; }

private:
    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
back to top