1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00
v/vlib/math/math_test.v

62 lines
1.2 KiB
V
Raw Normal View History

2019-12-19 22:16:03 +03:00
module math
2019-06-29 18:24:55 +03:00
fn test_gcd() {
2019-12-19 22:16:03 +03:00
assert gcd(6, 9) == 3
assert gcd(6, -9) == 3
assert gcd(-6, -9) == 3
assert gcd(0, 0) == 0
}
2019-06-29 18:24:55 +03:00
fn test_lcm() {
2019-12-19 22:16:03 +03:00
assert lcm(2, 3) == 6
assert lcm(-2, 3) == 6
assert lcm(-2, -3) == 6
assert lcm(0, 0) == 0
2019-06-29 18:24:55 +03:00
}
fn test_digits() {
2019-12-19 22:16:03 +03:00
digits_in_10th_base := digits(125, 10)
assert digits_in_10th_base[0] == 5
assert digits_in_10th_base[1] == 2
assert digits_in_10th_base[2] == 1
2019-12-19 22:16:03 +03:00
digits_in_16th_base := digits(15, 16)
assert digits_in_16th_base[0] == 15
2019-12-19 22:16:03 +03:00
negative_digits := digits(-4, 2)
assert negative_digits[2] == -1
}
fn test_factorial() {
2019-12-19 22:16:03 +03:00
assert factorial(12) == 479001600
assert factorial(5) == 120
assert factorial(0) == 1
}
fn test_erf() {
2019-12-19 22:16:03 +03:00
assert erf(0) == 0
assert erf(1.5) + erf(-1.5) == 0
assert erfc(0) == 1
assert erf(2.5) + erfc(2.5) == 1
assert erfc(3.6) + erfc(-3.6) == 2
}
fn test_gamma() {
2019-12-19 22:16:03 +03:00
assert gamma(1) == 1
assert gamma(5) == 24
2019-11-28 11:46:52 +03:00
sval := '2.453737'
2019-12-19 22:16:03 +03:00
assert log_gamma(4.5).str() == sval
assert log(gamma(4.5)).str() == sval
assert abs( log_gamma(4.5) - log(gamma(4.5)) ) < 0.000001
// assert log_gamma(4.5) == log(gamma(4.5)) /* <-- fails on alpine/musl
}
2019-11-06 18:04:48 +03:00
fn test_mod() {
assert 4 % 2 == 0
x := 2
assert u64(5) % x == 1
2019-11-06 20:47:03 +03:00
mut a := 10
a %= 2
assert a == 0
2019-12-19 22:16:03 +03:00
}