Math.NET Numerics
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

305 lines
12 KiB

using System;
using System.Globalization;
using MbUnit.Framework;
namespace MathNet.Numerics.UnitTests
{
[TestFixture]
public class ComplexTest
{
[Test, MultipleAsserts]
public void CanCreateComplexNumberUsingTheConstructor()
{
var complex = new Complex(1.1, -2.2);
Assert.AreEqual(1.1, complex.Real, "Real part is 1.1.");
Assert.AreEqual(-2.2, complex.Imaginary, "Imaginary part is -2.2.");
}
[Test, MultipleAsserts]
public void CanCreateComplexNumberWithRealImaginaryIntializer()
{
var complex = Complex.WithRealImaginary(1.1, -2.2);
Assert.AreEqual(1.1, complex.Real, "Real part is 1.1.");
Assert.AreEqual(-2.2, complex.Imaginary, "Imaginary part is -2.2.");
}
[Test]
public void WithModulusArgumentThrowsArgumentOutOfRangeException()
{
Assert.Throws<ArgumentOutOfRangeException>(() => Complex.WithModulusArgument(-1, 1), "Throws exception because modulus is negative.");
}
[Test, MultipleAsserts]
public void CanCreateComplexNumberWithModulusArgument()
{
var complex = Complex.WithModulusArgument(2, -Math.PI / 6);
Assert.AreApproximatelyEqual(Math.Sqrt(3), complex.Real, 1e-15, "Real part is Sqrt(3).");
Assert.AreApproximatelyEqual(-1, complex.Imaginary, 1e-15, "Imaginary part is -1.");
}
[Test]
public void CanDetermineIfZeroValueComplexNumber()
{
var complex = new Complex(0, 0);
Assert.IsTrue(complex.IsZero, "Zero complex number.");
}
[Test]
public void CanDetermineIfOneValueComplexNumber()
{
var complex = new Complex(1, 0);
Assert.IsTrue(complex.IsOne, "Complex number with a value of one.");
}
[Test]
public void CanDetermineIfImaginaryUnit()
{
var complex = new Complex(0, 1);
Assert.IsTrue(complex.IsI, "Imaginary unit");
}
[Test, MultipleAsserts]
public void CanDetermineIfNaN()
{
var complex = new Complex(double.NaN, 1);
Assert.IsTrue(complex.IsNaN, "Real part is NaN.");
complex = new Complex(1, double.NaN);
Assert.IsTrue(complex.IsNaN, "Imaginary part is NaN.");
complex = new Complex(double.NaN, double.NaN);
Assert.IsTrue(complex.IsNaN, "Both parts are NaN.");
}
[Test, MultipleAsserts]
public void CanDetermineIfInfinity()
{
var complex = new Complex(double.PositiveInfinity, 1);
Assert.IsTrue(complex.IsInfinity, "Real part is infinity.");
complex = new Complex(1, double.NegativeInfinity);
Assert.IsTrue(complex.IsInfinity, "Imaginary part is infinity.");
complex = new Complex(double.NegativeInfinity, double.PositiveInfinity);
Assert.IsTrue(complex.IsInfinity, "Both parts are infinity.");
}
[Test]
public void CanDetermineIfRealNumber()
{
var complex = new Complex(-1, 0);
Assert.IsTrue(complex.IsReal, "Is a real number.");
}
[Test]
public void CanDetermineIfRealNonNegativeNumber()
{
var complex = new Complex(1, 0);
Assert.IsTrue(complex.IsReal, "Is a real non-negative number.");
}
[Test, MultipleAsserts]
public void CanCalculateHashCode()
{
var complex = new Complex(1, 0);
Assert.AreEqual(1072693248, complex.GetHashCode());
complex = new Complex(0, 1);
Assert.AreEqual(-1072693248, complex.GetHashCode());
complex = new Complex(1, 1);
Assert.AreEqual(-2097152, complex.GetHashCode());
}
[Test, MultipleAsserts]
public void CanCreateStringFromComplexNumber()
{
Assert.AreEqual("NaN", Complex.NaN.ToString());
Assert.AreEqual("Infinity", Complex.Infinity.ToString());
Assert.AreEqual("1.1", new Complex(1.1, 0).ToString());
Assert.AreEqual("-1.1i", new Complex(0, -1.1).ToString());
Assert.AreEqual("1.1i", new Complex(0, 1.1).ToString());
Assert.AreEqual("1.1 + 1.1i", new Complex(1.1, 1.1).ToString());
}
[Test, MultipleAsserts]
public void CanTestForEquality()
{
Assert.AreNotEqual(Complex.NaN, Complex.NaN);
Assert.AreEqual(Complex.Infinity, Complex.Infinity);
Assert.AreEqual(new Complex(1.1, -2.2), new Complex(1.1, -2.2));
Assert.AreNotEqual(new Complex(-1.1, 2.2), new Complex(1.1, -2.2));
}
[Test, MultipleAsserts]
public void CanCreateStringUsingNumberFormat()
{
Assert.AreEqual("NaN", Complex.NaN.ToString("#.000"));
Assert.AreEqual("Infinity", Complex.Infinity.ToString("#.000"));
Assert.AreEqual("1.100", new Complex(1.1, 0).ToString("#.000"));
Assert.AreEqual("-1.100i", new Complex(0, -1.1).ToString("#.000"));
Assert.AreEqual("1.100i", new Complex(0, 1.1).ToString("#.000"));
Assert.AreEqual("1.100 + 1.100i", new Complex(1.1, 1.1).ToString("#.000"));
}
[Test, MultipleAsserts]
public void CanCreateStringUsingFormatProvider()
{
var provider = CultureInfo.GetCultureInfo("tr-TR");
Assert.AreEqual("NaN", Complex.NaN.ToString(provider));
Assert.AreEqual("Infinity", Complex.Infinity.ToString(provider));
Assert.AreEqual("1,1", new Complex(1.1, 0).ToString(provider));
Assert.AreEqual("-1,1i", new Complex(0, -1.1).ToString(provider));
Assert.AreEqual("1,1i", new Complex(0, 1.1).ToString(provider));
Assert.AreEqual("1,1 + 1,1i", new Complex(1.1, 1.1).ToString(provider));
}
[Test, MultipleAsserts]
public void CanTestForEqualityUsingOperators()
{
AssertEx.That(() => Complex.NaN != Complex.NaN);
AssertEx.That(() => Complex.Infinity == Complex.Infinity);
AssertEx.That(() => new Complex(1.1, -2.2) == new Complex(1.1, -2.2));
AssertEx.That(() => new Complex(-1.1, 2.2) != new Complex(1.1, -2.2));
}
[Test, MultipleAsserts]
public void CanConvertDoubleToComplex()
{
AssertEx.That(() => ((Complex) double.NaN).IsNaN);
AssertEx.That(() => ((Complex) double.NegativeInfinity).IsInfinity);
Assert.AreEqual((Complex) 1.1, new Complex(1.1, 0));
}
[Test]
public void CanUsePlusOperator()
{
var complex = new Complex(1.1, -2.2);
Assert.AreEqual(complex, +complex);
}
[Test]
public void CanNegateValueUsingOperator()
{
var complex = new Complex(1.1, -2.2);
Assert.AreEqual(new Complex(-1.1, 2.2), -complex);
}
[Test]
public void CanUsePlus()
{
var complex = new Complex(1.1, -2.2);
Assert.AreEqual(complex, complex.Plus());
}
[Test]
public void CanNegateValue()
{
var complex = new Complex(1.1, -2.2);
Assert.AreEqual(new Complex(-1.1, 2.2), complex.Negate());
}
[Test, MultipleAsserts]
public void CanAddTwoComplexNumbersUsingOperartor()
{
AssertEx.That(() => (Complex.NaN + Complex.NaN).IsNaN);
AssertEx.That(() => (Complex.Infinity + Complex.One).IsInfinity);
AssertEx.That(() => (Complex.One + Complex.Zero) == Complex.One);
AssertEx.That(() => (new Complex(1.1, -2.2) + new Complex(-1.1, 2.2)) == Complex.Zero);
}
[Test, MultipleAsserts]
public void CanAddTwoComplexNumbers()
{
AssertEx.That(() => (Complex.NaN.Add(Complex.NaN)).IsNaN);
AssertEx.That(() => (Complex.Infinity.Add(Complex.One).IsInfinity));
AssertEx.That(() => (Complex.One.Add(Complex.Zero)) == Complex.One);
AssertEx.That(() => (new Complex(1.1, -2.2).Add(new Complex(-1.1, 2.2))) == Complex.Zero);
}
[Test, MultipleAsserts]
public void CanAddComplexNumberAndDoubleUsingOperartor()
{
AssertEx.That(() => (Complex.NaN + double.NaN).IsNaN);
AssertEx.That(() => (double.NaN + Complex.NaN).IsNaN);
AssertEx.That(() => (double.PositiveInfinity + Complex.One).IsInfinity);
AssertEx.That(() => (Complex.Infinity + 1.0).IsInfinity);
AssertEx.That(() => (Complex.One + 0.0) == Complex.One);
AssertEx.That(() => (0.0 + Complex.One) == Complex.One);
AssertEx.That(() => (new Complex(1.1, -2.2) + 1.1 == new Complex(2.2, -2.2)));
AssertEx.That(() => -2.2 + new Complex(-1.1, 2.2) == new Complex(-3.3, 2.2));
}
[Test, MultipleAsserts]
public void CanAddSubtractComplexNumbersUsingOperartor()
{
AssertEx.That(() => (Complex.NaN - Complex.NaN).IsNaN);
AssertEx.That(() => (Complex.Infinity - Complex.One).IsInfinity);
AssertEx.That(() => (Complex.One - Complex.Zero) == Complex.One);
AssertEx.That(() => (new Complex(1.1, -2.2) - new Complex(1.1, -2.2)) == Complex.Zero);
}
[Test, MultipleAsserts]
public void CanSubtractTwoComplexNumbers()
{
AssertEx.That(() => (Complex.NaN.Subtract(Complex.NaN)).IsNaN);
AssertEx.That(() => (Complex.Infinity.Subtract(Complex.One)).IsInfinity);
AssertEx.That(() => (Complex.One.Subtract(Complex.Zero)) == Complex.One);
AssertEx.That(() => (new Complex(1.1, -2.2).Subtract(new Complex(1.1, -2.2))) == Complex.Zero);
}
[Test, MultipleAsserts]
public void CanSubtractComplexNumberAndDoubleUsingOperartor()
{
AssertEx.That(() => (Complex.NaN - double.NaN).IsNaN);
AssertEx.That(() => (double.NaN - Complex.NaN).IsNaN);
AssertEx.That(() => (double.PositiveInfinity - Complex.One).IsInfinity);
AssertEx.That(() => (Complex.Infinity - 1.0).IsInfinity);
AssertEx.That(() => (Complex.One - 0.0) == Complex.One);
AssertEx.That(() => (0.0 - Complex.One) == -Complex.One);
AssertEx.That(() => (new Complex(1.1, -2.2) - 1.1 == new Complex(0.0, -2.2)));
AssertEx.That(() => -2.2 - new Complex(-1.1, 2.2) == new Complex(-1.1, -2.2));
}
[Test, MultipleAsserts]
public void CanMultipleTwoComplexNumbersUsingOperators()
{
AssertEx.That(() => (Complex.NaN * Complex.One).IsNaN);
Assert.AreEqual(new Complex(0, 16), new Complex(4, -4) * new Complex(-2, 2));
}
[Test, MultipleAsserts]
public void CanMultipleTwoComplexNumbers()
{
AssertEx.That(() => (Complex.NaN.Multiply(Complex.One).IsNaN));
Assert.AreEqual(new Complex(0, 16), new Complex(4, -4).Multiply(new Complex(-2, 2)));
}
[Test, MultipleAsserts]
public void CanMultipleComplexNumberAndDoubleUsingOperators()
{
AssertEx.That(() => (Complex.NaN * 1.0).IsNaN);
Assert.AreEqual(new Complex(8, -8), new Complex(4, -4) * 2);
Assert.AreEqual(new Complex(8, -8), 2 * new Complex(4, -4));
}
[Test, MultipleAsserts]
public void CanDivideTwoComplexNumbersUsingOperators()
{
AssertEx.That(() => (Complex.NaN / Complex.One).IsNaN);
Assert.AreEqual(new Complex(-2, 0), new Complex(4, -4) / new Complex(-2, 2));
Assert.AreEqual(Complex.Infinity, Complex.One / Complex.Zero);
}
[Test, MultipleAsserts]
public void CanDivideTwoComplexNumbers()
{
AssertEx.That(() => (Complex.NaN.Multiply(Complex.One).IsNaN));
Assert.AreEqual(new Complex(-2, 0), new Complex(4, -4).Divide(new Complex(-2, 2)));
Assert.AreEqual(Complex.Infinity, Complex.One.Divide(Complex.Zero));
}
[Test, MultipleAsserts]
public void CanDivideComplexNumberAndDoubleUsingOperators()
{
AssertEx.That(() => (Complex.NaN * 1.0).IsNaN);
Assert.AreEqual(new Complex(-2, 2), new Complex(4, -4) / -2);
Assert.AreEqual(new Complex(0.25, 0.25), 2 / new Complex(4, -4));
Assert.AreEqual(Complex.Infinity, Complex.One / 0);
}
}
}