/* -*- C++ -*- */ /* * Copyright 2008 Steve Glass * * This file is part of OP25. * * OP25 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, or (at your option) * any later version. * * OP25 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 OP25; see the file COPYING. If not, write to the Free * Software Foundation, Inc., 51 Franklin Street, Boston, MA * 02110-1301, USA. */ #ifndef INCLUDED_IMBE_DECODER_H #define INCLUDED_IMBE_DECODER_H #include #include #include #include typedef std::deque audio_output; typedef std::vector voice_codeword; typedef boost::shared_ptr imbe_decoder_sptr; /** * imbe_decoder is the interface to the various mechanisms for * translating P25 voice codewords into audio samples. */ class imbe_decoder : public boost::noncopyable { public: /** * imbe_decoder (virtual) constructor. The exact subclass * instantiated depends on some yet-to-be-decided magic. * * \return A shared_ptr to an imbe_decoder. */ static imbe_decoder_sptr make_imbe_decoder(); /** * imbe_decoder (virtual) destructor. */ virtual ~imbe_decoder(); /** * Apply error correction to the voice_codeword in_out, * decode the audio and write it to the audio_output. * * \param in_out IMBE codewords and parity. * \param in Queue of audio samples to which output is written. * \return The number of samples written to out. */ virtual size_t decode(voice_codeword& in_out, audio_output& out) = 0; protected: /** * Construct an instance of imbe_decoder. Access is protected * because this is an abstract class and users should call * make_imbe_decoder to construct concrete instances. */ imbe_decoder(); }; #endif /* INCLUDED_IMBE_DECODER_H */