GNU Radio 3.6.5 C++ API

gr_sync_interpolator Class Reference

synchronous 1:N input to output with historyOverride work to provide the signal processing implementation. More...

#include <gr_sync_interpolator.h>

Inheritance diagram for gr_sync_interpolator:
gr_sync_block gr_block gr_basic_block gr_msg_accepter gruel::msg_accepter atsc_depad digital_bytes_to_syms digital_chunks_to_symbols_bc digital_chunks_to_symbols_bf digital_chunks_to_symbols_ic digital_chunks_to_symbols_if digital_chunks_to_symbols_sc digital_chunks_to_symbols_sf gr::analog::cpfsk_bc gr::blocks::complex_to_interleaved_short gr::blocks::interleave gr::blocks::repeat gr::blocks::streams_to_stream gr::blocks::unpack_k_bits_bb gr::blocks::vector_to_stream gr::filter::interp_fir_filter_ccc gr::filter::interp_fir_filter_ccf gr::filter::interp_fir_filter_fcc gr::filter::interp_fir_filter_fff gr::filter::interp_fir_filter_fsf gr::filter::interp_fir_filter_scc gr::filter::pfb_interpolator_ccf gr::filter::pfb_synthesizer_ccf gr_bytes_to_syms gr_chunks_to_symbols_bc gr_chunks_to_symbols_bf gr_chunks_to_symbols_ic gr_chunks_to_symbols_if gr_chunks_to_symbols_sc gr_chunks_to_symbols_sf gr_complex_to_interleaved_short gr_cpfsk_bc gr_encode_ccsds_27_bb gr_interleave gr_interp_fir_filter_ccc gr_interp_fir_filter_ccf gr_interp_fir_filter_fcc gr_interp_fir_filter_fff gr_interp_fir_filter_fsf gr_interp_fir_filter_scc gr_pfb_interpolator_ccf gr_pfb_synthesizer_ccf gr_repeat gr_streams_to_stream gr_unpack_k_bits_bb gr_vector_to_stream vocoder_codec2_decode_ps vocoder_cvsd_decode_bs vocoder_gsm_fr_decode_ps

List of all members.

Public Member Functions

unsigned interpolation () const
void set_interpolation (unsigned interpolation)
void forecast (int noutput_items, gr_vector_int &ninput_items_required)
 Estimate input requirements given output request.
int general_work (int noutput_items, gr_vector_int &ninput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
 compute output items from input items
int fixed_rate_ninput_to_noutput (int ninput)
 Given ninput samples, return number of output samples that will be produced. N.B. this is only defined if fixed_rate returns true. Generally speaking, you don't need to override this.
int fixed_rate_noutput_to_ninput (int noutput)
 Given noutput samples, return number of input samples required to produce noutput. N.B. this is only defined if fixed_rate returns true. Generally speaking, you don't need to override this.

Protected Member Functions

 gr_sync_interpolator (void)
 gr_sync_interpolator (const std::string &name, gr_io_signature_sptr input_signature, gr_io_signature_sptr output_signature, unsigned interpolation)

Detailed Description

synchronous 1:N input to output with history

Override work to provide the signal processing implementation.


Constructor & Destructor Documentation

gr_sync_interpolator::gr_sync_interpolator ( void  ) [inline, protected]
gr_sync_interpolator::gr_sync_interpolator ( const std::string &  name,
gr_io_signature_sptr  input_signature,
gr_io_signature_sptr  output_signature,
unsigned  interpolation 
) [protected]

Member Function Documentation

int gr_sync_interpolator::fixed_rate_ninput_to_noutput ( int  ninput) [virtual]

Given ninput samples, return number of output samples that will be produced. N.B. this is only defined if fixed_rate returns true. Generally speaking, you don't need to override this.

Reimplemented from gr_sync_block.

int gr_sync_interpolator::fixed_rate_noutput_to_ninput ( int  noutput) [virtual]

Given noutput samples, return number of input samples required to produce noutput. N.B. this is only defined if fixed_rate returns true. Generally speaking, you don't need to override this.

Reimplemented from gr_sync_block.

void gr_sync_interpolator::forecast ( int  noutput_items,
gr_vector_int ninput_items_required 
) [virtual]

Estimate input requirements given output request.

Parameters:
noutput_itemsnumber of output items to produce
ninput_items_requirednumber of input items required on each input stream

Given a request to product noutput_items, estimate the number of data items required on each input stream. The estimate doesn't have to be exact, but should be close.

Reimplemented from gr_sync_block.

int gr_sync_interpolator::general_work ( int  noutput_items,
gr_vector_int ninput_items,
gr_vector_const_void_star input_items,
gr_vector_void_star output_items 
) [virtual]

compute output items from input items

Parameters:
noutput_itemsnumber of output items to write on each output stream
ninput_itemsnumber of input items available on each input stream
input_itemsvector of pointers to the input items, one entry per input stream
output_itemsvector of pointers to the output items, one entry per output stream
Returns:
number of items actually written to each output stream, or -1 on EOF. It is OK to return a value less than noutput_items. -1 <= return value <= noutput_items

general_work must call consume or consume_each to indicate how many items were consumed on each input stream.

Reimplemented from gr_sync_block.

unsigned gr_sync_interpolator::interpolation ( ) const [inline]
void gr_sync_interpolator::set_interpolation ( unsigned  interpolation) [inline]

The documentation for this class was generated from the following file: