2021-03-23 18:13:35 +03:00
|
|
|
/*
|
2022-08-19 15:59:13 +03:00
|
|
|
* Copyright 2018-2022 KMath contributors.
|
2021-11-16 14:04:44 +03:00
|
|
|
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
|
2021-03-23 18:13:35 +03:00
|
|
|
*/
|
|
|
|
|
2021-02-18 11:17:28 +03:00
|
|
|
package space.kscience.kmath.testutils
|
2020-08-12 17:18:47 +03:00
|
|
|
|
2021-02-18 11:17:28 +03:00
|
|
|
import space.kscience.kmath.operations.Field
|
|
|
|
import space.kscience.kmath.operations.invoke
|
2020-08-12 17:18:47 +03:00
|
|
|
import kotlin.test.assertEquals
|
|
|
|
import kotlin.test.assertNotEquals
|
|
|
|
|
2022-06-14 16:27:32 +03:00
|
|
|
public class FieldVerifier<T, out A : Field<T>>(
|
2021-03-08 21:03:48 +03:00
|
|
|
algebra: A, a: T, b: T, c: T, x: Number,
|
|
|
|
) : RingVerifier<T, A>(algebra, a, b, c, x) {
|
2020-08-12 17:18:47 +03:00
|
|
|
|
|
|
|
override fun verify() {
|
|
|
|
super.verify()
|
|
|
|
|
|
|
|
algebra {
|
2020-12-20 16:48:38 +03:00
|
|
|
assertEquals(a + b, b + a, "Addition in $algebra is not commutative.")
|
|
|
|
assertEquals(a * b, b * a, "Multiplication in $algebra is not commutative.")
|
2020-08-12 17:18:47 +03:00
|
|
|
assertNotEquals(a / b, b / a, "Division in $algebra is not anti-commutative.")
|
|
|
|
assertNotEquals((a / b) / c, a / (b / c), "Division in $algebra is associative.")
|
|
|
|
assertEquals((a + b) / c, (a / c) + (b / c), "Division in $algebra is not right-distributive.")
|
|
|
|
assertEquals(a, a / one, "$one in $algebra is not neutral division element.")
|
|
|
|
assertEquals(one, one / a * a, "$algebra does not provide single reciprocal element.")
|
|
|
|
assertEquals(zero / a, zero, "$zero in $algebra is not left neutral element for division.")
|
|
|
|
assertEquals(-one, a / (-a), "Division by sign reversal element in $algebra does not give ${-one}.")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|