diff --git a/MathLib/InterpolationAlgorithms/PiecewiseLinearInterpolation.cpp b/MathLib/InterpolationAlgorithms/PiecewiseLinearInterpolation.cpp index 74c8b5ac8bdde408a0eb518c1c84311c4afb21c6..c8b4084ffba02e9144f6c1891eb83e6cb81a4d85 100644 --- a/MathLib/InterpolationAlgorithms/PiecewiseLinearInterpolation.cpp +++ b/MathLib/InterpolationAlgorithms/PiecewiseLinearInterpolation.cpp @@ -13,6 +13,7 @@ */ #include <cmath> #include <limits> +#include <utility> #include "PiecewiseLinearInterpolation.h" @@ -20,10 +21,12 @@ namespace MathLib { -PiecewiseLinearInterpolation::PiecewiseLinearInterpolation(const std::vector<double>& supporting_points, - const std::vector<double>& values_at_supp_pnts, - bool supp_pnts_sorted) : - _supp_pnts(supporting_points), _values_at_supp_pnts(values_at_supp_pnts) +PiecewiseLinearInterpolation::PiecewiseLinearInterpolation( + std::vector<double> supporting_points, + std::vector<double> values_at_supp_pnts, + bool supp_pnts_sorted) + : _supp_pnts(std::move(supporting_points)), + _values_at_supp_pnts(std::move(values_at_supp_pnts)) { if (!supp_pnts_sorted) { BaseLib::quicksort<double, double>(_supp_pnts, static_cast<std::size_t> (0), @@ -31,12 +34,14 @@ PiecewiseLinearInterpolation::PiecewiseLinearInterpolation(const std::vector<dou } } -PiecewiseLinearInterpolation::PiecewiseLinearInterpolation(const std::vector<double>& supporting_points, - const std::vector<double>& values_at_supp_pnts, - const std::vector<double>& points_to_interpolate, - std::vector<double>& values_at_interpol_pnts, - bool supp_pnts_sorted) : - _supp_pnts(supporting_points), _values_at_supp_pnts(values_at_supp_pnts) +PiecewiseLinearInterpolation::PiecewiseLinearInterpolation( + std::vector<double> supporting_points, + std::vector<double> values_at_supp_pnts, + const std::vector<double>& points_to_interpolate, + std::vector<double>& values_at_interpol_pnts, + bool supp_pnts_sorted) + : _supp_pnts(std::move(supporting_points)), + _values_at_supp_pnts(std::move(values_at_supp_pnts)) { if (!supp_pnts_sorted) { BaseLib::quicksort<double, double>(_supp_pnts, static_cast<std::size_t> (0), diff --git a/MathLib/InterpolationAlgorithms/PiecewiseLinearInterpolation.h b/MathLib/InterpolationAlgorithms/PiecewiseLinearInterpolation.h index 6941d54460b4aa8bbdec4789ad856fbbddb99bb0..b3c160013035a6e14025e7d636af843f755c5d12 100644 --- a/MathLib/InterpolationAlgorithms/PiecewiseLinearInterpolation.h +++ b/MathLib/InterpolationAlgorithms/PiecewiseLinearInterpolation.h @@ -44,8 +44,8 @@ public: * @param supp_pnts_sorted false (default), if it is sure the supporting points are sorted * one can set the switch to true */ - PiecewiseLinearInterpolation(const std::vector<double>& supporting_points, - const std::vector<double>& values_at_supp_pnts, + PiecewiseLinearInterpolation(std::vector<double> supporting_points, + std::vector<double> values_at_supp_pnts, bool supp_pnts_sorted = false); /** * The same requirements on the input vectors supporting_points and values_at_supp_pnts @@ -60,8 +60,8 @@ public: * @param supp_pnts_sorted Is set to false per default. If it is sure that the supporting * points are sorted one can set the switch to true. */ - PiecewiseLinearInterpolation(const std::vector<double>& supporting_points, - const std::vector<double>& values_at_supp_pnts, + PiecewiseLinearInterpolation(std::vector<double> supporting_points, + std::vector<double> values_at_supp_pnts, const std::vector<double>& points_to_interpolate, std::vector<double>& values_at_interpol_pnts, bool supp_pnts_sorted = false);