function F=root3d(x,p,w)
  [s1,s2] = size(w);
  [p1,p2] = size(p);

  for i = 1:p1
     ss = 0;
     for j = 1:s2
         for k = 2:s1
             if k-1 ~= j
                 ss = ss + w(k,j)*tanh_opt(x(i,k));
             end
         end

         F(i*j) = x(i,j)-ss-p(i,j);
     end
  end
end