eDSP  0.0.1
A cross-platform DSP library written in C++.
norm.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 * Filename: norm.hpp
19 * Author: Mohammed Boujemaoui
20 * Date: 12/10/18
21 */
22 
23 #ifndef EDSP_NORM_HPP
24 #define EDSP_NORM_HPP
25 
26 #include <edsp/meta/iterator.hpp>
27 #include <edsp/math/numeric.hpp>
28 #include <functional>
29 
30 namespace edsp { namespace statistics {
31 
47  template <typename InputIt>
48  constexpr meta::value_type_t<InputIt> norm(InputIt first, InputIt last) {
49  using value_type = meta::value_type_t<InputIt>;
50  const auto predicate = [](const value_type accumulated, const value_type comming) {
51  return accumulated + math::square(std::abs(comming));
52  };
53  const auto accumulated = std::accumulate(first, last, static_cast<value_type>(0), std::cref(predicate));
54  return std::sqrt(accumulated);
55  }
56 
57 }} // namespace edsp::statistics
58 
59 #endif //EDSP_NORM_HPP
constexpr meta::value_type_t< InputIt > norm(InputIt first, InputIt last)
Compute the L2-norm of the signals in the range [first1, last1).
Definition: norm.hpp:48
constexpr T square(T x)
Computes the square value of the input number.
Definition: numeric.hpp:188
Definition: amplifier.hpp:29