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