diff options
Diffstat (limited to 'macros')
-rw-r--r-- | macros/besselap.bin | bin | 0 -> 4340 bytes | |||
-rw-r--r-- | macros/besselap.sci | 48 | ||||
-rw-r--r-- | macros/buttap.bin | bin | 0 -> 4104 bytes | |||
-rw-r--r-- | macros/buttap.sci | 45 | ||||
-rw-r--r-- | macros/cheb.bin | bin | 0 -> 3404 bytes | |||
-rw-r--r-- | macros/cheb.sci | 34 | ||||
-rw-r--r-- | macros/cheb1ap.bin | bin | 0 -> 5508 bytes | |||
-rw-r--r-- | macros/cheb1ap.sci | 51 | ||||
-rw-r--r-- | macros/cheb2ap.bin | bin | 0 -> 4056 bytes | |||
-rw-r--r-- | macros/cheb2ap.sci | 39 | ||||
-rw-r--r-- | macros/cplxreal.bin | bin | 0 -> 5940 bytes | |||
-rw-r--r-- | macros/cplxreal.sci | 43 | ||||
-rw-r--r-- | macros/ellipap.bin | bin | 0 -> 5264 bytes | |||
-rw-r--r-- | macros/ellipap.sci | 46 | ||||
-rw-r--r-- | macros/fft.bin | bin | 0 -> 6080 bytes | |||
-rw-r--r-- | macros/fft.sci | 49 | ||||
-rw-r--r-- | macros/fft2.bin | bin | 0 -> 5292 bytes | |||
-rw-r--r-- | macros/fft2.sci | 45 | ||||
-rw-r--r-- | macros/freqs.bin | bin | 0 -> 3628 bytes | |||
-rw-r--r-- | macros/freqs.sci | 29 | ||||
-rw-r--r-- | macros/ifft.bin | bin | 0 -> 6476 bytes | |||
-rw-r--r-- | macros/ifft.sci | 51 | ||||
-rw-r--r-- | macros/ifft2.bin | bin | 0 -> 6016 bytes | |||
-rw-r--r-- | macros/ifft2.sci | 45 | ||||
-rw-r--r-- | macros/lib | bin | 5688 -> 5528 bytes | |||
-rw-r--r-- | macros/names | 20 | ||||
-rw-r--r-- | macros/ncauer.bin | bin | 0 -> 5372 bytes | |||
-rw-r--r-- | macros/ncauer.sci | 49 | ||||
-rw-r--r-- | macros/peak2rms.bin | bin | 13896 -> 13896 bytes | |||
-rw-r--r-- | macros/pei_tseng_notch.bin | bin | 0 -> 5436 bytes | |||
-rw-r--r-- | macros/pei_tseng_notch.sci | 44 | ||||
-rw-r--r-- | macros/wconv.bin | bin | 0 -> 3416 bytes | |||
-rw-r--r-- | macros/wconv.sci | 33 | ||||
-rw-r--r-- | macros/zp2ss.bin | bin | 0 -> 5916 bytes | |||
-rw-r--r-- | macros/zp2ss.sci | 65 | ||||
-rw-r--r-- | macros/zp2tf.bin | bin | 0 -> 4116 bytes | |||
-rw-r--r-- | macros/zp2tf.sci | 46 |
37 files changed, 782 insertions, 0 deletions
diff --git a/macros/besselap.bin b/macros/besselap.bin Binary files differnew file mode 100644 index 0000000..9794042 --- /dev/null +++ b/macros/besselap.bin diff --git a/macros/besselap.sci b/macros/besselap.sci new file mode 100644 index 0000000..6fe4f47 --- /dev/null +++ b/macros/besselap.sci @@ -0,0 +1,48 @@ +function [zero, pole, gain] = besselap (n) +//Return bessel analog filter prototype. +//Calling Sequence +//[zero, pole, gain] = besselap (n) +//[zero, pole] = besselap (n) +//zero = besselap (n) +//Parameters +//n: Filter Order +//zero: Zeros +//pole: Poles +//gain: Gain +//Description +//This is an Octave function. +//It Return bessel analog filter prototype of nth order. +//Examples +//[zero, pole, gain] = besselap (5) +//zero = [](0x0) +//pole = +// +// -0.59058 + 0.90721i +// -0.59058 - 0.90721i +// -0.92644 + 0.00000i +// -0.85155 + 0.44272i +// -0.85155 - 0.44272i +// +//gain = 1 + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 1 | rhs > 1) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 1 then + if(lhs==1) + zero = callOctave("besselap",n) + elseif(lhs==2) + [zero, pole] = callOctave("besselap",n) + elseif(lhs==3) + [zero, pole, gain] = callOctave("besselap",n) + else + error("Wrong number of output argments.") + end + end +endfunction diff --git a/macros/buttap.bin b/macros/buttap.bin Binary files differnew file mode 100644 index 0000000..10ce21e --- /dev/null +++ b/macros/buttap.bin diff --git a/macros/buttap.sci b/macros/buttap.sci new file mode 100644 index 0000000..9c2e08d --- /dev/null +++ b/macros/buttap.sci @@ -0,0 +1,45 @@ +function [z, p, g] = buttap (n) +//Design a lowpass analog Butterworth filter. +//Calling Sequence +//z = buttap (n) +//[z, p] = buttap (n) +//[z, p, g] = buttap (n) +//Parameters +//n: Filter Order +//z: Zeros +//p: Poles +//g: Gain +//Description +//This is an Octave function. +//It designs a lowpass analog Butterworth filter of nth order. +//Examples +//[z, p, g] = buttap (5) +//z = [](0x0) +//p = +// +// -0.30902 + 0.95106i -0.80902 + 0.58779i -1.00000 + 0.00000i -0.80902 - 0.58779i -0.30902 - 0.95106i +// +//g = 1 + + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 1 | rhs > 1) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 1 then + if(lhs==1) + z = callOctave("buttap",n) + elseif(lhs==2) + [z, p] = callOctave("buttap",n) + elseif(lhs==3) + [z, p, g] = callOctave("buttap",n) + else + error("Wrong number of output argments.") + end + end +endfunction diff --git a/macros/cheb.bin b/macros/cheb.bin Binary files differnew file mode 100644 index 0000000..28632eb --- /dev/null +++ b/macros/cheb.bin diff --git a/macros/cheb.sci b/macros/cheb.sci new file mode 100644 index 0000000..db2df85 --- /dev/null +++ b/macros/cheb.sci @@ -0,0 +1,34 @@ +function res = cheb (n, x) +//Calculates the nth-order Chebyshev polynomial at the point x. +//Calling Sequence +//cheb(n, x) +//Parameters +//n: Filter order +//x: Point at which the Chebyshev polynomial is calculater. +//Description +//This is an Octave function. +//Equation for Chebyshev polynomial is +// / cos(n acos(x), |x| <= 1 +// Tn(x) = | +// \ cosh(n acosh(x), |x| > 1 +// +//x can also be a vector. In that case the output will also be a vector of same size as x. +//Examples +//x = [1 2 3 4] +// cheb(10, x) +//ans = +// +// 1.0000e+00 2.6209e+05 2.2620e+07 4.5747e+08 + +funcprot(0); +rhs = argn(2) +if (rhs < 2 | rhs > 2) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 2 then + res = callOctave("cheb",n,x) + end +endfunction diff --git a/macros/cheb1ap.bin b/macros/cheb1ap.bin Binary files differnew file mode 100644 index 0000000..7414b4a --- /dev/null +++ b/macros/cheb1ap.bin diff --git a/macros/cheb1ap.sci b/macros/cheb1ap.sci new file mode 100644 index 0000000..361f272 --- /dev/null +++ b/macros/cheb1ap.sci @@ -0,0 +1,51 @@ +function [z, p, g] = cheb1ap (n, Rp) +//This function designs a lowpass analog Chebyshev type I filter. +//Calling Sequence +//[z, p, g] = cheb1ap (n, Rp) +//[z, p] = cheb1ap (n, Rp) +//p = cheb1ap (n, Rp) +//Parameters +//n: Filter Order +//Rp: Peak-to-peak passband ripple +//z: Zeros +//p: Poles +//g: Gain +//Description +//This is an Octave function. +//It designs a lowpass analog Chebyshev type I filter of nth order and with a Peak-to-peak passband ripple of Rp. +//Examples +//[z, p, g] = cheb1ap (10, 20) +//z = [](0x0) +//p = +// +// Columns 1 through 6: +// +// -0.00157 - 0.98774i -0.00456 - 0.89105i -0.00709 - 0.70714i -0.00894 - 0.45401i -0.00991 - 0.15644i -0.00991 + 0.15644i +// +// Columns 7 through 10: +// +// -0.00894 + 0.45401i -0.00709 + 0.70714i -0.00456 + 0.89105i -0.00157 + 0.98774i +// +//g = 1.9630e-04 - 6.3527e-22i + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 2 | rhs > 2) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 2 then + if(lhs==1) + z = callOctave("cheb1ap", n, Rp) + elseif(lhs==2) + [z, p] = callOctave("cheb1ap", n, Rp) + elseif(lhs==3) + [z, p, g] = callOctave("cheb1ap", n, Rp) + else + error("Wrong number of output argments.") + end + end +endfunction diff --git a/macros/cheb2ap.bin b/macros/cheb2ap.bin Binary files differnew file mode 100644 index 0000000..558a95b --- /dev/null +++ b/macros/cheb2ap.bin diff --git a/macros/cheb2ap.sci b/macros/cheb2ap.sci new file mode 100644 index 0000000..007d2d5 --- /dev/null +++ b/macros/cheb2ap.sci @@ -0,0 +1,39 @@ +function [z, p, g] = cheb2ap (n, Rs) +//This function designs a lowpass analog Chebyshev type II filter. +//Calling Sequence +//[z, p, g] = cheb2ap (n, Rs) +//[z, p] = cheb2ap (n, Rs) +//p = cheb2ap (n, Rs) +//Parameters +//n: Filter Order +//Rs: Stopband attenuation +//z: Zeros +//p: Poles +//g: Gain +//Description +//This is an Octave function. +//This function designs a lowpass analog Chebyshev type II filter of nth order and with a stopband attenuation of Rs. +//Examples +// + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 2 | rhs > 2) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 2 then + if(lhs==1) + z = callOctave("cheb2ap", n, Rs) + elseif(lhs==2) + [z, p] = callOctave("cheb2ap", n, Rs) + elseif(lhs==3) + [z, p, g] = callOctave("cheb2ap", n, Rs) + else + error("Wrong number of output argments.") + end + end +endfunction diff --git a/macros/cplxreal.bin b/macros/cplxreal.bin Binary files differnew file mode 100644 index 0000000..c5c522b --- /dev/null +++ b/macros/cplxreal.bin diff --git a/macros/cplxreal.sci b/macros/cplxreal.sci new file mode 100644 index 0000000..8443837 --- /dev/null +++ b/macros/cplxreal.sci @@ -0,0 +1,43 @@ +function [zc, zr] = cplxreal (z, thresh) +//Function to divide vector z into complex and real elements, removing the one of each complex conjugate pair. +//Calling Sequence +//[zc, zr] = cplxreal (z, thresh) +//[zc, zr] = cplxreal (z) +//zc = cplxreal (z, thresh) +//zc = cplxreal (z) +//Parameters +//z: vector of complex numbers. +//thresh: tolerance for comparisons. +//zc: vector containing the elements of z that have positive imaginary parts. +//zr: vector containing the elements of z that are real. +//Description +//This is an Octave function. +//Every complex element of z is expected to have a complex-conjugate elsewhere in z. From the pair of complex-conjugates, the one with the negative imaginary part is removed. +//If the magnitude of the imaginary part of an element is less than the thresh, it is declared as real. +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 1 | rhs > 2) +error("Wrong number of input arguments.") +end + +select(rhs) + case 1 then + if(lhs==1) + zc = callOctave("cplxreal",z) + elseif (lhs==2) + [zc, zr] = callOctave("cplxreal",z) + else + error("Wrong number of output argments.") + end + + case 2 then + if(lhs==1) + zc = callOctave("cplxreal",z, thresh) + elseif (lhs==2) + [zc, zr] = callOctave("cplxreal",z, thresh) + else + error("Wrong number of output argments.") + end + end +endfunction diff --git a/macros/ellipap.bin b/macros/ellipap.bin Binary files differnew file mode 100644 index 0000000..da6ce2e --- /dev/null +++ b/macros/ellipap.bin diff --git a/macros/ellipap.sci b/macros/ellipap.sci new file mode 100644 index 0000000..7b4c1ae --- /dev/null +++ b/macros/ellipap.sci @@ -0,0 +1,46 @@ +function [z, p, g] = ellipap (n, Rp, Rs) +//Designs a lowpass analog elliptic filter. +//Calling Sequence +//[z, p, g] = ellipap (n, Rp, Rs) +//[z, p] = ellipap (n, Rp, Rs) +//z = ellipap (n, Rp, Rs) +//Parameters +//n: Filter Order +//Rp: Peak-to-peak passband ripple +//Rs: Stopband attenuation +//Description +//This is an Octave function. +//It designs a lowpass analog elliptic filter of nth order, with a Peak-to-peak passband ripple of Rp and a stopband attenuation of Rs. +//Examples +//[z, p, g] = ellipap (5, 10, 10) +//z = +// +// 0.0000 + 2.5546i 0.0000 + 1.6835i -0.0000 - 2.5546i -0.0000 - 1.6835i +// +//p = +// +// -0.05243 + 0.63524i -0.01633 + 0.96289i -0.05243 - 0.63524i -0.01633 - 0.96289i -0.07369 + 0.00000i +// +//g = 0.0015012 + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 3 | rhs > 3) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 3 then + if(lhs==1) + z = callOctave("ellipap", n, Rp, Rs) + elseif(lhs==2) + [z, p] = callOctave("ellipap", n, Rp, Rs) + elseif(lhs==3) + [z, p, g] = callOctave("ellipap", n, Rp, Rs) + else + error("Wrong number of output argments.") + end + end +endfunction diff --git a/macros/fft.bin b/macros/fft.bin Binary files differnew file mode 100644 index 0000000..088707e --- /dev/null +++ b/macros/fft.bin diff --git a/macros/fft.sci b/macros/fft.sci new file mode 100644 index 0000000..0ea54ab --- /dev/null +++ b/macros/fft.sci @@ -0,0 +1,49 @@ +function res = fft (x, n, dim) +//Calculates the discrete Fourier transform of a matrix using Fast Fourier Transform algorithm. +//Calling Sequence +//fft (x, n, dim) +//fft (x, n) +//fft (x) +//Parameters +//x: input matrix +//n: Specifies the number of elements of x to be used +//dim: Specifies the dimention of the matrix along which the FFT is performed +//Description +//This is an Octave function. +//The FFT is calculated along the first non-singleton dimension of the array. Thus, FFT is computed for each column of x. +// +//n is an integer specifying the number of elements of x to use. If n is larger than dimention along. which the FFT is calculated, then x is resized and padded with zeros. +//Similarly, if n is smaller, then x is truncated. +// +//dim is an integer specifying the dimension of the matrix along which the FFT is performed. +//Examples +//x = [1 2 3; 4 5 6; 7 8 9] +//n = 3 +//dim = 2 +//fft (x, n, dim) +//ans = +// +// 6.0000 + 0.0000i -1.5000 + 0.8660i -1.5000 - 0.8660i +// 15.0000 + 0.0000i -1.5000 + 0.8660i -1.5000 - 0.8660i +// 24.0000 + 0.0000i -1.5000 + 0.8660i -1.5000 - 0.8660i + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 1 | rhs > 3) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 1 then + res = callOctave("fft", x) + + case 2 then + res = callOctave("fft", x, n) + + case 3 then + res = callOctave("fft", x, n, dim) + + end +endfunction diff --git a/macros/fft2.bin b/macros/fft2.bin Binary files differnew file mode 100644 index 0000000..dd6e2cc --- /dev/null +++ b/macros/fft2.bin diff --git a/macros/fft2.sci b/macros/fft2.sci new file mode 100644 index 0000000..58cd70d --- /dev/null +++ b/macros/fft2.sci @@ -0,0 +1,45 @@ +function res = fft2 (A, m, n) +//Calculates the two-dimensional discrete Fourier transform of A using a Fast Fourier Transform algorithm. +//Calling Sequence +//fft2 (A, m, n) +//fft2 (A) +//Parameters +//A: input matrix +//m: number of rows of A to be used +//n: number of columns of A to be used +//Description +//This is an Octave function. +//It performs two-dimentional FFT on the matrix A. m and n may be used specify the number of rows and columns of A to use. If either of these is larger than the size of A, A is resized and padded with zeros. +//If A is a multi-dimensional matrix, each two-dimensional sub-matrix of A is treated separately. +//Examples +//x = [1 2 3; 4 5 6; 7 8 9] +//m = 4 +//n = 4 +//fft2 (A, m, n) +//ans = +// +// 45 + 0i -6 - 15i 15 + 0i -6 + 15i +// -18 - 15i -5 + 8i -6 - 5i 5 - 4i +// 15 + 0i -2 - 5i 5 + 0i -2 + 5i +// -18 + 15i 5 + 4i -6 + 5i -5 - 8i + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 1 | rhs > 3) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 1 then + res = callOctave("fft2", A) + + case 2 then + error("Wrong number of input arguments.") + + case 3 then + res = callOctave("fft2", A, m, n) + + end +endfunction diff --git a/macros/freqs.bin b/macros/freqs.bin Binary files differnew file mode 100644 index 0000000..066c156 --- /dev/null +++ b/macros/freqs.bin diff --git a/macros/freqs.sci b/macros/freqs.sci new file mode 100644 index 0000000..88773fe --- /dev/null +++ b/macros/freqs.sci @@ -0,0 +1,29 @@ +function h = freqs (b, a, w) +//Compute the s-plane frequency response of the IIR filter. +//Calling Sequence +//h = freqs (b, a, w) +//Parameters +//b: vector containing the coefficients of the numerator of the filter. +//a: vector containing the coefficients of the denominator of the filter. +//w: vector containing frequencies +//Description +//This is an Octave function. +//It computes the s-plane frequency response of the IIR filter B(s)/A(s) as H = polyval(B,j*W)./polyval(A,j*W). +//If called with no output argument, a plot of magnitude and phase are displayed. +//Examples +//B = [1 2]; +//A = [1 1]; +//w = linspace(0,4,128); +//freqs(B,A,w); + +funcprot(0); +rhs = argn(2) +if(rhs<3 | rhs>3) +error("Wrong number of input arguments.") +end + +select (rhs) + case 3 then + y = callOctave("freqs",b, a, w) + end +endfunction diff --git a/macros/ifft.bin b/macros/ifft.bin Binary files differnew file mode 100644 index 0000000..1c95870 --- /dev/null +++ b/macros/ifft.bin diff --git a/macros/ifft.sci b/macros/ifft.sci new file mode 100644 index 0000000..70688e4 --- /dev/null +++ b/macros/ifft.sci @@ -0,0 +1,51 @@ +function res = ifft (x, n, dim) +//Calculates the inverse discrete Fourier transform of a matrix using Fast Fourier Transform algorithm. +//Calling Sequence +//ifft (x, n, dim) +//ifft (x, n) +//ifft (x) +//Parameters +//x: input matrix +//n: Specifies the number of elements of x to be used +//dim: Specifies the dimention of the matrix along which the inverse FFT is performed +//Description +//This is an Octave function. +//Description +//This is an Octave function. +//The inverse FFT is calculated along the first non-singleton dimension of the array. Thus, inverse FFT is computed for each column of x. +// +//n is an integer specifying the number of elements of x to use. If n is larger than dimention along. which the inverse FFT is calculated, then x is resized and padded with zeros. +//Similarly, if n is smaller, then x is truncated. +// +//dim is an integer specifying the dimension of the matrix along which the inverse FFT is performed. +//Examples +//x = [1 2 3; 4 5 6; 7 8 9] +//n = 3 +//dim = 2 +//ifft (x, n, dim) +//ans = +// +// 2.00000 + 0.00000i -0.50000 - 0.28868i -0.50000 + 0.28868i +// 5.00000 + 0.00000i -0.50000 - 0.28868i -0.50000 + 0.28868i +// 8.00000 + 0.00000i -0.50000 - 0.28868i -0.50000 + 0.28868i + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 1 | rhs > 3) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 1 then + res = callOctave("ifft", x) + + case 2 then + res = callOctave("ifft", x, n) + + case 3 then + res = callOctave("ifft", x, n, dim) + + end +endfunction diff --git a/macros/ifft2.bin b/macros/ifft2.bin Binary files differnew file mode 100644 index 0000000..bcd3a09 --- /dev/null +++ b/macros/ifft2.bin diff --git a/macros/ifft2.sci b/macros/ifft2.sci new file mode 100644 index 0000000..8ecb1a5 --- /dev/null +++ b/macros/ifft2.sci @@ -0,0 +1,45 @@ +function res = ifft2 (A, m, n) +//Calculates the inverse two-dimensional discrete Fourier transform of A using a Fast Fourier Transform algorithm. +//Calling Sequence +//ifft2 (A, m, n) +//ifft2 (A) +//Parameters +//A: input matrix +//m: number of rows of A to be used +//n: number of columns of A to be used +//Description +//This is an Octave function. +//It performs inverse two-dimensional FFT on the matrix A. m and n may be used specify the number of rows and columns of A to use. If either of these is larger than the size of A, A is resized and padded with zeros. +//If A is a multi-dimensional matrix, each two-dimensional sub-matrix of A is treated separately. +//Examples +//x = [1 2 3; 4 5 6; 7 8 9] +//m = 4 +//n = 4 +//ifft2 (A, m, n) +//ans = +// +// 2.81250 + 0.00000i -0.37500 + 0.93750i 0.93750 + 0.00000i -0.37500 - 0.93750i +// -1.12500 + 0.93750i -0.31250 - 0.50000i -0.37500 + 0.31250i 0.31250 + 0.25000i +// 0.93750 + 0.00000i -0.12500 + 0.31250i 0.31250 + 0.00000i -0.12500 - 0.31250i +// -1.12500 - 0.93750i 0.31250 - 0.25000i -0.37500 - 0.31250i -0.31250 + 0.50000i + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 1 | rhs > 3) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 1 then + res = callOctave("ifft2", A) + + case 2 then + error("Wrong number of input arguments.") + + case 3 then + res = callOctave("ifft2", A, m, n) + + end +endfunction Binary files differdiff --git a/macros/names b/macros/names index 79a4781..b2ce8bd 100644 --- a/macros/names +++ b/macros/names @@ -7,6 +7,7 @@ armcov aryule barthannwin bartlett +besselap besself bitrevorder blackman @@ -15,12 +16,16 @@ blackmannuttall bohmanwin boxcar buffer +buttap butter buttord cceps cconv cell2sos +cheb +cheb1ap cheb1ord +cheb2ap cheb2ord chebwin cheby1 @@ -31,6 +36,7 @@ clustersegment cmorwavf convmtx corrmtx +cplxreal cummax cummin czt @@ -44,10 +50,13 @@ downsample dst1 dutycycle ellip +ellipap ellipord enbw eqtflength falltime +fft +fft2 fftfilt fht filternorm @@ -58,6 +67,7 @@ firpmord firtype flattopwin fracshift +freqs fwhm fwhmjlt fwht @@ -73,11 +83,16 @@ helperHarmonicDistortionAmplifier hilbert1 hurst icceps +<<<<<<< HEAD +ifft +ifft2 +======= idct1 idct2 idst1 ifht ifwht +>>>>>>> 9f6962b19c4a5fa76f7525a72faabb1b754712ad iirlp2mb impinvar impz @@ -113,6 +128,7 @@ modulate morlet movingrms musicBase +ncauer nnls nuttallwin parzenwin @@ -120,6 +136,7 @@ pchip pchips peak2peak peak2rms +pei_tseng_notch peig periodogram phaseInputParseAs_ab @@ -206,6 +223,7 @@ upsample upsamplefill var vco +wconv welchwin window wkeep @@ -215,4 +233,6 @@ xcov1 yulewalker zerocrossing zp2sos +zp2ss +zp2tf zplane diff --git a/macros/ncauer.bin b/macros/ncauer.bin Binary files differnew file mode 100644 index 0000000..0886fbd --- /dev/null +++ b/macros/ncauer.bin diff --git a/macros/ncauer.sci b/macros/ncauer.sci new file mode 100644 index 0000000..c76eb65 --- /dev/null +++ b/macros/ncauer.sci @@ -0,0 +1,49 @@ +function [Zz, Zp, Zg] = ncauer(Rp, Rs, n) +//Analog prototype for Cauer filter. +//Calling Sequence +//[Zz, Zp, Zg] = ncauer(Rp, Rs, n) +//[Zz, Zp] = ncauer(Rp, Rs, n) +//Zz = ncauer(Rp, Rs, n) +//Parameters +//n: Filter Order +//Rp: Peak-to-peak passband ripple +//Rs: Stopband attenuation +//Description +//This is an Octave function. +//It designs an analog prototype for Cauer filter of nth order, with a Peak-to-peak passband ripple of Rp and a stopband attenuation of Rs. +//Examples +//n = 5; +//Rp = 5; +//Rs = 5; +//[Zz, Zp, Zg] = ncauer(Rp, Rs, n) +//Zz = +// +// 0.0000 + 2.5546i 0.0000 + 1.6835i -0.0000 - 2.5546i -0.0000 - 1.6835i +// +//Zp = +// +// -0.10199 + 0.64039i -0.03168 + 0.96777i -0.10199 - 0.64039i -0.03168 - 0.96777i -0.14368 + 0.00000i +// +//Zg = 0.0030628 + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 3 | rhs > 3) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 3 then + if(lhs==1) + Zz = callOctave("ncauer", Rp, Rs, n) + elseif(lhs==2) + [Zz, Zp] = callOctave("ncauer", Rp, Rs, n) + elseif(lhs==3) + [Zz, Zp, Zg] = callOctave("ncauer", Rp, Rs, n) + else + error("Wrong number of output argments.") + end + end +endfunction diff --git a/macros/peak2rms.bin b/macros/peak2rms.bin Binary files differindex 12d6e85..8f6cf06 100644 --- a/macros/peak2rms.bin +++ b/macros/peak2rms.bin diff --git a/macros/pei_tseng_notch.bin b/macros/pei_tseng_notch.bin Binary files differnew file mode 100644 index 0000000..40cd414 --- /dev/null +++ b/macros/pei_tseng_notch.bin diff --git a/macros/pei_tseng_notch.sci b/macros/pei_tseng_notch.sci new file mode 100644 index 0000000..1de0fcd --- /dev/null +++ b/macros/pei_tseng_notch.sci @@ -0,0 +1,44 @@ +function [b, a] = pei_tseng_notch (frequencies, bandwidths) + +//Return coefficients for an IIR notch-filter. +//Calling Sequence +//[b, a] = pei_tseng_notch (frequencies, bandwidths) +//b = pei_tseng_notch (frequencies, bandwidths) +//Parameters +//frequencies: filter frequencies +//bandwidths: bandwidths to be used with filter +//Description +//This is an Octave function. +//It return coefficients for an IIR notch-filter with one or more filter frequencies and according bandwidths. The filter is based on a all pass filter that performs phasereversal at filter frequencies. +//This leads to removal of those frequencies of the original and phase-distorted signal. +//Examples +//sf = 800; sf2 = sf/2; +//data=[[1;zeros(sf-1,1)],sinetone(49,sf,1,1),sinetone(50,sf,1,1),sinetone(51,sf,1,1)]; +//[b,a]=pei_tseng_notch ( 50 / sf2, 2/sf2 ) +//b = +// +// 0.99213 -1.83322 0.99213 +// +//a = +// +// 1.00000 -1.83322 0.98426 + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 2 | rhs > 2) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 2 then + if(lhs==1) + b = callOctave("pei_tseng_notch", frequencies, bandwidths) + elseif(lhs==2) + [b, a] = callOctave("pei_tseng_notch", frequencies, bandwidths) + else + error("Wrong number of output argments.") + end + end +endfunction diff --git a/macros/wconv.bin b/macros/wconv.bin Binary files differnew file mode 100644 index 0000000..f174e54 --- /dev/null +++ b/macros/wconv.bin diff --git a/macros/wconv.sci b/macros/wconv.sci new file mode 100644 index 0000000..a0682a6 --- /dev/null +++ b/macros/wconv.sci @@ -0,0 +1,33 @@ +function y = wconv (type, x, f, shape) +//Performs 1D or 2D convolution. +//Calling Sequence +//y = wconv (type, x, f) +// y = wconv (type, x, f, shape) +//Parameters +//type: convolution type. +//x: Signal vector or matrix. +//f: FIR filter coefficients. +//shape: Shape. +//Description +//This is an Octave function. +//It performs 1D or 2D convolution between the signal x and the filter coefficients f. +//Examples +//a = [1 2 3 4 5] +//b = [7 8 9 10] +//wconv(1,a,b) +//ans = +// 7 22 46 80 114 106 85 50 + +funcprot(0); +rhs = argn(2) +if(rhs<3 | rhs>4) +error("Wrong number of input arguments.") +end + +select (rhs) + case 3 then + y = callOctave("wconv",type, x, f) + case 4 then + y = callOctave("wconv",type, x, f, shape) + end +endfunction diff --git a/macros/zp2ss.bin b/macros/zp2ss.bin Binary files differnew file mode 100644 index 0000000..b8ab377 --- /dev/null +++ b/macros/zp2ss.bin diff --git a/macros/zp2ss.sci b/macros/zp2ss.sci new file mode 100644 index 0000000..ab14bfd --- /dev/null +++ b/macros/zp2ss.sci @@ -0,0 +1,65 @@ +function [a, b, c, d] = zp2ss (z, p, k) +//Converts zeros / poles to state space. +//Calling Sequence +//[a, b, c, d] = zp2ss (z, p, k) +//[a, b, c] = zp2ss (z, p, k) +//[a, b] = zp2ss (z, p, k) +//a = zp2ss (z, p, k) +//Parameters +//z: Zeros +//p: Poles +//k: Leading coefficient +//a: State space parameter +//a: State space parameter +//b: State space parameter +//c: State space parameter +//d: State space parameter +//Description +//This is an Octave function. +//It converts zeros / poles to state space. +//Examples +//z = [1 2 3] +// p = [4 5 6] +//k = 5 +//[a, b, c, d] = zp2ss (z, p, k) +//a = +// +// -0.00000 0.00000 -1.20000 +// -10.00000 0.00000 -7.40000 +// 0.00000 10.00000 15.00000 +// +//b = +// +// -5.7000 +// -31.5000 +// 45.0000 +// +//c = +// +// 0.00000 0.00000 1.00000 +// +//d = 5 + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 3 | rhs > 3) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 3 then + if(lhs==1) + a = callOctave("zp2ss", z, p, k) + elseif(lhs==2) + [a, b] = callOctave("zp2ss", z, p, k) + elseif(lhs==3) + [a, b, c] = callOctave("zp2ss", z, p, k) + elseif(lhs==4) + [a, b, c, d] = callOctave("zp2ss", z, p, k) + else + error("Wrong number of output argments.") + end + end +endfunction diff --git a/macros/zp2tf.bin b/macros/zp2tf.bin Binary files differnew file mode 100644 index 0000000..2597b7d --- /dev/null +++ b/macros/zp2tf.bin diff --git a/macros/zp2tf.sci b/macros/zp2tf.sci new file mode 100644 index 0000000..c830e3d --- /dev/null +++ b/macros/zp2tf.sci @@ -0,0 +1,46 @@ +function [num, den] = zp2tf (z, p, k) +//Converts zeros / poles to a transfer function. +//Calling Sequence +//[num, den] = zp2tf (z, p, k) +//num = zp2tf (z, p, k) +//Parameters +//z: Zeros +//p: Poles +//k: Leading coefficient +//Num: Numerator of the transfer function +//den: Denomenator of the transfer function +//Description +//This is an Octave function. +//It converts zeros / poles to a transfer function. +//Examples +//z = [1 2 3] +// p = [4 5 6] +//k = 5 +//[num, den] = zp2tf (z, p, k) +//num = +// +// 5 -30 55 -30 +// +//den = +// +// 1 -15 74 -120 + +funcprot(0); +lhs = argn(1) +rhs = argn(2) +if (rhs < 3 | rhs > 3) +error("Wrong number of input arguments.") +end + +select(rhs) + + case 3 then + if(lhs==1) + num = callOctave("zp2tf", z, p, k) + elseif(lhs==2) + [num, den] = callOctave("zp2tf", z, p, k) + else + error("Wrong number of output argments.") + end + end +endfunction |