Completed
Pull Request — master (#21)
by Grega
01:03
created

Rosenbrock.__init__()   A

Complexity

Conditions 1

Size

Total Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

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