GNU Radio 3.6.5 C++ API

pm_remez.h

Go to the documentation of this file.
00001 /* -*- c++ -*- */
00002 /*
00003  * Copyright 2004,2012 Free Software Foundation, Inc.
00004  *
00005  * This file is part of GNU Radio
00006  *
00007  * GNU Radio is free software; you can redistribute it and/or modify
00008  * it under the terms of the GNU General Public License as published by
00009  * the Free Software Foundation; either version 3, or (at your option)
00010  * any later version.
00011  *
00012  * GNU Radio is distributed in the hope that it will be useful,
00013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00015  * GNU General Public License for more details.
00016  *
00017  * You should have received a copy of the GNU General Public License
00018  * along with GNU Radio; see the file COPYING.  If not, write to
00019  * the Free Software Foundation, Inc., 51 Franklin Street,
00020  * Boston, MA 02110-1301, USA.
00021  */
00022 
00023 #ifndef INCLUDED_FILTER_PM_REMEZ_H
00024 #define INCLUDED_FILTER_PM_REMEZ_H
00025 
00026 #include <filter/api.h>
00027 #include <gr_types.h>
00028 #include <string>
00029 #include <stdexcept>
00030 
00031 namespace gr {
00032   namespace filter {
00033     /*!
00034      * \brief Parks-McClellan FIR filter design using Remez algorithm.
00035      * \ingroup filter_design
00036      *
00037      * \details
00038      * Calculates the optimal (in the Chebyshev/minimax sense) FIR
00039      * filter inpulse reponse given a set of band edges, the desired
00040      * reponse on those bands, and the weight given to the error in
00041      * those bands.
00042      *
00043      * \param order         filter order (number of taps in the returned filter - 1)
00044      * \param bands         frequency at the band edges [ b1 e1 b2 e2 b3 e3 ...]
00045      * \param ampl          desired amplitude at the band edges [ a(b1) a(e1) a(b2) a(e2) ...]
00046      * \param error_weight  weighting applied to each band (usually 1)
00047      * \param filter_type   one of "bandpass", "hilbert" or "differentiator"
00048      * \param grid_density  determines how accurately the filter will be constructed. \
00049      *                      The minimum value is 16; higher values are slower to compute.
00050      *
00051      * Frequency is in the range [0, 1], with 1 being the Nyquist
00052      * frequency (Fs/2)
00053      *
00054      * \returns vector of computed taps
00055      *
00056      * \throws std::runtime_error if args are invalid or calculation
00057      * fails to converge.
00058      */
00059 
00060     FILTER_API std::vector<double>
00061     pm_remez(int order,
00062              const std::vector<double> &bands,
00063              const std::vector<double> &ampl,
00064              const std::vector<double> &error_weight,
00065              const std::string filter_type = "bandpass",
00066              int grid_density = 16
00067              ) throw (std::runtime_error);
00068     
00069   } /* namespace filter */
00070 } /* namespace gr */
00071 
00072 #endif /* INCLUDED_FILTER_PM_REMEZ_H */