view m-toolbox/classes/@pz/cp2iir.m @ 50:7d2e2e065cf1 database-connection-manager

Update unit tests
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Wed, 07 Dec 2011 17:24:37 +0100
parents f0afece42f48
children
line wrap: on
line source

% CP2IIR Return a,b IIR filter coefficients for a complex pole designed using the bilinear transform.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% DESCRIPTION: CP2IIR Return a,b IIR filter coefficients for a complex pole
%              designed using the bilinear transform.
%
% CALL:        [a,b] = cp2iir(p, fs)
%
% REMARK:      This is just a helper function. This function should only be
%              called from class functions.
%
% INPUT:       p  - pole object
%              fs - the sample rate for the filter
%
% VERSION:     $Id: cp2iir.m,v 1.7 2011/02/18 16:48:54 ingo Exp $
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

function varargout = cp2iir(varargin)

  p  = varargin{1};
  fs = varargin{2};

  f0 = p.f;
  q  = p.q;

  w0  = f0*2*pi;
  w02 = w0^2;

  k    = (q*w02 + 4*q*fs*fs + 2*w0*fs) / (q*w02);
  b(1) =  1;
  b(2) = (2*w02-8*fs*fs) / (k*w02);
  b(3) = (q*w02 + 4*q*fs*fs - 2*w0*fs) / (k*q*w02);

  a(1) =  1/k;
  a(2) = -2/k;
  a(3) = -1/k;
  a    =  a*-2;

  varargout{1} = a;
  varargout{2} = b;
end