|
29 | 29 |
|
30 | 30 | using System; |
31 | 31 | using System.Collections.Generic; |
| 32 | +#if NET5_0_OR_GREATER |
| 33 | +using System.Text.Json; |
| 34 | +using System.Text.Json.Serialization; |
| 35 | +#endif |
32 | 36 | using NUnit.Framework; |
33 | 37 | using MathNet.Numerics.Statistics; |
34 | 38 |
|
@@ -301,5 +305,47 @@ public void ZeroVarianceSequence() |
301 | 305 | Assert.That(stats.Skewness, Is.NaN); |
302 | 306 | Assert.That(stats.Kurtosis, Is.NaN); |
303 | 307 | } |
| 308 | + |
| 309 | +#if NET5_0_OR_GREATER |
| 310 | + /// <summary> |
| 311 | + /// <c>IEnumerable</c> Double. |
| 312 | + /// </summary> |
| 313 | + /// <param name="dataSet">Dataset name.</param> |
| 314 | + /// <param name="digits">Digits count.</param> |
| 315 | + /// <param name="skewness">Skewness value.</param> |
| 316 | + /// <param name="kurtosis">Kurtosis value.</param> |
| 317 | + /// <param name="median">Median value.</param> |
| 318 | + /// <param name="min">Min value.</param> |
| 319 | + /// <param name="max">Max value.</param> |
| 320 | + /// <param name="count">Count value.</param> |
| 321 | + [TestCase("lottery", 12, -0.09333165310779, -1.19256091074856, 522.5, 4, 999, 218)] |
| 322 | + [TestCase("lew", 12, -0.050606638756334, -1.49604979214447, -162, -579, 300, 200)] |
| 323 | + [TestCase("mavro", 11, 0.64492948110824, -0.82052379677456, 2.0018, 2.0013, 2.0027, 50)] |
| 324 | + [TestCase("michelso", 11, -0.0185388637725746, 0.33968459842539, 299.85, 299.62, 300.07, 100)] |
| 325 | + [TestCase("numacc1", 15, 0, double.NaN, 10000002, 10000001, 10000003, 3)] |
| 326 | + [TestCase("numacc2", 13, 0, -2.003003003003, 1.2, 1.1, 1.3, 1001)] |
| 327 | + [TestCase("numacc3", 9, 0, -2.003003003003, 1000000.2, 1000000.1, 1000000.3, 1001)] |
| 328 | + [TestCase("numacc4", 7, 0, -2.00300300299913, 10000000.2, 10000000.1, 10000000.3, 1001)] |
| 329 | + [TestCase("meixner", 8, -0.016649617280859657, 0.8171318629552635, -0.002042931016531602, -4.825626912281697, 5.3018298664184913, 10000)] |
| 330 | + public void JsonDeserializationTest(string dataSet, int digits, double skewness, double kurtosis, double median, double min, double max, int count) |
| 331 | + { |
| 332 | + var data = _data[dataSet]; |
| 333 | + var serialize = new DescriptiveStatistics(data.Data, false); |
| 334 | + var jsonSerializerOptions = new JsonSerializerOptions |
| 335 | + { |
| 336 | + NumberHandling = JsonNumberHandling.AllowNamedFloatingPointLiterals, |
| 337 | + }; |
| 338 | + var json = JsonSerializer.Serialize(serialize, jsonSerializerOptions); |
| 339 | + var stats = JsonSerializer.Deserialize<DescriptiveStatistics>(json, jsonSerializerOptions); |
| 340 | + Assert.NotNull(stats); |
| 341 | + AssertHelpers.AlmostEqualRelative(data.Mean, stats.Mean, 10); |
| 342 | + AssertHelpers.AlmostEqualRelative(data.StandardDeviation, stats.StandardDeviation, digits); |
| 343 | + AssertHelpers.AlmostEqualRelative(skewness, stats.Skewness, 8); |
| 344 | + AssertHelpers.AlmostEqualRelative(kurtosis, stats.Kurtosis, 8); |
| 345 | + Assert.AreEqual(stats.Minimum, min); |
| 346 | + Assert.AreEqual(stats.Maximum, max); |
| 347 | + Assert.AreEqual(stats.Count, count); |
| 348 | + } |
| 349 | +#endif |
304 | 350 | } |
305 | 351 | } |
0 commit comments