function [fhat_nxt,fhat_nxt_tau,fbar_nxt,what_curr,ahat_curr,ahatpr_curr,count_curr,nrm_w_curr,nrm_a_curr,nrm_apr_curr,Wt] = DOME_Fusion(t,N,Gph_Bin,eta_alpha,eta_w,what_prev,ahat_prev,ahatpr_prev,fhat_prev,fhat_curr,fbar_curr,ft_curr,ft_nxt,xTg_curr,count_prev,nrm_w_prev,nrm_a_prev,nrm_apr_prev,fhat_curr_tau,ft_nxt_tau,Tp)
% t = current time; N = total number of robots; Gph_Bin = binary adjacency matrix 
% for the comm. network; eta_alpha,eta_w : learning rate parameters; 
% what_prev,ahat_prev,ahatpr_prev : previous time weights; 
% fhat_prev : previous to previous time social 1-step lookahead; 
% fhat_curr,fbar_curr,ft_curr : previous time 1-step social, local, algorithms' lookahead predictions
% ft_nxt : current time social 1-step lookahead predictions 
% xTg_curr : current target position 
% fhat_curr_tau,ft_nxt_tau : previous time tau-step lookahead social, algorithms' predictions

To = Tp; % periodic reset time cycle

delta = 10^-50; % machine's least precision
s = count_prev; 
% normalization counters: nrm_cnt
nrm_w_curr = nrm_w_prev; 
nrm_a_curr = nrm_a_prev;
nrm_apr_curr = nrm_apr_prev;

lssfn = @(x,y) min(sqrt(sum((x-y).^2))./50,1); % bounded convex loss function
if t > 1
    lt = lssfn(ft_curr,xTg_curr);
    lhat_prev = lssfn(fhat_prev,xTg_curr);
    lbar = lssfn(fbar_curr,xTg_curr);  
    
    % learning phase with periodic reset
    if s < To 
        ahat_curr = ahat_prev.*exp(-eta_alpha.*lt);
        ahatpr_curr = ahatpr_prev.*exp(-eta_alpha.*lhat_prev);
        what_curr = what_prev.*exp(-eta_w.*lbar);
        s = s+1;
    else
        ahat_curr = ones(1,N);
        ahatpr_curr = ones(1,N);
        what_curr = ones(1,N);
        s = 0;
    end
    
    % normalization scheme 
    for i = 1:N
        if ahat_curr(i) <= delta
            ahat_curr(i) = ahat_curr(i)/delta;
            nrm_a_curr(i) = nrm_a_prev(i) + 1;
        end
        if ahatpr_curr(i) <= delta
            ahatpr_curr(i) = ahatpr_curr(i)/delta;
            nrm_apr_curr(i) = nrm_apr_prev(i) + 1;
        end
        if what_curr(i) <= delta
            what_curr(i) = what_curr(i)/delta;
            nrm_w_curr(i) = nrm_w_prev(i) + 1;
        end
    end
    
    count_curr = s;
else
    ahat_curr = ahat_prev;
    ahatpr_curr = ahatpr_prev;
    what_curr = what_prev;
    count_curr = s;
end

What_curr = zeros(N,N);
% normalization scheme
for i = 1:N 
    min_nrm_w = min(nrm_w_curr(logical(Gph_Bin(i,:))));
    min_nrm_alp = min(nrm_a_curr(i),nrm_apr_curr(i));
    
    if nrm_a_curr(i) > min_nrm_alp
        ahat_curr(i) = 0;
    end
    if nrm_apr_curr(i) > min_nrm_alp
       ahatpr_curr(i) = 0; 
    end
    
    What_curr(i,:) = what_curr.*Gph_Bin(i,:); % considering the communication network
    nl = 1:N;
    for j = nl(logical(Gph_Bin(i,:)))       
       if nrm_w_curr(j) > min_nrm_w
            What_curr(i,j) = 0;
       end
    end
end

Ahat_curr = ahat_curr./(ahat_curr + ahatpr_curr); % alpha_i weights

fbar_nxt = repmat(Ahat_curr,2,1).*ft_nxt + repmat(1-Ahat_curr,2,1).*fhat_curr; % local 1-step lookahead predictions
fbar_nxt_tau = repmat(Ahat_curr,2,1).*ft_nxt_tau + repmat(1-Ahat_curr,2,1).*fhat_curr_tau; % local tau-step lookahead predictions

Wt = What_curr./repmat(sum(What_curr,2),1,N); % w_ij weights 

fhat_nxt = (Wt*fbar_nxt')'; % social 1-step lookahead predictions
fhat_nxt_tau = (Wt*fbar_nxt_tau')'; % social tau-step lookahead predictions
    
end