18 #ifndef GNSS_SDR_FIFO_READER_H_ 19 #define GNSS_SDR_FIFO_READER_H_ 22 #include <gnuradio/sync_block.h> 34 using sptr = gnss_shared_ptr<FifoReader>;
35 static sptr make(
const std::string &file_name,
const std::string &sample_type);
43 int work(
int noutput_items,
44 gr_vector_const_void_star &input_items,
45 gr_vector_void_star &output_items);
51 FifoReader(
const std::string &file_name,
const std::string &sample_type);
53 size_t read_gr_complex(
int noutput_items, gr_vector_void_star &output_items);
59 template <
typename Type>
60 size_t read_interleaved(
int noutput_items, gr_vector_void_star &output_items)
62 size_t items_retrieved = 0;
63 for (
int n = 0; n < noutput_items; n++)
67 std::array<char, 2 * sizeof(Type)> buffer;
68 fifo_.read(reinterpret_cast<char *>(buffer.data()), buffer.size());
71 auto real =
reinterpret_cast<Type
const *
>(&buffer[0]);
72 auto imag =
reinterpret_cast<Type
const *
>(&buffer[
sizeof(Type)]);
73 static_cast<gr_complex *
>(output_items[0])[n] = gr_complex(*real, *imag);
87 return items_retrieved;
92 void fifo_error_output()
const;
94 const std::string file_name_;
95 const std::string sample_type_;
bool start()
initialize istream resource for FIFO
This interface represents a GNSS block.
gnss_shared_ptr< FifoReader > sptr
static function to create a class instance