2024-03-11 16:33:28 +01:00
|
|
|
#pragma once
|
|
|
|
#include <memory>
|
2024-03-12 11:19:52 +01:00
|
|
|
#include <vector>
|
2024-03-11 16:33:28 +01:00
|
|
|
|
2024-03-12 11:19:52 +01:00
|
|
|
#include "lasp_mathtypes.h"
|
|
|
|
#include "lasp_types.h"
|
2024-03-11 16:33:28 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \addtogroup dsp
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2024-03-12 11:19:52 +01:00
|
|
|
* @brief Apply frequency domain smoothing to a Frequency domain (single
|
|
|
|
* sided)signal power spectrum
|
2024-03-11 16:33:28 +01:00
|
|
|
*
|
2024-03-12 11:19:52 +01:00
|
|
|
* @param freq Frequency range
|
|
|
|
* @param X Signal pwr
|
|
|
|
* @param w Parameter determining the smoothing with. 1 = 1/1 octave, 3 = 1/3th
|
|
|
|
* octave and so on
|
|
|
|
* @param power_correct Apply a correction to the whole spectrum to make the
|
|
|
|
* signal power equal to the unsmoothed signal power.
|
|
|
|
* @return vd Smoothed spectrum
|
2024-03-11 16:33:28 +01:00
|
|
|
*/
|
2024-03-12 11:19:52 +01:00
|
|
|
vd freqSmooth(const vd& freq, const vd& X, const unsigned w,
|
|
|
|
bool power_correct = false);
|
2024-03-11 16:33:28 +01:00
|
|
|
|
|
|
|
/** @} */
|