2015-04-02 23:13:36 +02:00
|
|
|
/** @file
|
|
|
|
* @author Edouard DUPIN
|
|
|
|
* @author Fatima MARFOUQ
|
|
|
|
* @copyright 2011, Edouard DUPIN, all right reserved
|
|
|
|
* @license APACHE v2.0 (see license file)
|
|
|
|
*/
|
2016-02-02 21:18:54 +01:00
|
|
|
#pragma once
|
2015-04-02 23:13:36 +02:00
|
|
|
|
|
|
|
#include <etk/types.h>
|
2015-09-14 21:11:04 +02:00
|
|
|
#include <chrono>
|
2015-04-23 21:17:45 +02:00
|
|
|
#include <audio/format.h>
|
2015-09-14 21:11:04 +02:00
|
|
|
#include <memory>
|
2015-04-23 21:17:45 +02:00
|
|
|
|
2015-04-02 23:13:36 +02:00
|
|
|
namespace audio {
|
|
|
|
namespace algo {
|
2015-04-23 21:17:45 +02:00
|
|
|
namespace river {
|
|
|
|
class NlmsPrivate;
|
2015-04-02 23:13:36 +02:00
|
|
|
/**
|
|
|
|
* @brief Least Mean Square (LMS) algorithm "echo canceller"
|
|
|
|
* base on publication: http://www.arpapress.com/Volumes/Vol7Issue1/IJRRAS_7_1_05.pdf
|
|
|
|
Electronic description:
|
|
|
|
/
|
|
|
|
o---o /|
|
|
|
|
_feedback | |/ |
|
|
|
|
>---------------->| | | >~~~~~~~~o
|
|
|
|
x(n) | |\ | |
|
|
|
|
o---o \| |
|
|
|
|
\ o--------0
|
|
|
|
| | Environement
|
|
|
|
| u(n) | transfert fonction
|
|
|
|
| |
|
|
|
|
o--------o
|
|
|
|
|
|
|
|
|
|
|
|
|
|
o---o ___ |
|
|
|
|
_microphone | |/ \ <~~~~~~o
|
|
|
|
<----------------<| | | <~~~~~~~~~~~~< Noise
|
|
|
|
d(n) | |\___/ <~~~~~~0
|
|
|
|
o---o |
|
|
|
|
|
|
|
|
|
o~~~~~< Usefull signal
|
|
|
|
s(n)
|
|
|
|
|
|
|
|
LMS Algorithm:
|
|
|
|
|
|
|
|
_microphone -----------------------------o
|
|
|
|
d(n) |
|
|
|
|
|
|
|
|
|
o--------o | o-------------o
|
|
|
|
o---> filter --------->| | o--->| | _output
|
|
|
|
| û(n) | convol-| | d(n) - y(n) |----> e(n) -------> echo-cancelled
|
|
|
|
| | -ution |----> y(n) ---->| | |
|
|
|
|
| _feedback -----o--->| | o-------------o |
|
|
|
|
| x(n) | o--------o |
|
|
|
|
| | |
|
|
|
|
| | o----------------------------------o |
|
|
|
|
| | | | |
|
|
|
|
| o-------->| |<-------o
|
|
|
|
| | û(n+1) = û(n) |
|
|
|
|
| | + mu * e(n) * x(n) |
|
|
|
|
| | |
|
|
|
|
| o----------------------------------o
|
|
|
|
| |
|
|
|
|
| |
|
|
|
|
o--------------------------------------------o
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
class Nlms {
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @brief Constructor
|
|
|
|
*/
|
2015-04-23 21:17:45 +02:00
|
|
|
Nlms();
|
2015-04-02 23:13:36 +02:00
|
|
|
/**
|
|
|
|
* @brief Destructor
|
|
|
|
*/
|
2015-04-23 21:17:45 +02:00
|
|
|
virtual ~Nlms();
|
2015-04-02 23:13:36 +02:00
|
|
|
public:
|
|
|
|
/**
|
2015-04-23 21:17:45 +02:00
|
|
|
* @brief Reset algorithm
|
2015-04-02 23:13:36 +02:00
|
|
|
*/
|
2015-04-23 21:17:45 +02:00
|
|
|
virtual void reset();
|
2015-04-02 23:13:36 +02:00
|
|
|
/**
|
2015-04-23 21:17:45 +02:00
|
|
|
* @brief Initialize the Algorithm
|
|
|
|
* @param[in] _nbChannel Number of channel in the stream.
|
|
|
|
* @param[in] _sampleRate Sample rate.
|
|
|
|
* @param[in] _format Input/output data format.
|
2015-04-02 23:13:36 +02:00
|
|
|
*/
|
2015-04-23 21:17:45 +02:00
|
|
|
virtual void init(int8_t _nbChannel, float _sampleRate, enum audio::format _format = audio::format_float);
|
2015-04-02 23:13:36 +02:00
|
|
|
/**
|
2015-04-23 21:17:45 +02:00
|
|
|
* @brief Get list of format suported in input.
|
|
|
|
* @return list of supported format
|
2015-04-02 23:13:36 +02:00
|
|
|
*/
|
2015-04-23 21:17:45 +02:00
|
|
|
virtual std::vector<enum audio::format> getSupportedFormat();
|
2015-04-02 23:13:36 +02:00
|
|
|
/**
|
2015-04-23 21:17:45 +02:00
|
|
|
* @brief Get list of algorithm format suported. No format convertion.
|
|
|
|
* @return list of supported format
|
2015-04-02 23:13:36 +02:00
|
|
|
*/
|
2015-04-23 21:17:45 +02:00
|
|
|
virtual std::vector<enum audio::format> getNativeSupportedFormat();
|
|
|
|
/**
|
|
|
|
* @brief Main input algo process.
|
|
|
|
* @param[in,out] _output Output data.
|
|
|
|
* @param[in] _input Input data.
|
|
|
|
* @param[in] _inputFeedback Input feedback data (all time MONO).
|
|
|
|
* @param[in] _nbChunk Number of chunk in the input buffer.
|
|
|
|
* @param[in] _nbChannel Number of channel in the stream.
|
|
|
|
*/
|
|
|
|
virtual void process(void* _output, const void* _input, const void* _inputFeedback, size_t _nbChunk);
|
|
|
|
protected:
|
2016-03-08 21:29:34 +01:00
|
|
|
std::shared_ptr<NlmsPrivate> m_private; // private data.
|
2015-04-23 21:17:45 +02:00
|
|
|
public: // parameter area:
|
2015-04-02 23:13:36 +02:00
|
|
|
/**
|
|
|
|
* @brief Set filter size with specifing the filter temporal size and his samplerate
|
|
|
|
* @param[in] _time Time of the filter size
|
|
|
|
*/
|
2016-03-08 21:29:34 +01:00
|
|
|
virtual void setFilterTime(std::chrono::microseconds _time);
|
2015-04-02 23:13:36 +02:00
|
|
|
/**
|
|
|
|
* @brief Set filter size in number of sample
|
|
|
|
* @param[in] _nbSample Sample size of the filter
|
|
|
|
*/
|
2015-04-23 21:17:45 +02:00
|
|
|
virtual void setFilterSize(size_t _nbSample);
|
|
|
|
/**
|
|
|
|
* @brief Set Mu value for basic LMS value
|
|
|
|
* @param[in] _val new mu value
|
|
|
|
*/
|
|
|
|
virtual void setMu(double _val);
|
2015-04-02 23:13:36 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|