function poly = best_result_poly(x,y,id)
kfold = max(id);
d_iter = 1:5;
r_iter = [0,0.1,0.2,0.5,1,2];
acc_best = 0;
for i = 1:length(d_iter)
    for j = 1:length(r_iter)
    d = d_iter(i);
    r = r_iter(j);
    kernel_train = cell(kfold,1);
     kernel_test = cell(kfold,1);
     y_train = cell(kfold,1);
     y_test = cell(kfold,1);
     for q = 1:kfold
         id_train = find(id ~= q);
         id_test = find(id == q);
         kernel_train{q} = gramPOLY(x(id_train,:),x(id_train,:),d,r);
         kernel_test{q} = gramPOLY(x(id_test,:),x(id_train,:),d,r);
         y_train{q} = y(id_train);
         y_test{q} = y(id_test);
      end
     [acc_current,svmparam] = give_me_best_acc_svm(kernel_train,kernel_test,y_train,y_test);
     if acc_current > acc_best
        acc_best = acc_current
        best_d =d;
        best_r = r;
        svmparam_best = svmparam;
      end
end
poly = struct();
poly.acc_kfold = acc_best;
poly.svmparam = svmparam_best;
poly.d = best_d;
poly.r = best_r;
end