function q = calculateq(sd,param)
sigmaw = param.sigmaw;
sigmav = param.sigmav;
sigmau = param.sigmau;
[T,L] = size(sd);
q = zeros(T,L);
q(T,L) = (sigmav^2)*sd(T,L);
for t = (T-1):-1:1
    q(t,L) = (sigmaw(L)^2)*q(t+1,L)*sd(t,L);
end
if L > 1
   for l = (L-1):-1:1
      q(T,l) = (sigmau(l+1)^2)*q(T,l+1)*sd(T,l);
   end
   for l = (L-1):-1:1
       for t = (T-1):-1:1
           q(t,l) = sd(t,l)*( (sigmaw(l)^2)*q(t+1,l) + (sigmau(l+1)^2)*q(t,l+1) );
       end
   end    
end
end

