1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
//! The module with functions to test optimization algorithms.
use Float;
/// Paraboloid.
///
/// y = (x0 - 1)^2 + (x1 - 2)^2 + (x2 - 3)^2 ... (xn - n)^2
/// The min val is 0.0 for point (0.0, 1.0, 2.0, ... n).
///
/// ```
/// use optlib::testfunctions::paraboloid;
///
/// let x = vec![1.0, 2.0, 3.0, 4.0, 5.0];
/// let value = paraboloid(&x);
///
/// assert!(value < 1e-5);
/// assert!(value >= 0.0);
/// ```
/// Schwefel function
///
/// # Parameters
/// Any x lies in [-500.0; 500.0].
/// Global minimum is x' = (420.9687, 420.9687, ...).
/// f(x') = 0
///
/// ```
/// use optlib::testfunctions::schwefel;
///
/// let x = vec![420.9687, 420.9687, 420.9687, 420.9687];
/// let value = schwefel(&x);
/// assert!(value < 1e-4);
/// assert!(value > 0.0);
/// ```