From 89d3075f88ee7b466eb290c0485376e088fbcd7c Mon Sep 17 00:00:00 2001 From: Ulises Jeremias Cornejo Fandos Date: Mon, 30 Dec 2019 01:24:30 -0300 Subject: [PATCH] math: update complex operators for multiplication and division --- vlib/math/complex/complex.v | 28 +++++++++++++--------------- vlib/math/complex/complex_test.v | 16 ++++++++-------- 2 files changed, 21 insertions(+), 23 deletions(-) diff --git a/vlib/math/complex/complex.v b/vlib/math/complex/complex.v index 8f9c2c422e..be936cf1cc 100644 --- a/vlib/math/complex/complex.v +++ b/vlib/math/complex/complex.v @@ -55,23 +55,21 @@ pub fn (c1 Complex) - (c2 Complex) Complex { } // Complex Multiplication c1 * c2 -// Currently Not Supported -// pub fn (c1 Complex) * (c2 Complex) Complex { -// return Complex{ -// (c1.re * c2.re) + ((c1.im * c2.im) * -1), -// (c1.re * c2.im) + (c1.im * c2.re) -// } -// } +pub fn (c1 Complex) * (c2 Complex) Complex { + return Complex{ + (c1.re * c2.re) + ((c1.im * c2.im) * -1), + (c1.re * c2.im) + (c1.im * c2.re) + } +} // Complex Division c1 / c2 -// Currently Not Supported -// pub fn (c1 Complex) / (c2 Complex) Complex { -// denom := (c2.re * c2.re) + (c2.im * c2.im) -// return Complex { -// ((c1.re * c2.re) + ((c1.im * -c2.im) * -1))/denom, -// ((c1.re * -c2.im) + (c1.im * c2.re))/denom -// } -// } +pub fn (c1 Complex) / (c2 Complex) Complex { + denom := (c2.re * c2.re) + (c2.im * c2.im) + return Complex { + ((c1.re * c2.re) + ((c1.im * -c2.im) * -1))/denom, + ((c1.re * -c2.im) + (c1.im * c2.re))/denom + } +} // Complex Addition c1.add(c2) pub fn (c1 Complex) add(c2 Complex) Complex { diff --git a/vlib/math/complex/complex_test.v b/vlib/math/complex/complex_test.v index 42c70a641d..792996ed2d 100644 --- a/vlib/math/complex/complex_test.v +++ b/vlib/math/complex/complex_test.v @@ -48,19 +48,19 @@ fn test_complex_multiplication() { // https://www.khanacademy.org/math/precalculus/imaginary-and-complex-numbers mut c1 := cmplx.complex(1,2) mut c2 := cmplx.complex(1,-4) - mut result := c1.multiply(c2) + mut result := c1 * c2 assert result.equals(cmplx.complex(9,-2)) c1 = cmplx.complex(-4,-4) c2 = cmplx.complex(-5,-3) - result = c1.multiply(c2) + result = c1 * c2 assert result.equals(cmplx.complex(8,32)) c1 = cmplx.complex(4,4) c2 = cmplx.complex(-2,-5) - result = c1.multiply(c2) + result = c1 * c2 assert result.equals(cmplx.complex(12,-28)) c1 = cmplx.complex(2,-2) c2 = cmplx.complex(4,-4) - result = c1.multiply(c2) + result = c1 * c2 assert result.equals(cmplx.complex(0,-16)) } @@ -69,19 +69,19 @@ fn test_complex_division() { // https://www.khanacademy.org/math/precalculus/imaginary-and-complex-numbers mut c1 := cmplx.complex(-9,-6) mut c2 := cmplx.complex(-3,-2) - mut result := c1.divide(c2) + mut result := c1 / c2 assert result.equals(cmplx.complex(3,0)) c1 = cmplx.complex(-23,11) c2 = cmplx.complex(5,1) - result = c1.divide(c2) + result = c1 / c2 assert result.equals(cmplx.complex(-4,3)) c1 = cmplx.complex(8,-2) c2 = cmplx.complex(-4,1) - result = c1.divide(c2) + result = c1 / c2 assert result.equals(cmplx.complex(-2,0)) c1 = cmplx.complex(11,24) c2 = cmplx.complex(-4,-1) - result = c1.divide(c2) + result = c1 / c2 assert result.equals(cmplx.complex(-4,-5)) }