YassinHajaj 0bf12a690c BAEL-3204 (#8085)
* BAEL-3204

* BAEL-3204
2019-11-15 15:15:43 -08:00

40 lines
1.4 KiB
Kotlin

package com.baeldung.simplelinearregression
import org.junit.Assert.assertEquals
import org.junit.jupiter.api.Test
class SimpleLinearRegressionUnitTest {
@Test
fun givenAProperDataSetWhenFedToASimpleLinearRegressionModelThenItPredictsCorrectly() {
val xs = arrayListOf(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
val ys = arrayListOf(25, 35, 49, 60, 75, 90, 115, 130, 150, 200)
val model = SimpleLinearRegression(xs, ys)
val predictionOne = model.predict(2.5)
assertEquals(38.99, predictionOne, 0.01)
val predictionTwo = model.predict(7.5)
assertEquals(128.84, predictionTwo, 0.01)
}
@Test
fun givenAPredictableDataSetWhenCalculatingTheLossFunctionThenTheModelIsConsideredReliable() {
val xs = arrayListOf(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
val ys = arrayListOf(25, 35, 49, 60, 75, 90, 115, 130, 150, 200)
val model = SimpleLinearRegression(xs, ys)
assertEquals(0.95, model.calculateRSquared(), 0.01)
}
@Test
fun givenAnUnpredictableDataSetWhenCalculatingTheLossFunctionThenTheModelIsConsideredUnreliable() {
val xs = arrayListOf(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
val ys = arrayListOf(200, 0, 200, 0, 0, 0, -115, 1000, 0, 1)
val model = SimpleLinearRegression(xs, ys)
assertEquals(0.01, model.calculateRSquared(), 0.01)
}
}