eDSP  0.0.1
A cross-platform DSP library written in C++.
peak.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: peak.hpp
19  * Author: Mohammed Boujemaoui
20  * Date: 2018-10-01
21  */
22 #ifndef EDSP_STATISTICAL_PEAK_HPP
23 #define EDSP_STATISTICAL_PEAK_HPP
24 
25 #include <edsp/meta/iterator.hpp>
26 #include <algorithm>
27 
28 namespace edsp { namespace statistics {
29 
37  template <typename ForwardIt>
38  constexpr auto peak(ForwardIt first, ForwardIt last)
39  -> std::pair<typename meta::diff_type_t<ForwardIt>, typename meta::value_type_t<ForwardIt>> {
40  const auto iter = std::max_element(first, last);
41  return {std::distance(first, iter), *iter};
42  }
43 
51  template <typename ForwardIt>
52  constexpr auto peakabs(ForwardIt first, ForwardIt last)
53  -> std::pair<typename meta::diff_type_t<ForwardIt>, typename meta::value_type_t<ForwardIt>> {
54  using input_t = meta::value_type_t<ForwardIt>;
55  const auto comp = [](const input_t left, const input_t right) { return std::abs(left) < std::abs(right); };
56  const auto iter = std::max_element(first, last, comp);
57  return {std::distance(first, iter), *iter};
58  }
59 
60 }} // namespace edsp::statistics
61 
62 #endif // EDSP_STATISTICAL_PEAK_HPP
constexpr auto peak(ForwardIt first, ForwardIt last) -> std::pair< typename meta::diff_type_t< ForwardIt >, typename meta::value_type_t< ForwardIt >>
Computes the peak value of the range [first, last)
Definition: peak.hpp:38
constexpr T distance(T x, T y) noexcept
Computes the distance between x and y.
Definition: numeric.hpp:328
constexpr auto peakabs(ForwardIt first, ForwardIt last) -> std::pair< typename meta::diff_type_t< ForwardIt >, typename meta::value_type_t< ForwardIt >>
Computes the absolute peak value of the range [first, last)
Definition: peak.hpp:52
Definition: amplifier.hpp:29