2022-07-04 17:03:07 -04:00
|
|
|
// Copyright 2020 modemm17 LLC.
|
2022-06-06 21:22:18 -04:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "IirFilter.h"
|
|
|
|
|
|
|
|
#include <array>
|
|
|
|
#include <algorithm>
|
|
|
|
#include <numeric>
|
|
|
|
#include <cmath>
|
|
|
|
#include <tuple>
|
|
|
|
|
2022-07-04 17:03:07 -04:00
|
|
|
namespace modemm17
|
2022-06-06 21:22:18 -04:00
|
|
|
{
|
|
|
|
|
|
|
|
struct CarrierDetect
|
|
|
|
{
|
2022-06-09 14:12:35 -04:00
|
|
|
using result_t = std::tuple<bool, float>;
|
2022-06-06 21:22:18 -04:00
|
|
|
|
2022-06-09 14:12:35 -04:00
|
|
|
BaseIirFilter<3> filter_;
|
|
|
|
float lock_;
|
|
|
|
float unlock_;
|
2022-06-06 21:22:18 -04:00
|
|
|
bool locked_ = false;
|
|
|
|
|
2022-06-09 14:12:35 -04:00
|
|
|
CarrierDetect(std::array<float, 3> const& b, std::array<float, 3> const& a, float lock_level, float unlock_level)
|
2022-06-06 21:22:18 -04:00
|
|
|
: filter_(b, a), lock_(lock_level), unlock_(unlock_level)
|
|
|
|
{
|
|
|
|
}
|
2022-06-09 14:12:35 -04:00
|
|
|
|
|
|
|
result_t operator()(float value)
|
2022-06-06 21:22:18 -04:00
|
|
|
{
|
|
|
|
auto filtered = filter_(std::abs(value));
|
|
|
|
if (locked_ && (filtered > unlock_)) locked_ = false;
|
|
|
|
else if (!locked_ && (filtered < lock_)) locked_ = true;
|
|
|
|
|
|
|
|
return std::make_tuple(locked_, filtered);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-07-04 17:03:07 -04:00
|
|
|
} // modemm17
|