Этот пример показывает, как задать Системные объекты, которые включают другие Системные объекты. Задайте Систему полосового фильтра object™ от отдельного highpass, и lowpass фильтруют Системные объекты.
Полный файл определения класса системного объекта составного объекта полосового фильтра
Файл определения класса для КИХ-компонента Lowpass полосового фильтра
Файл определения класса для КИХ-компонента Highpass полосового фильтра
Чтобы задать Системный объект от других Системных объектов, храните те другие объекты в своем файле определения класса как свойства. В этом примере highpass и фильтрами lowpass являются отдельные Системные объекты, заданные в их собственных файлах определения класса.
properties (Access = private) % Properties that hold filter System objects pLowpass pHighpass end
classdef BandpassFIRFilter < matlab.System % Implements a bandpass filter using a cascade of eighth-order lowpass % and eighth-order highpass FIR filters. properties (Access = private) % Properties that hold filter System objects pLowpass pHighpass end methods (Access = protected) function setupImpl(obj) % Setup composite object from constituent objects obj.pLowpass = LowpassFIRFilter; obj.pHighpass = HighpassFIRFilter; end function yHigh = stepImpl(obj,u) yLow = obj.pLowpass(u); yHigh = obj.pHighpass(yLow); end function resetImpl(obj) reset(obj.pLowpass); reset(obj.pHighpass); end end end
classdef LowpassFIRFilter < matlab.System % Implements eighth-order lowpass FIR filter with 0.6pi cutoff properties (Nontunable) % Filter coefficients Numerator = [0.006,-0.0133,-0.05,0.26,0.6,0.26,-0.05,-0.0133,0.006]; end properties (DiscreteState) State end methods (Access = protected) function setupImpl(obj) obj.State = zeros(length(obj.Numerator)-1,1); end function y = stepImpl(obj,u) [y,obj.State] = filter(obj.Numerator,1,u,obj.State); end function resetImpl(obj) obj.State = zeros(length(obj.Numerator)-1,1); end end end
classdef HighpassFIRFilter < matlab.System % Implements eighth-order highpass FIR filter with 0.4pi cutoff properties (Nontunable) % Filter coefficients Numerator = [0.006,0.0133,-0.05,-0.26,0.6,-0.26,-0.05,0.0133,0.006]; end properties (DiscreteState) State end methods (Access = protected) function setupImpl(obj) obj.State = zeros(length(obj.Numerator)-1,1); end function y = stepImpl(obj,u) [y,obj.State] = filter(obj.Numerator,1,u,obj.State); end function resetImpl(obj) obj.State = zeros(length(obj.Numerator)-1,1); end end end