The experiment setup agrees with the requirements specified by the used benchmarks.
The number of independent runs was set to 30 for all benchmarks. 
All implementations start from a specified, identical seed. This ensures the repeatability of results (until someone changes the random number generator implementation in the system library). Unfortunately, this does not ensure identical starting points for different implementations, as different programming languages can use various random number generator implementations.
Therefore, here, all algorithms use the same previously generated starting points to reduce the influence of starting points on the results. Of course, when an algorithm uses more points than the other, these additional points constitute additional variability at the start.
As I believe that: “a difference is a difference only if it makes a difference” (Darrell Huff, How to Lie with Statistics), 
the error values are rounded to 5 significant digits, and the FES (objective functions evaluations) are rounded to tenths.
Benchmarks:
    
      - BBOB - the blackbox optimization benchmarking is a part of COCO (COmparing Continuous Optimizers) platform. BBOB consists of 24 noiseless, single-objective functions available in 2, 3, 5, 10, 20, and 40 dimensions. Each function has 15 instances. BBOB assumes nonconstrained search but defines a region of interest as [-5,5]^D. Here, these functions are used like functions from CECs, i.e., 30 independent runs on the first instance of each function are performed. The budget is set to 10000*D (where D is problem dimensionality). The search is stopped when the error level is 1e-8. The search is bound constrained to [-100,100]^D (as most of the used algorithms were created for CECs competition, their setup assumes that range). The experiments were performed for the following dimensionalities: 10, 20, and 40.
- CEC2017 - the benchmark was used during the competition on single objective bound constrained numerical optimization organized during the IEEE congress on evolutionary computation 2017.
Its description is available here
The source code was downloaded from.
 Remark: the competition organizers removed F2 from the competition.
 In the version used here, the benchmark functions return "INF" for queries outside the box constraints.
- CEC2022 - the benchmark was used during the competition on single objective bound constrained numerical optimization organized during the IEEE congress on evolutionary computation 2022. Its description is available here. The source code was downloaded from. 
 The version used here corrected the issues reported, which resulted in the definitions of F9 and F5 being changed.
 In the version used here, the benchmark functions return "INF" for queries outside the box constraints (one of the contestants of CEC 2022 asked for such points, and default implementation answered, giving additional knowledge to the algorithm).
Algorithms:
    
      - NL-SHADE-LBC took the second place in the CEC 2022 competition on single objective bound constrained numerical optimization. The implementation used here is downloaded from the competition organizers' repository.
The results of the tuned variant are discussed in the paper: Revisiting CEC 2022 ranking: A new ranking method and influence of parameter tuning. 
- NL-SHADE-RSP-MID took the third place in the CEC 2022 competition on single objective bound constrained numerical optimization. The implementation used here is downloaded from the competition organizers' repository. 
The newer implementation (C++) is available on author's homepage.
 The results of the tuned variant are discussed in the paper: Revisiting CEC 2022 ranking: A new ranking method and influence of parameter tuning.
- S-LSHADE-DP took fourth place in the CEC 2022 competition on single objective bound constrained numerical optimization. The implementation used here is downloaded from the competition organizers' repository.
The results of the tuned variant are discussed in the paper: Revisiting CEC 2022 ranking: A new ranking method and influence of parameter tuning. 
- L-SRTDE won CEC 2024 competition on single objective bound constrained numerical optimization. The implementation used here is downloaded from the competition organizers' repository.
- aBIPOP_CMA-ES (active BIPOP-CMA-ES) as implemented in libcmaes.
The initial step size (σ) was set to 0.3(u-l), which equals 60.
According to, as of July 2014, it is the leader on the noise-free version of the BBOB2009 benchmark.
- CMA-ES as implemented in libcmaes.
The initial step size (σ) was set to 0.3(u-l), which equals 60.
- EA4EigSimpTowardsIDE - the algorithm is described in the paper: Analysis and simplification of the winner of the CEC 2022 optimization competition on single objective bound constrained search. 
The source code.
 It is the strongest simplification of EA4Eig, which won CEC2022 competition on single objective bound constrained search.
The code of EA4Eig is in Matlab (about 716 lines) and can be downloaded from the CEC 2022 competition organizers repository. The simplification uses only 244 lines of C++ code. Logically, it uses only a part of one modified component of the original. The resulting algorithm is more similar to IDE than to the EA4Eig.
- EA4EigSimpTowardsIDE_jSO - the algorithm is described in the paper: Analysis and simplification of the winner of the CEC 2022 optimization competition on single objective bound constrained search. 
The source code.
 It is the simplification of EA4Eig, which won CEC2022 competition on single objective bound constrained search.
The code of EA4Eig is in Matlab and can be downloaded from the CEC 2022 competition organizers repository. The simplification (in C++) uses only two components (of the four): jSO and IDE.
- L-BFGS-B as implemented in dlib.
The algorithm is restarted with different starting points until the entire budget is used up. When possible starting points are the same for all algorithms under comparison.
Algorithm configuration: objective_delta_stop=1e-10 (larger values stopped algorithm too early); max_size=10, derivative_eps=1e-6.
- EA4Eig - the algorithm won CEC2022 competition on single objective bound constrained search.
The code of EA4Eig was downloaded from the CEC 2022 competition organizers repository.
The code was corrected because in the original, one decision path does not enforce bound constrains. The modification is described in the paper: Analysis and simplification of the winner of the CEC 2022 optimization competition on single objective bound constrained search. 
- Nelder-Mead Simplex as implemented in nlopt.
The algorithm is restarted with different starting points until the entire budget is used up. When possible starting points are the same for all algorithms under comparison.
Algorithm configuration: stopval=1e-8; xtol_rel=-1e-8; xtol_abs=-1e-8; ftol_abs=1e-9; ftol_rel=1e-7.
- RB-IPOP-CMA-ES is a modification of IPOP-CMA-ES. The RB-IPOP-CMA-ES took 7th place during CEC 2017 competition on sigle objective bound constrained search. Author's homepage.
- PSopt - is a PSO implementation available in R package NMOF, described also in book. The population size was set to 10*dim, quadratic penalty was used for bound constraint handling.
- DES as implemented in package.
Remark: The implementation uses the provided starting point only as the old population mean, which is used to compute step size. The initial population is generated inside the implementation in range <-80,80>. The implementation restarts when failed, and there is some budget left.
- GenSA - Generalized Simulated Annealing as implemented in R package. 
- EA (evolutionary algorithm) that used tournament selection of size 2, averaging crossover, and Gaussian mutation.
Population size 10*DIM, sigma=1, PC=0.5.
More about EAs can be found in paper. 
The algorithm is restarted when stagnation is detected. In the used implementation, the restart is triggered when the difference between the objective function values of the best and the worst individual in the current population is less than 1e-9.
Bound constraints are handled using reflection. More about bound constraints handling can be found in paper.
- DE in version DE/local-to-best/1/bin, which is default in several packages, e.g. DEOptim.
Population size is set to 10*DIM, F=0.8, CR=0.9.
In the version implemented and used here, bound constraints are handled using mutation repetition (called resampling), but after 20 consecutive failures to generate a feasible mutant, reflection is used. More about bound constraints handling can be found in paper.
- DE_restarts uses DE in version DE/local-to-best/1/bin, which is default in several packages, e.g. DEOptim.
The algorithm is restarted when stagnation is detected. In the used implementation, the restart is triggered when the difference between the objective function values of the best and the worst individual in the current population is less than 1e-9.
Population size is set to 10*DIM, F=0.8, CR=0.9.
Bound constraints are handled using mutation repetition (called resampling), but after 20 consecutive failures to generate a feasible mutant, reflection is used. More about bound constraints handling can be found in paper.
- SADE - self-adaptive DE. 
Population size is set to 10*DIM,  muF=0.5, muCR=0.5.
In the version implemented and used here, bound constraints are handled using mutation repetition (called resampling), but after 20 consecutive failures to generate a feasible mutant, reflection is used. More about bound constraints handling can be found in paper. The original paper states "If the values of some parameters of a newly generated trial vector exceed the corresponding upper and lower bounds, we randomly and uniformly reinitialize them within the prespecified range."
- JADE - Adaptive Differential Evolution With Optional External Archive. 
Population size is set to 10*DIM,  muF=0.5, muCR=0.5, pArch = 0.1, cLearnRate=0.1.
In the version implemented and used here, bound constraints are handled using mutation repetition (called resampling), but after 20 consecutive failures to generate a feasible mutant, reflection is used. More about bound constraints handling can be found in paper. The original paper states: "sets the violating components to be the middle of the violated bounds and the corresponding components of the parent individual".
- ES(mu+lambda) (evolution strategy). Lambda=10*DIM, mu=lambda/4. The initial sigma is set to 1.
Bound constraints are handled using reflection. More about bound constraints handling can be found in paper.
More about ES(mu+lambda) can be found in paper. 
- jSO - it is extended version of the iL-SHADE. 
Initial population size is set to round( sqrt(DIM) * log(DIM) * 25),  muF=0.3, muCR=0.8.
In the version implemented and used here, bound constraints are handled using mutation repetition (called resampling), but after 20 consecutive failures to generate a feasible mutant, reflection is used. More about bound constraints handling can be found in paper. The original paper just stated "If some variables from the trial vector are out of bounds, a repeat mechanism is applied.".
- ES(1+1) (evolution strategy). Sigma is adapted every 20 iterations. The initial sigma is set to 40.
The algorithm is restarted when the sigma is smaller than 1e-8.
When the candidate solution is not feasible, it is not evaluated; the iteration is counted as a failure. 
More about ES(1+1) can be found in book.