# EVOLVE-BLOCK-START
"""Generic oscillator-inspired symbolic-regression baseline for MT-STS."""

import numpy as np


def func(x, params):
    """Predict dv_dt from input columns [x, t, v] with a generic stable baseline."""
    x = np.asarray(x, dtype=float)
    params = np.asarray(params, dtype=float).reshape(-1)
    if params.size < 10:
        params = np.pad(params, (0, 10 - params.size))

    pos = x[:, 0]
    t_val = x[:, 1]
    vel = x[:, 2]

    clipped_pos = np.clip(pos, -6.0, 6.0)
    clipped_vel = np.clip(vel, -6.0, 6.0)
    decay = np.exp(-np.clip(np.abs(clipped_pos), 0.0, 8.0))

    restoring = -(params[0] * clipped_pos + params[1] * clipped_pos**3)
    damping = -(params[2] * clipped_vel + params[3] * clipped_vel**3)
    forcing = params[4] * np.sin(params[5] * t_val)
    coupling = params[6] * clipped_pos * t_val + params[7] * np.sin(clipped_vel)
    mixed = params[8] * decay * clipped_vel
    bias = params[9]

    prediction = restoring + damping + forcing + coupling + mixed + bias
    return np.asarray(prediction, dtype=float)


func.num_params = 10


def run_search():
    return func


# EVOLVE-BLOCK-END
