function q = gramcalculateq(sd,param)
sigmaw = param.sigmaw;
sigmav = param.sigmav;
sigmau = param.sigmau;
[n1,n2,T,L] = size(sd);
q = zeros(n1,n2,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

