v/vlib/math/math_test.v

49 lines
1.1 KiB
Go
Raw Normal View History

2019-06-29 17:24:55 +02:00
import math
fn test_gcd() {
2019-06-29 17:24:55 +02:00
assert math.gcd(6, 9) == 3
assert math.gcd(6, -9) == 3
assert math.gcd(-6, -9) == 3
assert math.gcd(0, 0) == 0
}
2019-06-29 17:24:55 +02:00
fn test_lcm() {
2019-06-29 17:24:55 +02:00
assert math.lcm(2, 3) == 6
assert math.lcm(-2, 3) == 6
assert math.lcm(-2, -3) == 6
assert math.lcm(0, 0) == 0
2019-06-29 17:24:55 +02:00
}
fn test_digits() {
digits_in_10th_base := math.digits(125, 10)
assert digits_in_10th_base[0] == 5
assert digits_in_10th_base[1] == 2
assert digits_in_10th_base[2] == 1
digits_in_16th_base := math.digits(15, 16)
assert digits_in_16th_base[0] == 15
negative_digits := math.digits(-4, 2)
assert negative_digits[2] == -1
}
fn test_factorial() {
2019-07-17 00:03:51 +02:00
assert math.factorial(12) == 479001600
assert math.factorial(5) == 120
assert math.factorial(0) == 1
}
fn test_erf() {
assert math.erf(0) == 0
2019-07-31 09:20:40 +02:00
assert (math.erf(1.5) + math.erf(-1.5)).eq(0)
assert math.erfc(0) == 1
2019-07-31 09:20:40 +02:00
assert (math.erf(2.5) + math.erfc(2.5)).eq(1)
assert (math.erfc(3.6) + math.erfc(-3.6)).eq(2)
}
fn test_gamma() {
assert math.gamma(1) == 1
assert math.gamma(5) == 24
assert math.log_gamma(4.5) == math.log(math.gamma(4.5))
}