Source code for optilab.functions.unimodal.cumulative_squared_sums

"""
Cumulative squared sums function.
"""

from ...data_classes import Point
from ..objective_function import ObjectiveFunction


[docs] class CumulativeSquaredSums(ObjectiveFunction): """ Cumulative squared sums function. """
[docs] def __init__(self, dim: int): """ Class constructor. Args: dim: Dimensionality of the function. """ super().__init__("cumulative_squared_sums", dim)
[docs] def __call__(self, point: Point) -> Point: """ Evaluate a single point with the objective function. Args: point: Point to evaluate. Raises: ValueError: If dimensionality of x doesn't match self.dim. Returns: Evaluated point. """ super().__call__(point) return Point( x=point.x, y=sum(sum(point.x[:i]) ** 2 for i in range(point.dim())), is_evaluated=True, )