NormalDistributionFunction2DTest.java 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. /* ===========================================================
  2. * JFreeChart : a free chart library for the Java(tm) platform
  3. * ===========================================================
  4. *
  5. * (C) Copyright 2000-2013, by Object Refinery Limited and Contributors.
  6. *
  7. * Project Info: http://www.jfree.org/jfreechart/index.html
  8. *
  9. * This library is free software; you can redistribute it and/or modify it
  10. * under the terms of the GNU Lesser General Public License as published by
  11. * the Free Software Foundation; either version 2.1 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This library is distributed in the hope that it will be useful, but
  15. * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
  16. * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
  17. * License for more details.
  18. *
  19. * You should have received a copy of the GNU Lesser General Public
  20. * License along with this library; if not, write to the Free Software
  21. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
  22. * USA.
  23. *
  24. * [Oracle and Java are registered trademarks of Oracle and/or its affiliates.
  25. * Other names may be trademarks of their respective owners.]
  26. *
  27. * -------------------------------------
  28. * NormalDistributionFunction2DTest.java
  29. * -------------------------------------
  30. * (C) Copyright 2009-2013, by Object Refinery Limited and Contributors.
  31. *
  32. * Original Author: David Gilbert (for Object Refinery Limited);
  33. * Contributor(s): -;
  34. *
  35. * Changes
  36. * -------
  37. * 28-May-2009 : Version 1 (DG);
  38. *
  39. */
  40. package org.jfree.data.function;
  41. import org.jfree.chart.TestUtilities;
  42. import org.junit.Test;
  43. import static org.junit.Assert.assertEquals;
  44. import static org.junit.Assert.assertNotEquals;
  45. /**
  46. * Tests for the {@link NormalDistributionFunction2D} class.
  47. */
  48. public class NormalDistributionFunction2DTest {
  49. private static final double EPSILON = 0.000000001;
  50. /**
  51. * Some tests for the constructor.
  52. */
  53. @Test
  54. public void testConstructor() {
  55. NormalDistributionFunction2D f = new NormalDistributionFunction2D(1.0,
  56. 2.0);
  57. assertEquals(1.0, f.getMean(), EPSILON);
  58. assertEquals(2.0, f.getStandardDeviation(), EPSILON);
  59. }
  60. /**
  61. * For datasets, the equals() method just checks keys and values.
  62. */
  63. @Test
  64. public void testEquals() {
  65. NormalDistributionFunction2D f1 = new NormalDistributionFunction2D(1.0,
  66. 2.0);
  67. NormalDistributionFunction2D f2 = new NormalDistributionFunction2D(1.0,
  68. 2.0);
  69. assertEquals(f1, f2);
  70. f1 = new NormalDistributionFunction2D(2.0, 3.0);
  71. assertNotEquals(f1, f2);
  72. f2 = new NormalDistributionFunction2D(2.0, 3.0);
  73. assertEquals(f1, f2);
  74. }
  75. /**
  76. * Serialize an instance, restore it, and check for equality.
  77. */
  78. @Test
  79. public void testSerialization() {
  80. NormalDistributionFunction2D f1 = new NormalDistributionFunction2D(1.0,
  81. 2.0);
  82. NormalDistributionFunction2D f2 = (NormalDistributionFunction2D)
  83. TestUtilities.serialised(f1);
  84. assertEquals(f1, f2);
  85. }
  86. /**
  87. * Objects that are equal should have the same hash code otherwise FindBugs
  88. * will tell on us...
  89. */
  90. @Test
  91. public void testHashCode() {
  92. NormalDistributionFunction2D f1 = new NormalDistributionFunction2D(1.0,
  93. 2.0);
  94. NormalDistributionFunction2D f2 = new NormalDistributionFunction2D(1.0,
  95. 2.0);
  96. assertEquals(f1.hashCode(), f2.hashCode());
  97. }
  98. }