GNU Radio 3.4.2 C++ API
gr_remez.h
Go to the documentation of this file.
00001 /* -*- c++ -*- */
00002 /*
00003  * Copyright 2004 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_GR_REMEZ_H
00024 #define INCLUDED_GR_REMEZ_H
00025 
00026 #include <gr_types.h>
00027 #include <string>
00028 #include <stdexcept>
00029 
00030 /*!
00031  * \brief Parks-McClellan FIR filter design.
00032  *
00033  * \ingroup filter_design
00034  *
00035  * Calculates the optimal (in the Chebyshev/minimax sense) FIR filter
00036  * inpulse reponse given a set of band edges, the desired reponse on
00037  * those bands, and the weight given to the error in those bands.
00038  *
00039  * \param order             filter order (number of taps in the returned filter - 1)
00040  * \param bands             frequency at the band edges [ b1 e1 b2 e2 b3 e3 ...]
00041  * \param ampl              desired amplitude at the band edges [ a(b1) a(e1) a(b2) a(e2) ...]
00042  * \param error_weight      weighting applied to each band (usually 1)
00043  * \param filter_type       one of "bandpass", "hilbert" or "differentiator"
00044  * \param grid_density      determines how accurately the filter will be constructed. \
00045  *                              The minimum value is 16; higher values are slower to compute.
00046  *
00047  * Frequency is in the range [0, 1], with 1 being the Nyquist frequency (Fs/2)
00048  *
00049  * \returns vector of computed taps
00050  *
00051  * \throws std::runtime_error if args are invalid or calculation fails to converge.
00052  */
00053 
00054 std::vector<double>
00055 gr_remez (int order,
00056           const std::vector<double> &bands,
00057           const std::vector<double> &ampl,
00058           const std::vector<double> &error_weight,
00059           const std::string filter_type = "bandpass",
00060           int grid_density = 16
00061           ) throw (std::runtime_error);
00062 
00063 
00064 #endif /* INCLUDED_GR_REMEZ_H */