Passed
Push — master ( 90fac4...b39ade )
by Grega
51s
created

Rosenbrock.evaluate()   A

Complexity

Conditions 2

Size

Total Lines 9

Duplication

Lines 0
Ratio 0 %

Importance

Changes 2
Bugs 0 Features 2
Metric Value
dl 0
loc 9
rs 9.6666
c 2
b 0
f 2
cc 2
1
"""Implementation of Rosenbrock benchmark function."""
2
3
import math
4
5
__all__ = ['Rosenbrock']
6
7
8
class Rosenbrock(object):
9
10
    @classmethod
11
    def function(cls):
12
        def evaluate(D, sol):
13
            val = 0.0
14
15
            for i in range(D - 1):
16
                val = val + 100 * \
17
                    math.pow(sol[i + 1] - math.pow((sol[i]), 2),
18
                             2) + math.pow((sol[i] - 1), 2)
19
20
            return val
21
22
        return evaluate
23