HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux sci 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: tpdc (1002)
PHP: 7.4.3-4ubuntu2.29
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/html/nsci/wp-content/plugins/tablepress/libraries/vendor/Complex/Operations.php
<?php

namespace TablePress\Complex;

use InvalidArgumentException;

class Operations
{
	/**
	 * Adds two or more complex numbers
	 *
	 * @param     array of string|integer|float|TablePress\Complex    $complexValues   The numbers to add
	 * @return    TablePress\Complex
	 */
	public static function add(...$complexValues): TablePress\Complex
	{
		if (count($complexValues) < 2) {
			throw new \Exception('This function requires at least 2 arguments');
		}

		$base = array_shift($complexValues);
		$result = clone Complex::validateComplexArgument($base);

		foreach ($complexValues as $complex) {
			$complex = Complex::validateComplexArgument($complex);

			if ($result->isComplex() && $complex->isComplex() &&
				$result->getSuffix() !== $complex->getSuffix()) {
				throw new Exception('Suffix Mismatch');
			}

			$real = $result->getReal() + $complex->getReal();
			$imaginary = $result->getImaginary() + $complex->getImaginary();

			$result = new Complex(
				$real,
				$imaginary,
				($imaginary == 0.0) ? null : max($result->getSuffix(), $complex->getSuffix())
			);
		}

		return $result;
	}

	/**
	 * Divides two or more complex numbers
	 *
	 * @param     array of string|integer|float|TablePress\Complex    $complexValues   The numbers to divide
	 * @return    TablePress\Complex
	 */
	public static function divideby(...$complexValues): TablePress\Complex
	{
		if (count($complexValues) < 2) {
			throw new \Exception('This function requires at least 2 arguments');
		}

		$base = array_shift($complexValues);
		$result = clone Complex::validateComplexArgument($base);

		foreach ($complexValues as $complex) {
			$complex = Complex::validateComplexArgument($complex);

			if ($result->isComplex() && $complex->isComplex() &&
				$result->getSuffix() !== $complex->getSuffix()) {
				throw new Exception('Suffix Mismatch');
			}
			if ($complex->getReal() == 0.0 && $complex->getImaginary() == 0.0) {
				throw new InvalidArgumentException('Division by zero');
			}

			$delta1 = ($result->getReal() * $complex->getReal()) +
				($result->getImaginary() * $complex->getImaginary());
			$delta2 = ($result->getImaginary() * $complex->getReal()) -
				($result->getReal() * $complex->getImaginary());
			$delta3 = ($complex->getReal() * $complex->getReal()) +
				($complex->getImaginary() * $complex->getImaginary());

			$real = $delta1 / $delta3;
			$imaginary = $delta2 / $delta3;

			$result = new Complex(
				$real,
				$imaginary,
				($imaginary == 0.0) ? null : max($result->getSuffix(), $complex->getSuffix())
			);
		}

		return $result;
	}

	/**
	 * Divides two or more complex numbers
	 *
	 * @param     array of string|integer|float|TablePress\Complex    $complexValues   The numbers to divide
	 * @return    TablePress\Complex
	 */
	public static function divideinto(...$complexValues): TablePress\Complex
	{
		if (count($complexValues) < 2) {
			throw new \Exception('This function requires at least 2 arguments');
		}

		$base = array_shift($complexValues);
		$result = clone Complex::validateComplexArgument($base);

		foreach ($complexValues as $complex) {
			$complex = Complex::validateComplexArgument($complex);

			if ($result->isComplex() && $complex->isComplex() &&
				$result->getSuffix() !== $complex->getSuffix()) {
				throw new Exception('Suffix Mismatch');
			}
			if ($result->getReal() == 0.0 && $result->getImaginary() == 0.0) {
				throw new InvalidArgumentException('Division by zero');
			}

			$delta1 = ($complex->getReal() * $result->getReal()) +
				($complex->getImaginary() * $result->getImaginary());
			$delta2 = ($complex->getImaginary() * $result->getReal()) -
				($complex->getReal() * $result->getImaginary());
			$delta3 = ($result->getReal() * $result->getReal()) +
				($result->getImaginary() * $result->getImaginary());

			$real = $delta1 / $delta3;
			$imaginary = $delta2 / $delta3;

			$result = new Complex(
				$real,
				$imaginary,
				($imaginary == 0.0) ? null : max($result->getSuffix(), $complex->getSuffix())
			);
		}

		return $result;
	}

	/**
	 * Multiplies two or more complex numbers
	 *
	 * @param     array of string|integer|float|TablePress\Complex    $complexValues   The numbers to multiply
	 * @return    TablePress\Complex
	 */
	public static function multiply(...$complexValues): TablePress\Complex
	{
		if (count($complexValues) < 2) {
			throw new \Exception('This function requires at least 2 arguments');
		}

		$base = array_shift($complexValues);
		$result = clone Complex::validateComplexArgument($base);

		foreach ($complexValues as $complex) {
			$complex = Complex::validateComplexArgument($complex);

			if ($result->isComplex() && $complex->isComplex() &&
				$result->getSuffix() !== $complex->getSuffix()) {
				throw new Exception('Suffix Mismatch');
			}

			$real = ($result->getReal() * $complex->getReal()) -
				($result->getImaginary() * $complex->getImaginary());
			$imaginary = ($result->getReal() * $complex->getImaginary()) +
				($result->getImaginary() * $complex->getReal());

			$result = new Complex(
				$real,
				$imaginary,
				($imaginary == 0.0) ? null : max($result->getSuffix(), $complex->getSuffix())
			);
		}

		return $result;
	}

	/**
	 * Subtracts two or more complex numbers
	 *
	 * @param     array of string|integer|float|TablePress\Complex    $complexValues   The numbers to subtract
	 * @return    TablePress\Complex
	 */
	public static function subtract(...$complexValues): TablePress\Complex
	{
		if (count($complexValues) < 2) {
			throw new \Exception('This function requires at least 2 arguments');
		}

		$base = array_shift($complexValues);
		$result = clone Complex::validateComplexArgument($base);

		foreach ($complexValues as $complex) {
			$complex = Complex::validateComplexArgument($complex);

			if ($result->isComplex() && $complex->isComplex() &&
				$result->getSuffix() !== $complex->getSuffix()) {
				throw new Exception('Suffix Mismatch');
			}

			$real = $result->getReal() - $complex->getReal();
			$imaginary = $result->getImaginary() - $complex->getImaginary();

			$result = new Complex(
				$real,
				$imaginary,
				($imaginary == 0.0) ? null : max($result->getSuffix(), $complex->getSuffix())
			);
		}

		return $result;
	}
}