Vectorization time-varying recursive linear function
4 ビュー (過去 30 日間)
古いコメントを表示
I try to vectorize this simple recursive relation (all quantities are scalars)
x_{0} = 0;
x_{n} = x_{n-1}*a_{n} + b_{n} for n=1,2,...,N
In MATLAB code it can be carried out by for loop
% test inputs
b=rand(1,10);
a=0.9+zeros(size(b));
xk=0;
x=zeros(size(b));
for k=1:length(x)
xk = a(k)*xk+b(k);
x(k) = xk;
end
For a(:) constant this can be vectorized by IIR filter
ac = unique(a);
if length(ac)==1
x = filter(1, [1 -ac], b);
end
I would though it could have some time-varying IIR filter that I can use to vectorize the case where a is time-dependent.
But I couldn't find anywhere such stock function. anyone have an idea?
0 件のコメント
採用された回答
David Goodmanson
2020 年 8 月 28 日
編集済み: David Goodmanson
2020 年 8 月 28 日
Hi Bruno,
a = rand(1,50);
b = rand(1,50);
% method 1
xk = 0;
x = zeros(1,50);
for k = 1:50
xk = a(k)*xk + b(k);
x(k) = xk;
end
% method 2
cpa = cumprod([1 a(2:end)])
x1 = filter(1,[1 -1],b./cpa).*cpa;
max(abs(x1-x))
ans = 4.4409e-16
2 件のコメント
David Goodmanson
2020 年 8 月 29 日
Hi Bruno,
Also, if one of the a's is nonzero but very small, there are probably going to be numerical accuracy issues. It's unfortunate that Matlab apparently does not have a built-in function for this type of iteration.
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Filter Design についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!