summaryrefslogtreecommitdiff
path: root/gr-analog/lib/pwr_squelch_cc_impl.cc
blob: a81b2918dfd3ea5f6ef0a18f268e1f1975bfea43 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/* -*- c++ -*- */
/*
 * Copyright 2004,2006,2010,2012 Free Software Foundation, Inc.
 *
 * This file is part of GNU Radio
 *
 * SPDX-License-Identifier: GPL-3.0-or-later
 *
 */

#ifdef HAVE_CONFIG_H
#include "config.h"
#endif

#include "pwr_squelch_cc_impl.h"

namespace gr {
namespace analog {

pwr_squelch_cc::sptr
pwr_squelch_cc::make(double threshold, double alpha, int ramp, bool gate)
{
    return gnuradio::make_block_sptr<pwr_squelch_cc_impl>(threshold, alpha, ramp, gate);
}

pwr_squelch_cc_impl::pwr_squelch_cc_impl(double threshold,
                                         double alpha,
                                         int ramp,
                                         bool gate)
    : block("pwr_squelch_cc",
            io_signature::make(1, 1, sizeof(gr_complex)),
            io_signature::make(1, 1, sizeof(gr_complex))),
      squelch_base_cc_impl("pwr_squelch_cc", ramp, gate),
      d_pwr(0),
      d_iir(alpha)
{
    set_threshold(threshold);
}

pwr_squelch_cc_impl::~pwr_squelch_cc_impl() {}

std::vector<float> pwr_squelch_cc_impl::squelch_range() const
{
    std::vector<float> r(3);
    r[0] = -50.0;               // min	FIXME
    r[1] = +50.0;               // max	FIXME
    r[2] = (r[1] - r[0]) / 100; // step size

    return r;
}

void pwr_squelch_cc_impl::update_state(const gr_complex& in)
{
    d_pwr = d_iir.filter(in.real() * in.real() + in.imag() * in.imag());
}

void pwr_squelch_cc_impl::set_threshold(double db)
{
    gr::thread::scoped_lock l(d_setlock);
    d_threshold = std::pow(10.0, db / 10);
}

void pwr_squelch_cc_impl::set_alpha(double alpha)
{
    gr::thread::scoped_lock l(d_setlock);
    d_iir.set_taps(alpha);
}

} /* namespace analog */
} /* namespace gr */