function [results] = CompMultiNoParallel(methods, Datas, parameters, results)

% Compute Multilevel SVM classifier and validation with leave one out
% No Parallel Version



for l = 0 : parameters.multilevel.l

   
    tic;
    t0 = toc;
    % correct_t = 0;
    % correct_n = 0;
    % wrong_t = 0;
    % wrong_n = 0;
     
   for j = 0:parameters.data.Kfold:parameters.data.n 
        jfold = j + leaveout; jfold(jfold > parameters.data.n) = [];
        if isempty(jfold), continue, end
        
        tic;
        t1 = toc;
        % Copy variables for each processor
        Datas2 = Datas;
        parameters2 = parameters;
        
   
        for i = 0:parameters.data.Kfold:parameters.data.t
             ifold = i + leaveout; ifold(ifold > parameters.data.t) = [];
             if isempty(ifold), continue, end
            
           
            parameters2.data.i = ifold;
            parameters2.data.j = jfold;

           % Split data into two groups: training and testing 
            [Datas2] = methods.all.prepdata(Datas, parameters2);

            %Transformation Map Goes here:
            Datas2 = methods.transform.tree(Datas2, parameters, methods);
    
            % Generating Coeff for every gene series (col)
            [parameters2] = methods.Multi.Getcoeff(Datas2, parameters2);

           
            % Nested
            if parameters.multilevel.nested == 1
                Datas2 = methods.Multi.nesteddatasvm(Datas2, parameters2, methods, l);   % for level 0-l nested
            else
                Datas2 = methods.Multi.datasvm(Datas2, parameters2, methods, l);   % for level l
            end
            
           
            
            % Fit SVM
            if parameters2.svm.kernal == 1
                [parameters2.multilevel.SVMModel] = methods.all.SVMmodel(Datas2.X_Train, Datas2.y_Train, ...
                                                    'KernelFunction', 'RBF', 'KernelScale', 'auto');
            else
                [parameters2.multilevel.SVMModel] = methods.all.SVMmodel(Datas2.X_Train, Datas2.y_Train);%,...
            end
  

            % Prediction
            y_Test_tumor = methods.all.SVMpredict(parameters2.multilevel.SVMModel, Datas2.X_Test_tumor);
            y_Test_normal = methods.all.SVMpredict(parameters2.multilevel.SVMModel, Datas2.X_Test_normal);

            if y_Test_normal == 0
                correct_n = correct_n + 1;
            elseif y_Test_normal == 1
                wrong_n = wrong_n + 1;
            end

            if y_Test_tumor == 1
                correct_t = correct_t + 1;
            elseif y_Test_tumor == 0
                wrong_t = wrong_t + 1;
            end


            t2 = toc; 
            fprintf('Test %d， Time = %.2f \n', i, t2 - t1);
            
         
        end
      
        
        
        
   end

   [correct_n, correct_t, wrong_n, wrong_t] =...
    CompMultiPredict(Datas, parameters, correct_n, correct_t, wrong_n, wrong_t);
    results.multilevel.accuracy(parameters.data.currentiter, l+1) = (correct_t + correct_n)/(correct_t + wrong_n + correct_n + wrong_t);
    results.multilevel.precision(parameters.data.currentiter, l+1) = correct_t/(correct_t + wrong_n);
 
    t3 = toc;
    fprintf('Level %d， Time = %.2f \n', l, t3 - t0);
    fprintf('------------------------------------- \n');
    
end
    

end