-
Notifications
You must be signed in to change notification settings - Fork 78
/
armorf.m
105 lines (97 loc) · 2.96 KB
/
armorf.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
function varargout = armorf(x,Nr,Nl,p)
%ARMORF AR parameter estimation via LWR method by Morf modified.
% x is a matrix whose every row is one variable's time series
% Nr is the number of realizations, Nl is the length of every realization
% If the time series are stationary long, just let Nr=1, Nl=length(x)
% p is the order of AR model
%
% A = ARMORF(X,NR,NL,P) returns the polynomial coefficients A corresponding to
% the AR model estimate of matrix X using Morf's method.
%
% [A,E] = ARMORF(...) returns the final prediction error E (the
% covariance matrix of the white noise of the AR model).
%
% [A,E,K] = ARMORF(...) returns the vector K of reflection
% coefficients (parcor coefficients).
%
% Ref: M. Morf, etal, Recursive Multichannel Maximum Entropy Spectral Estimation,
% IEEE trans. GeoSci. Elec., 1978, Vol.GE-16, No.2, pp85-94.
% S. Haykin, Nonlinear Methods of Spectral Analysis, 2nd Ed.
% Springer-Verlag, 1983, Chapter 2
%
% finished on Aug.9, 2002 by Yonghong Chen
% Initialization
[L,N]=size(x);
R0=zeros(L,L);
R0f=R0;
R0b=R0;
pf=R0;
pb=R0;
pfb=R0;
ap(:,:,1)=R0;
bp(:,:,1)=R0;
En=R0;
for i=1:Nr
En=En+x(:,(i-1)*Nl+1:i*Nl)*x(:,(i-1)*Nl+1:i*Nl)';
ap(:,:,1)=ap(:,:,1)+x(:,(i-1)*Nl+2:i*Nl)*x(:,(i-1)*Nl+2:i*Nl)';
bp(:,:,1)=bp(:,:,1)+x(:,(i-1)*Nl+1:i*Nl-1)*x(:,(i-1)*Nl+1:i*Nl-1)';
end
ap(:,:,1) = inv((chol(ap(:,:,1)/Nr*(Nl-1)))');
bp(:,:,1) = inv((chol(bp(:,:,1)/Nr*(Nl-1)))');
for i=1:Nr
efp = ap(:,:,1)*x(:,(i-1)*Nl+2:i*Nl);
ebp = bp(:,:,1)*x(:,(i-1)*Nl+1:i*Nl-1);
pf = pf + efp*efp';
pb = pb + ebp*ebp';
pfb = pfb + efp*ebp';
end
En = chol(En/N)'; % Covariance of the noise
% Initial output variables
coeff = [];% Coefficient matrices of the AR model
kr=[]; % reflection coefficients
for m=1:p
% Calculate the next order reflection (parcor) coefficient
ck = inv((chol(pf))')*pfb*inv(chol(pb));
kr=[kr,ck];
% Update the forward and backward prediction errors
ef = eye(L)- ck*ck';
eb = eye(L)- ck'*ck;
% Update the prediction error
En = En*chol(ef)';
E = (ef+eb)./2;
% Update the coefficients of the forward and backward prediction errors
ap(:,:,m+1) = zeros(L);
bp(:,:,m+1) = zeros(L);
pf = zeros(L);
pb = zeros(L);
pfb = zeros(L);
for i=1:m+1
a(:,:,i) = inv((chol(ef))')*(ap(:,:,i)-ck*bp(:,:,m+2-i));
b(:,:,i) = inv((chol(eb))')*(bp(:,:,i)-ck'*ap(:,:,m+2-i));
end
for k=1:Nr
efp = zeros(L,Nl-m-1);
ebp = zeros(L,Nl-m-1);
for i=1:m+1
k1=m+2-i+(k-1)*Nl+1;
k2=Nl-i+1+(k-1)*Nl;
efp = efp+a(:,:,i)*x(:,k1:k2);
ebp = ebp+b(:,:,m+2-i)*x(:,k1-1:k2-1);
end
pf = pf + efp*efp';
pb = pb + ebp*ebp';
pfb = pfb + efp*ebp';
end
ap = a;
bp = b;
end
for j=1:p
coeff = [coeff,inv(a(:,:,1))*a(:,:,j+1)];
end
varargout{1} = -coeff;
if nargout >= 2
varargout{2} = En*En';
end
if nargout >= 3
varargout{3} = kr;
end