HEX
Server: LiteSpeed
System: Linux server.zepintelhosting.com 4.18.0 #1 SMP Mon Sep 30 15:36:27 MSK 2024 x86_64
User: enamadmin (1026)
PHP: 8.2.30
Disabled: exec,system,passthru,shell_exec,proc_open,popen,apache_child_terminate
Upload Files
File: /home/enamadmin/public_html/aaelearningb/lib/mlbackend/php/phpml/src/Phpml/Math/Kernel/RBF.php
<?php

declare(strict_types=1);

namespace Phpml\Math\Kernel;

use Phpml\Exception\InvalidArgumentException;
use Phpml\Math\Kernel;
use Phpml\Math\Product;

class RBF implements Kernel
{
    /**
     * @var float
     */
    private $gamma;

    public function __construct(float $gamma)
    {
        $this->gamma = $gamma;
    }

    public function compute($a, $b): float
    {
        if (!is_array($a) || !is_array($b)) {
            throw new InvalidArgumentException(sprintf('Arguments of %s must be arrays', __METHOD__));
        }

        $score = 2 * Product::scalar($a, $b);
        $squares = Product::scalar($a, $a) + Product::scalar($b, $b);

        return exp(-$this->gamma * ($squares - $score));
    }
}