How can I use a filter in a parfor with the more numerically stable z,p,k?

3 views (last 30 days)
Hello,
I would like to use a filter in a parfor loop. Using [b,a] coefficients there is no problem. Because of a better stability I have to use the [z,p,k] coefficients. It perfectly works in a for loop. However, in a parfor loop the error massage "Not enough input arguments." appears. Does anyone know a workaround?
Here is a little example: Anything works but the last loop!
% Signal
x = sin(0:pi/1000:10*pi);
% Filter properties
N = 1;
fc = 1/(2*pi);
fs = 1000/pi;
Wn = fc/(fs/2);
ftype = 'low';
% Transfer Function design
[b,a] = butter(N,Wn,ftype);
% Zero-Pole-Gain design
[z,p,k] = butter(N,Wn,ftype);
[sos,g] = zp2sos(z,p,k);
hd = dfilt.df2tsos(sos, g);
%%Loops
for n=1:2
y = filter(b,a,x);
end
parfor n=1:2
y = filter(b,a,x);
end
for n=1:2
y = filter(hd, x);
end
parfor n=1:2
y = filter(hd, x);
end

Accepted Answer

Aniruddha Katre
Aniruddha Katre on 26 Apr 2017
Modifying the parfor loop as follows seems to resolve the error. The filter object was causing the error to occur for some reason, but creating the filter object on each worker separately fixes it.
parfor n=1:2
hd = dfilt.df2tsos(sos, g);
y(n,:) = filter(hd, x);
end
  2 Comments
Edric Ellis
Edric Ellis on 27 Apr 2017
There's an underlying problem sending objects of type dfilt.df2tsos into parfor loops. An additional workaround you can use to avoid re-creating the object on each iteration is:
hdc = parallel.pool.Constant(hd);
parfor ...
... = filter(hdc.Value, ...);
end

Sign in to comment.

More Answers (0)

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!