function [Zt_next] = update_Z(Xt,Bt,Zt,Ht)

A=Xt*Bt'+Zt*Ht;
[Up,Sp,Vp] = svd(A,'econ');
Zt_next = Up*Vp';
end

