1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
function b = remez1(n,f,a, varargin)
//Parks-McClellan optimal FIR filter design
//Calling Sequence
//b = remez1 (n, f, a)
//b = remez1 (n, f, a, w)
//b = remez1 (n, f, a, w, ftype)
//b = remez1 (n, f, a, w, ftype, griddensity)
//Parameters
//n: gives the number of taps in the returned filter
//f:gives frequency at the band edges [b1 e1 b2 e2 b3 e3 …]
//a:gives amplitude at the band edges [a(b1) a(e1) a(b2) a(e2) …]
//w:gives weighting applied to each band
//ftype:is "bandpass", "hilbert" or "differentiator"
//griddensity:determines how accurately the filter will be constructed. The minimum value is 16, but higher numbers are slower to compute.
//Description
//Frequency is in the range (0, 1), with 1 being the Nyquist frequency.
funcprot(0);
rhs= argn(2);
if(rhs<3 | rhs>6)
error("Wrong number of input arguments");
end
select(rhs)
case 3 then
b= callOctave("remez", n,f,a);
case 4 then
b= callOctave("remez", n,f,a,varargin(1));
case 5 then
b= callOctave("remez", n,f,a,varargin(1), varargin(2));
case 6 then
b= callOctave("remez", n,f,a,varargin(1), varargin(2), varargin(3));
end
endfunction
|