Statistics
| Branch: | Tag: | Revision:

root / gnuradio-core / src / lib / general / gr_check_counting_s.h @ f1ae6ff2

History | View | Annotate | Download (2.6 kB)

1 5d69a524 jcorgan
/* -*- c++ -*- */
2 5d69a524 jcorgan
/*
3 5d69a524 jcorgan
 * Copyright 2004 Free Software Foundation, Inc.
4 5d69a524 jcorgan
 * 
5 5d69a524 jcorgan
 * This file is part of GNU Radio
6 5d69a524 jcorgan
 * 
7 5d69a524 jcorgan
 * GNU Radio is free software; you can redistribute it and/or modify
8 5d69a524 jcorgan
 * it under the terms of the GNU General Public License as published by
9 5d69a524 jcorgan
 * the Free Software Foundation; either version 2, or (at your option)
10 5d69a524 jcorgan
 * any later version.
11 5d69a524 jcorgan
 * 
12 5d69a524 jcorgan
 * GNU Radio is distributed in the hope that it will be useful,
13 5d69a524 jcorgan
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 5d69a524 jcorgan
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 5d69a524 jcorgan
 * GNU General Public License for more details.
16 5d69a524 jcorgan
 * 
17 5d69a524 jcorgan
 * You should have received a copy of the GNU General Public License
18 5d69a524 jcorgan
 * along with GNU Radio; see the file COPYING.  If not, write to
19 5d69a524 jcorgan
 * the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
20 5d69a524 jcorgan
 * Boston, MA 02111-1307, USA.
21 5d69a524 jcorgan
 */
22 5d69a524 jcorgan
#ifndef INCLUDED_GR_CHECK_COUNTING_S_H
23 5d69a524 jcorgan
#define INCLUDED_GR_CHECK_COUNTING_S_H
24 5d69a524 jcorgan
25 5d69a524 jcorgan
#include <gr_sync_block.h>
26 5d69a524 jcorgan
27 5d69a524 jcorgan
class gr_check_counting_s;
28 5d69a524 jcorgan
typedef boost::shared_ptr<gr_check_counting_s> gr_check_counting_s_sptr;
29 5d69a524 jcorgan
30 5d69a524 jcorgan
gr_check_counting_s_sptr gr_make_check_counting_s (bool do_32bit=false);
31 5d69a524 jcorgan
32 5d69a524 jcorgan
/*!
33 5d69a524 jcorgan
 * \brief sink that checks if its input stream consists of a counting sequence.
34 5d69a524 jcorgan
 * \param do_32bit  expect an interleaved 32 bit counter in stead of 16 bit counter (default false)
35 5d69a524 jcorgan
 * \ingroup sink
36 5d69a524 jcorgan
 *
37 5d69a524 jcorgan
 * This sink is typically used to test the USRP "Counting Mode" or "Counting mode 32 bit".
38 5d69a524 jcorgan
 */
39 5d69a524 jcorgan
class gr_check_counting_s : public gr_sync_block
40 5d69a524 jcorgan
{
41 5d69a524 jcorgan
  friend gr_check_counting_s_sptr gr_make_check_counting_s (bool do_32bit);
42 5d69a524 jcorgan
43 5d69a524 jcorgan
  enum state {
44 5d69a524 jcorgan
    SEARCHING,    // searching for synchronization
45 5d69a524 jcorgan
    LOCKED    // is locked
46 5d69a524 jcorgan
  };
47 5d69a524 jcorgan
48 5d69a524 jcorgan
  state      d_state;
49 5d69a524 jcorgan
  unsigned int    d_history;    // bitmask of decisions
50 5d69a524 jcorgan
  unsigned short  d_current_count;
51 5d69a524 jcorgan
  unsigned int    d_current_count_32bit;
52 5d69a524 jcorgan
  
53 5d69a524 jcorgan
  long      d_total_errors;
54 5d69a524 jcorgan
  long      d_total_shorts;
55 5d69a524 jcorgan
  bool      d_do_32bit;
56 5d69a524 jcorgan
57 5d69a524 jcorgan
  gr_check_counting_s (bool do_32bit);
58 5d69a524 jcorgan
  
59 5d69a524 jcorgan
  void enter_SEARCHING ();
60 5d69a524 jcorgan
  void enter_LOCKED ();
61 5d69a524 jcorgan
62 5d69a524 jcorgan
  void right (){
63 5d69a524 jcorgan
    d_history = (d_history << 1) | 0x1;
64 5d69a524 jcorgan
  }
65 5d69a524 jcorgan
  
66 5d69a524 jcorgan
  void wrong (){
67 5d69a524 jcorgan
    d_history = (d_history << 1) | 0x0;
68 5d69a524 jcorgan
    d_total_errors++;
69 5d69a524 jcorgan
  }
70 5d69a524 jcorgan
71 5d69a524 jcorgan
  bool right_three_times () { return (d_history & 0x7) == 0x7; }
72 5d69a524 jcorgan
  bool wrong_three_times () { return (d_history & 0x7) == 0x0; }
73 5d69a524 jcorgan
74 5d69a524 jcorgan
  void log_error (unsigned short expected, unsigned short actual);
75 5d69a524 jcorgan
  void log_error_32bit (unsigned int expected, unsigned int actual);
76 5d69a524 jcorgan
  
77 5d69a524 jcorgan
  int check_32bit (int noutput_items, unsigned short * in);
78 5d69a524 jcorgan
  int check_16bit (int noutput_items, unsigned short * in);
79 5d69a524 jcorgan
80 5d69a524 jcorgan
 public:
81 5d69a524 jcorgan
82 5d69a524 jcorgan
  int work (int noutput_items,
83 5d69a524 jcorgan
      gr_vector_const_void_star &input_items,
84 5d69a524 jcorgan
      gr_vector_void_star &output_items);
85 5d69a524 jcorgan
};
86 5d69a524 jcorgan
87 5d69a524 jcorgan
88 5d69a524 jcorgan
#endif /* INCLUDED_GR_CHECK_COUNTING_S_H */