Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/sources/HeuristicLab.Tests/HeuristicLab.Common-3.3/EnumerableStatisticExtensions.cs @ 13025

Last change on this file since 13025 was 13025, checked in by gkronber, 9 years ago

#2488 implemented quantile extension method in HeuristicLab.Common

File size: 1.7 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2015 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
22using System.Linq;
23using HeuristicLab.Common;
24using Microsoft.VisualStudio.TestTools.UnitTesting;
25
26namespace HeuristicLab.Tests {
27  [TestClass]
28  public class EnumerableStatisticExtensionsTest {
29    [TestMethod]
30    [TestCategory("General")]
31    [TestProperty("Time", "short")]
32    public void QuantileTest() {
33      var xs = new double[] { 1, 1, 1, 3, 4, 7, 9, 11, 13, 13 };
34      {
35        var q = xs.Quantile(0.3);
36        Assert.AreEqual(q, 2.0, 1E-6);
37      }
38      {
39        var q = xs.Quantile(0.75);
40        Assert.AreEqual(q, 11.0, 1E-6);
41      }
42      // quantile = 0.5 is equivalent to median
43      {
44        // even number of elements
45        Assert.AreEqual(xs.Quantile(0.5), xs.Median(), 1E-6);
46      }
47      {
48        // odd number of elements
49        Assert.AreEqual(xs.Take(9).Quantile(0.5), xs.Take(9).Median(), 1E-6);
50      }
51    }
52  }
53}
Note: See TracBrowser for help on using the repository browser.