blob: fc90f4587d389b8735a715762450a642170c2ba9 [file] [log] [blame]
ptrkrysikf8c7e832015-04-04 12:28:20 +02001/* -*- c++ -*- */
2/*
3 * @file
Piotr Krysika6268a52017-08-23 16:02:19 +02004 * @author (C) 2015-2017 by Piotr Krysik <ptrkrysik@gmail.com>
ptrkrysikf8c7e832015-04-04 12:28:20 +02005 * @section LICENSE
6 *
7 * Gr-gsm is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 3, or (at your option)
10 * any later version.
11 *
12 * Gr-gsm is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with gr-gsm; see the file COPYING. If not, write to
19 * the Free Software Foundation, Inc., 51 Franklin Street,
20 * Boston, MA 02110-1301, USA.
21 */
22
23#ifndef INCLUDED_GSM_CLOCK_OFFSET_CONTROL_IMPL_H
24#define INCLUDED_GSM_CLOCK_OFFSET_CONTROL_IMPL_H
25
26#include <grgsm/receiver/clock_offset_control.h>
27#include <string>
ptrkrysikf8c7e832015-04-04 12:28:20 +020028
29namespace gr {
30 namespace gsm {
31 class clock_offset_control_impl : public clock_offset_control
32 {
33 private:
34 float d_fc;
Piotr Krysik09826732016-07-15 13:14:24 +020035 float d_samp_rate;
Piotr Krysik83afe732016-07-17 22:48:35 +020036 unsigned int d_osr;
ptrkrysikf8c7e832015-04-04 12:28:20 +020037 float d_alfa;
38 float d_ppm_estimate;
Piotr Krysik09826732016-07-15 13:14:24 +020039 float d_last_ppm_estimate;
ptrkrysikf8c7e832015-04-04 12:28:20 +020040 bool d_first_measurement;
41 int d_counter;
42 std::string d_last_state;
ptrkrysik32c21162015-04-04 14:01:52 +020043 float d_current_time;
44 float d_last_fcch_time;
45 bool d_first_time;
ptrkrysikf8c7e832015-04-04 12:28:20 +020046
47 void process_measurement(pmt::pmt_t msg);
Piotr Krysik83afe732016-07-17 22:48:35 +020048 void send_ctrl_messages(float freq_offset);
ptrkrysikf8c7e832015-04-04 12:28:20 +020049 void timed_reset();
50 void reset();
51 public:
Piotr Krysik83afe732016-07-17 22:48:35 +020052 clock_offset_control_impl(float fc, float samp_rate, unsigned int osr);
ptrkrysikf8c7e832015-04-04 12:28:20 +020053 ~clock_offset_control_impl();
54
55 virtual void set_fc(float fc);
Piotr Krysik09826732016-07-15 13:14:24 +020056 virtual void set_samp_rate(float samp_rate);
Piotr Krysik83afe732016-07-17 22:48:35 +020057 virtual void set_osr(unsigned int osr);
ptrkrysikf8c7e832015-04-04 12:28:20 +020058 };
59 } // namespace gsm
60} // namespace gr
61
62#endif /* INCLUDED_GSM_CLOCK_OFFSET_CONTROL_IMPL_H */
63