From d58174e77f9da522228c0d84cd75e68ade226c06 Mon Sep 17 00:00:00 2001 From: Archan Patkar Date: Tue, 16 Jul 2019 00:46:41 +0530 Subject: [PATCH] math: moved fraction to math/fraction --- vlib/math/fraction_test.v | 100 +++++++++++++-------------- vlib/math/{ => fractions}/fraction.v | 6 +- 2 files changed, 54 insertions(+), 52 deletions(-) rename vlib/math/{ => fractions}/fraction.v (97%) diff --git a/vlib/math/fraction_test.v b/vlib/math/fraction_test.v index 49b7515800..da760fa516 100644 --- a/vlib/math/fraction_test.v +++ b/vlib/math/fraction_test.v @@ -1,141 +1,141 @@ -import math +import math.fractions as fractions // Results are verified using https://www.calculatorsoup.com/calculators/math/fractions.php fn test_fraction_creation() { - mut f1 := math.fraction(4,8) + mut f1 := fractions.fraction(4,8) assert f1.f64() == 0.5 assert f1.str().eq('4/8') - f1 = math.fraction(10,5) + f1 = fractions.fraction(10,5) assert f1.f64() == 2.0 assert f1.str().eq('10/5') - f1 = math.fraction(9,3) + f1 = fractions.fraction(9,3) assert f1.f64() == 3.0 assert f1.str().eq('9/3') } fn test_fraction_add() { - mut f1 := math.fraction(4,8) - mut f2 := math.fraction(5,10) + mut f1 := fractions.fraction(4,8) + mut f2 := fractions.fraction(5,10) mut sum := f1 + f2 assert sum.f64() == 1.0 assert sum.str().eq('80/80') - f1 = math.fraction(5,5) - f2 = math.fraction(8,8) + f1 = fractions.fraction(5,5) + f2 = fractions.fraction(8,8) sum = f1 + f2 assert sum.f64() == 2.0 assert sum.str().eq('80/40') - f1 = math.fraction(9,3) - f2 = math.fraction(1,3) + f1 = fractions.fraction(9,3) + f2 = fractions.fraction(1,3) sum = f1 + f2 println(sum.f64()) assert sum.str().eq('10/3') - f1 = math.fraction(3,7) - f2 = math.fraction(1,4) + f1 = fractions.fraction(3,7) + f2 = fractions.fraction(1,4) sum = f1 + f2 println(sum.f64()) assert sum.str().eq('19/28') } fn test_fraction_subtract() { - mut f1 := math.fraction(4,8) - mut f2 := math.fraction(5,10) + mut f1 := fractions.fraction(4,8) + mut f2 := fractions.fraction(5,10) mut diff := f2 - f1 assert diff.f64() == 0 assert diff.str().eq('0/80') - f1 = math.fraction(5,5) - f2 = math.fraction(8,8) + f1 = fractions.fraction(5,5) + f2 = fractions.fraction(8,8) diff = f2 - f1 assert diff.f64() == 0 assert diff.str().eq('0/40') - f1 = math.fraction(9,3) - f2 = math.fraction(1,3) + f1 = fractions.fraction(9,3) + f2 = fractions.fraction(1,3) diff = f1 - f2 println(diff.f64()) assert diff.str().eq('8/3') - f1 = math.fraction(3,7) - f2 = math.fraction(1,4) + f1 = fractions.fraction(3,7) + f2 = fractions.fraction(1,4) diff = f1 - f2 println(diff.f64()) assert diff.str().eq('5/28') } fn test_fraction_multiply() { - mut f1 := math.fraction(4,8) - mut f2 := math.fraction(5,10) + mut f1 := fractions.fraction(4,8) + mut f2 := fractions.fraction(5,10) mut product := f1.multiply(f2) assert product.f64() == 0.25 assert product.str().eq('20/80') - f1 = math.fraction(5,5) - f2 = math.fraction(8,8) + f1 = fractions.fraction(5,5) + f2 = fractions.fraction(8,8) product = f1.multiply(f2) assert product.f64() == 1.0 assert product.str().eq('40/40') - f1 = math.fraction(9,3) - f2 = math.fraction(1,3) + f1 = fractions.fraction(9,3) + f2 = fractions.fraction(1,3) product = f1.multiply(f2) assert product.f64() == 1.0 assert product.str().eq('9/9') - f1 = math.fraction(3,7) - f2 = math.fraction(1,4) + f1 = fractions.fraction(3,7) + f2 = fractions.fraction(1,4) product = f1.multiply(f2) println(product.f64()) assert product.str().eq('3/28') } fn test_fraction_divide() { - mut f1 := math.fraction(4,8) - mut f2 := math.fraction(5,10) + mut f1 := fractions.fraction(4,8) + mut f2 := fractions.fraction(5,10) mut re := f1.divide(f2) assert re.f64() == 1.0 assert re.str().eq('40/40') - f1 = math.fraction(5,5) - f2 = math.fraction(8,8) + f1 = fractions.fraction(5,5) + f2 = fractions.fraction(8,8) re = f1.divide(f2) assert re.f64() == 1.0 assert re.str().eq('40/40') - f1 = math.fraction(9,3) - f2 = math.fraction(1,3) + f1 = fractions.fraction(9,3) + f2 = fractions.fraction(1,3) re = f1.divide(f2) assert re.f64() == 9.0 assert re.str().eq('27/3') - f1 = math.fraction(3,7) - f2 = math.fraction(1,4) + f1 = fractions.fraction(3,7) + f2 = fractions.fraction(1,4) re = f1.divide(f2) println(re.f64()) assert re.str().eq('12/7') } fn test_fraction_reciprocal() { - mut f1 := math.fraction(4,8) + mut f1 := fractions.fraction(4,8) assert f1.reciprocal().str().eq('8/4') - f1 = math.fraction(5,10) + f1 = fractions.fraction(5,10) assert f1.reciprocal().str().eq('10/5') - f1 = math.fraction(5,5) + f1 = fractions.fraction(5,5) assert f1.reciprocal().str().eq('5/5') - f1 = math.fraction(8,8) + f1 = fractions.fraction(8,8) assert f1.reciprocal().str().eq('8/8') - f1 = math.fraction(9,3) + f1 = fractions.fraction(9,3) assert f1.reciprocal().str().eq('3/9') - f1 = math.fraction(1,3) + f1 = fractions.fraction(1,3) assert f1.reciprocal().str().eq('3/1') - f1 = math.fraction(3,7) + f1 = fractions.fraction(3,7) assert f1.reciprocal().str().eq('7/3') - f1 = math.fraction(1,4) + f1 = fractions.fraction(1,4) assert f1.reciprocal().str().eq('4/1') } fn test_fraction_equals() { - mut f1 := math.fraction(4,8) - mut f2 := math.fraction(5,10) + mut f1 := fractions.fraction(4,8) + mut f2 := fractions.fraction(5,10) assert f1.equals(f2) - f1 = math.fraction(1,2) - f2 = math.fraction(3,4) + f1 = fractions.fraction(1,2) + f2 = fractions.fraction(3,4) assert !f1.equals(f2) } fn test_gcd_and_reduce(){ - mut f := math.fraction(3, 9) + mut f := fractions.fraction(3, 9) assert f.gcd() == 3 - assert f.reduce().equals(math.fraction(1, 3)) + assert f.reduce().equals(fractions.fraction(1, 3)) } \ No newline at end of file diff --git a/vlib/math/fraction.v b/vlib/math/fractions/fraction.v similarity index 97% rename from vlib/math/fraction.v rename to vlib/math/fractions/fraction.v index cf1dfb6a85..ac8a41853a 100644 --- a/vlib/math/fraction.v +++ b/vlib/math/fractions/fraction.v @@ -2,7 +2,9 @@ // Use of this source code is governed by an MIT license // that can be found in the LICENSE file. -module math +module fractions + +import math // Fraction Struct struct Fraction { @@ -82,7 +84,7 @@ pub fn (f1 Fraction) reciprocal() Fraction { // Fraction method which gives greatest common divisor of numerator and denominator pub fn (f1 Fraction) gcd() i64 { - return gcd(f1.n, f1.d) + return math.gcd(f1.n, f1.d) } // Fraction method which reduces the fraction