public function assertComplexEquals($expected, $actual, $delta = 0)
 {
     if ($expected[0] === '#') {
         //	Expecting an error, so we do a straight string comparison
         if ($expected === $actual) {
             return true;
         }
         $this->_errorMessage = 'Expected Error: ' . $actual . ' !== ' . $expected;
         return false;
     }
     $expectedComplex = new Complex($expected);
     $actualComplex = new Complex($actual);
     if (!is_numeric($actualComplex->getReal()) || !is_numeric($expectedComplex->getReal())) {
         if ($actualComplex->getReal() !== $expectedComplex->getReal()) {
             $this->_errorMessage = 'Mismatched String: ' . $actualComplex->getReal() . ' !== ' . $expectedComplex->getReal();
             return false;
         }
         return true;
     }
     if ($actualComplex->getReal() < $expectedComplex->getReal() - $delta || $actualComplex->getReal() > $expectedComplex->getReal() + $delta) {
         $this->_errorMessage = 'Mismatched Real part: ' . $actualComplex->getReal() . ' != ' . $expectedComplex->getReal();
         return false;
     }
     if ($actualComplex->getImaginary() < $expectedComplex->getImaginary() - $delta || $actualComplex->getImaginary() > $expectedComplex->getImaginary() + $delta) {
         $this->_errorMessage = 'Mismatched Imaginary part: ' . $actualComplex->getImaginary() . ' != ' . $expectedComplex->getImaginary();
         return false;
     }
     if ($actualComplex->getSuffix() !== $actualComplex->getSuffix()) {
         $this->_errorMessage = 'Mismatched Suffix: ' . $actualComplex->getSuffix() . ' != ' . $expectedComplex->getSuffix();
         return false;
     }
     return true;
 }
示例#2
0
 /**
  * Returns the quotient of this complex number
  * and the given complex number.
  *
  * @param object Complex $c The given complex number.
  * @return object Complex The quotient.
  */
 public function div(Complex $c)
 {
     $denom = $c->getReal() * $c->getReal() - $c->getImag() * $c->getImag();
     return new Complex(($this->getReal() * $c->getReal() - $this->getImag() * $c->getImag()) / $denom, ($this->getImag() * $c->getReal() - $this->getReal() * $c->getImag()) / $denom);
 }