/*! * \file signal_generator.h * \brief Adapter of a class that generates synthesized GNSS signal. * \author Marc Molina, 2013. marc.molina.pena@gmail.com * * * ------------------------------------------------------------------------- * * Copyright (C) 2010-2014 (see AUTHORS file for a list of contributors) * * GNSS-SDR is a software defined Global Navigation * Satellite Systems receiver * * This file is part of GNSS-SDR. * * GNSS-SDR is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * at your option) any later version. * * GNSS-SDR is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with GNSS-SDR. If not, see . * * ------------------------------------------------------------------------- */ #ifndef GNSS_SDR_SIGNAL_GENERATOR_H_ #define GNSS_SDR_SIGNAL_GENERATOR_H_ #include #include #include #include #include #include #include "gnss_block_interface.h" #include "signal_generator_c.h" class ConfigurationInterface; /*! * \brief This class generates synthesized GNSS signal. * */ class SignalGenerator: public GNSSBlockInterface { public: SignalGenerator(ConfigurationInterface* configuration, std::string role, unsigned int in_stream, unsigned int out_stream, boost::shared_ptr queue); virtual ~SignalGenerator(); std::string role() { return role_; } /*! * \brief Returns "GNSSSignalGenerator". */ std::string implementation() { return "GNSSSignalGenerator"; } size_t item_size() { return item_size_; } void connect(gr::top_block_sptr top_block); void disconnect(gr::top_block_sptr top_block); gr::basic_block_sptr get_left_block(); gr::basic_block_sptr get_right_block(); private: std::string role_; unsigned int in_stream_; unsigned int out_stream_; std::string item_type_; size_t item_size_; bool dump_; std::string dump_filename_; boost::shared_ptr gen_source_; gr::blocks::vector_to_stream::sptr vector_to_stream_; gr::blocks::file_sink::sptr file_sink_; boost::shared_ptr queue_; }; #endif /*GNSS_SDR_SIGNAL_GENERATOR_H_*/