Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.10.x will end 8 November 2021 (12 months).
  • Bug fixes for security issues in 3.10.x will end 9 May 2022 (18 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are supported too.

Differences Between: [Versions 310 and 311]

   1  <?php
   2  
   3  /**
   4   *
   5   * Function code for the complex division operation
   6   *
   7   * @copyright  Copyright (c) 2013-2018 Mark Baker (https://github.com/MarkBaker/PHPComplex)
   8   * @license    https://opensource.org/licenses/MIT    MIT
   9   */
  10  namespace Complex;
  11  
  12  /**
  13   * Divides two or more complex numbers
  14   *
  15   * @param     array of string|integer|float|Complex    $complexValues   The numbers to divide
  16   * @return    Complex
  17   */
  18  function divideby(...$complexValues)
  19  {
  20      if (count($complexValues) < 2) {
  21          throw new \Exception('This function requires at least 2 arguments');
  22      }
  23  
  24      $base = array_shift($complexValues);
  25      $result = clone Complex::validateComplexArgument($base);
  26  
  27      foreach ($complexValues as $complex) {
  28          $complex = Complex::validateComplexArgument($complex);
  29  
  30          if ($result->isComplex() && $complex->isComplex() &&
  31              $result->getSuffix() !== $complex->getSuffix()) {
  32              throw new Exception('Suffix Mismatch');
  33          }
  34          if ($complex->getReal() == 0.0 && $complex->getImaginary() == 0.0) {
  35              throw new \InvalidArgumentException('Division by zero');
  36          }
  37  
  38          $delta1 = ($result->getReal() * $complex->getReal()) +
  39              ($result->getImaginary() * $complex->getImaginary());
  40          $delta2 = ($result->getImaginary() * $complex->getReal()) -
  41              ($result->getReal() * $complex->getImaginary());
  42          $delta3 = ($complex->getReal() * $complex->getReal()) +
  43              ($complex->getImaginary() * $complex->getImaginary());
  44  
  45          $real = $delta1 / $delta3;
  46          $imaginary = $delta2 / $delta3;
  47  
  48          $result = new Complex(
  49              $real,
  50              $imaginary,
  51              ($imaginary == 0.0) ? null : max($result->getSuffix(), $complex->getSuffix())
  52          );
  53      }
  54  
  55      return $result;
  56  }