// // Math.NET Numerics, part of the Math.NET Project // http://numerics.mathdotnet.com // http://github.com/mathnet/mathnet-numerics // http://mathnetnumerics.codeplex.com // // Copyright (c) 2009-2013 Math.NET // // Permission is hereby granted, free of charge, to any person // obtaining a copy of this software and associated documentation // files (the "Software"), to deal in the Software without // restriction, including without limitation the rights to use, // copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the // Software is furnished to do so, subject to the following // conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES // OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, // WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR // OTHER DEALINGS IN THE SOFTWARE. // namespace MathNet.Numerics.UnitTests.LinearAlgebraTests.Complex { using LinearAlgebra.Complex; using NUnit.Framework; using System; using System.Globalization; /// /// Dense vector text handling tests. /// [TestFixture] public class DenseVectorTextHandlingTest { /// /// Can parse a Complex dense vectors with invariant culture. /// /// String to parse. /// Expected result. [TestCase("2", "(2, 0)")] [TestCase("(3)", "(3, 0)")] [TestCase("[1,2,3]", "(1, 0) (2, 0) (3, 0)")] [TestCase(" [ 1.1 , 2.1 , 3.1 ] ", "(1.1, 0) (2.1, 0) (3.1, 0)")] [TestCase(" [ -1.1 , 2.1 , +3.1 ] ", "(-1.1, 0) (2.1, 0) (3.1, 0)")] [TestCase(" [1.2,3.4 , 5.6] ", "(1.2, 0) (3.4, 0) (5.6, 0)")] [TestCase("[1+1i,2+1i,3+1i]", "(1, 1) (2, 1) (3, 1)")] [TestCase(" [ 1.1 + 1i , 2.1+1i , 3.1+1i ] ", "(1.1, 1) (2.1, 1) (3.1, 1)")] [TestCase(" [ -1.1 + 1i , 2.1-1i , +3.1+1i ] ", "(-1.1, 1) (2.1, -1) (3.1, 1)")] [TestCase(" [1.2+2.3i ,3.4+4.5i , 5.6+ 6.7i] ", "(1.2, 2.3) (3.4, 4.5) (5.6, 6.7)")] public void CanParseComplexDenseVectorsWithInvariant(string stringToParse, string expectedToString) { var formatProvider = CultureInfo.InvariantCulture; var vector = DenseVector.Parse(stringToParse, formatProvider); Assert.AreEqual(expectedToString, vector.ToVectorString(1, int.MaxValue, 1, "G", formatProvider)); } /// /// Can parse a Complex dense vectors with culture. /// /// String to parse. /// Expected result. /// Culture name. [TestCase(" 1.2 + 1i , 3.4 + 1i , 5.6 + 1i ", "(1.2, 1) (3.4, 1) (5.6, 1)", "en-US")] [TestCase(" 1.2 + 1i ; 3.4 + 1i ; 5.6 + 1i ", "(1.2, 1) (3.4, 1) (5.6, 1)", "de-CH")] #if !PORTABLE [TestCase(" 1,2 + 1i ; 3,4 + 1i ; 5,6 + 1i ", "(1,2, 1) (3,4, 1) (5,6, 1)", "de-DE")] #endif public void CanParseComplexDenseVectorsWithCulture(string stringToParse, string expectedToString, string culture) { var formatProvider = new CultureInfo(culture); var vector = DenseVector.Parse(stringToParse, formatProvider); Assert.AreEqual(expectedToString, vector.ToVectorString(1, int.MaxValue, 1, "G", formatProvider)); } /// /// Parse if missing closing paren throws FormatException. /// [Test] public void ParseIfMissingClosingParenThrowsFormatException() { Assert.Throws(() => DenseVector.Parse("(1")); Assert.Throws(() => DenseVector.Parse("[1")); } /// /// Try parse a bad value with invariant returns false. /// /// Input string. [TestCase(null)] [TestCase("")] [TestCase(",")] [TestCase("1e+")] [TestCase("1e")] [TestCase("()")] [TestCase("[ ]")] public void TryParseBadValueWithInvariantReturnsFalse(string str) { DenseVector vector; var ret = DenseVector.TryParse(str, CultureInfo.InvariantCulture, out vector); Assert.IsFalse(ret); Assert.IsNull(vector); } } }