eDSP  0.0.1
A cross-platform DSP library written in C++.
linspace.hpp
Go to the documentation of this file.
1 /*
2  * eDSP, A cross-platform Digital Signal Processing library written in modern C++.
3  * Copyright (C) 2018 Mohammed Boujemaoui Boulaghmoudi, All rights reserved.
4  *
5  * This program is free software: you can redistribute it and/or modify it
6  * under the terms of the GNU General Public License as published by the Free
7  * Software Foundation, either version 3 of the License, or (at your option)
8  * any later version.
9  *
10  * This program is distributed in the hope that it will be useful, but WITHOUT
11  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
13  * more details.
14  *
15  * You should have received a copy of the GNU General Public License along width
16  * this program. If not, see <http://www.gnu.org/licenses/>
17  *
18  * File: linspace.hpp
19  * Author: Mohammed Boujemaoui
20  * Date: 02/08/2018
21  */
22 #ifndef EDSP_ALGORITHM_LINSPACE_H
23 #define EDSP_ALGORITHM_LINSPACE_H
24 
25 #include <edsp/meta/iterator.hpp>
26 #include <edsp/meta/advance.hpp>
27 #include <numeric>
28 #include <cmath>
29 
30 namespace edsp { inline namespace algorithm {
31 
40  template <typename OutputIt, typename Numeric>
41  constexpr void linspace(OutputIt d_first, Numeric N, meta::value_type_t<OutputIt> x1,
42  meta::value_type_t<OutputIt> x2) {
43  const auto size = static_cast<meta::diff_type_t<OutputIt>>(std::trunc(N));
44  const auto increment = (x2 - x1) / static_cast<meta::value_type_t<OutputIt>>(size - 1);
45  for (auto i = 0; i < size; ++i, ++d_first) {
46  *d_first = x1;
47  x1 += increment;
48  }
49  }
50 
51 }} // namespace edsp::algorithm
52 
53 #endif // EDSP_ALGORITHM_LINSPACE_H
constexpr void linspace(OutputIt d_first, Numeric N, meta::value_type_t< OutputIt > x1, meta::value_type_t< OutputIt > x2)
Generate N linearly spaced values between the range [x1,x2] and stores the result in another range...
Definition: linspace.hpp:41
Definition: amplifier.hpp:29