function [y,sf,sd,q,sx1,sx2] = newRNTK(x1,x2,param)
[x1,x2] = order_the_inputs(x1,x2);
[~,T1] = size(x1);
[~,T2] = size(x2);
L = length(param.sigmaw);
s = zeros(T1,L);
sd = zeros(T1,L);
sx1 = zeros(T1,L);
sx2 = zeros(T2,L);
[s(:,1),sd(:,1),sf,sx1(:,1),sx2(:,1)] = newGP_kernel_signle_layer(x1,x2,param);
if L > 1
    for l = 2:L
       [s(:,l),sd(:,l),sf,sx1(:,l),sx2(:,l)] = newGP_kernel_multi_layer(s(:,l-1),sx1(:,l-1),sx2(:,l-1),param,l); 
    end
end
q = calculateq(sd,param);
y = sum(sum(s.*q));
y = y + sf;
end


