function index = RouletteWheelSelection(N,Fitness)
%RouletteWheelSelection - Roulette-wheel selection.
%
%   P = RouletteWheelSelection(N,fitness) returns the indices of N
%   solutions by roulette-wheel selection based on fitness. A smaller
%   fitness value indicates a larger probability to be selected.
%
%   Example:
%       P = RouletteWheelSelection(100,FrontNo)

%------------------------------- Copyright --------------------------------
% Copyright (c) 2022 BIMK Group. You are free to use the PlatEMO for
% research purposes. All publications which use this platform or any code
% in the platform should acknowledge the use of "PlatEMO" and reference "Ye
% Tian, Ran Cheng, Xingyi Zhang, and Yaochu Jin, PlatEMO: A MATLAB platform
% for evolutionary multi-objective optimization [educational forum], IEEE
% Computational Intelligence Magazine, 2017, 12(4): 73-87".
%--------------------------------------------------------------------------

    Fitness = reshape(Fitness,1,[]);
    Fitness = Fitness - min(min(Fitness),0) + 1e-6;
    Fitness = cumsum(1./Fitness);
    Fitness = Fitness./max(Fitness);
    index   = arrayfun(@(S)find(rand<=Fitness,1),1:N);
end