function llhd = llhd_K_zeta_margin(y,c_zeta,theta,eta,invSig_vec, x, r)

[k, N] = size(eta);
[p, L] = size(theta);


[K_zeta, ~, ~] = GP_SE(c_zeta, x, r, true);

tmp_mat = sparse(diag(repmat(1./invSig_vec,1,N)));
if p < sqrt(N)
    
    for ll=1:L
        theta_ll = theta(:,ll);
        for kk=1:k
            eta_kk = eta(kk,:);
            tmp_mat = tmp_mat + kron((eta_kk*eta_kk').*K_zeta,theta_ll*theta_ll');
        end
    end
    
else
    
    for ll=1:L
        theta_ll = theta(:,ll);
        for kk=1:k
            eta_kk = eta(kk,:);
            eta_mat_kk = diag(eta_kk);
            eta_theta_ll_kk = kron(eta_mat_kk,theta_ll);
            
            tmp_mat = tmp_mat + eta_theta_ll_kk*K_zeta*eta_theta_ll_kk';
        end
    end
    
end


llhd = normpdfln(y(:),zeros(p*N,1),tmp_mat);


end