mirror of
https://github.com/wassname/simpeg.git
synced 2026-06-28 00:30:01 +08:00
137 lines
3.1 KiB
Python
137 lines
3.1 KiB
Python
import unittest
|
|
from SimPEG.Utils import Zero, Identity, sdiag
|
|
from SimPEG import np, sp
|
|
|
|
class Tests(unittest.TestCase):
|
|
|
|
def test_zero(self):
|
|
z = Zero()
|
|
assert z == 0
|
|
assert not (z < 0)
|
|
assert z <= 0
|
|
assert not (z > 0)
|
|
assert z >= 0
|
|
assert +z == z
|
|
assert -z == z
|
|
assert z + 1 == 1
|
|
assert z + 3 +z == 3
|
|
assert z - 3 == -3
|
|
assert z - 3 -z == -3
|
|
assert 3*z == 0
|
|
assert z*3 == 0
|
|
assert z/3 == 0
|
|
|
|
a = 1
|
|
a += z
|
|
assert a == 1
|
|
a = 1
|
|
a += z
|
|
assert a == 1
|
|
self.assertRaises(ZeroDivisionError, lambda:3/z)
|
|
|
|
def test_mat_zero(self):
|
|
z = Zero()
|
|
S = sdiag(np.r_[2,3])
|
|
assert S*z == 0
|
|
|
|
def test_one(self):
|
|
o = Identity()
|
|
assert o == 1
|
|
assert not (o < 1)
|
|
assert o <= 1
|
|
assert not (o > 1)
|
|
assert o >= 1
|
|
o = -o
|
|
assert o == -1
|
|
assert not (o < -1)
|
|
assert o <= -1
|
|
assert not (o > -1)
|
|
assert o >= -1
|
|
assert -(-o)*o == -o
|
|
o = Identity()
|
|
assert +o == o
|
|
assert -o == -o
|
|
assert o*3 == 3
|
|
assert -o*3 == -3
|
|
assert -o*o == -1
|
|
assert -o*o*-o == 1
|
|
assert -o + 3 == 2
|
|
assert 3 + -o == 2
|
|
|
|
assert -o - 3 == -4
|
|
assert o - 3 == -2
|
|
assert 3 - -o == 4
|
|
assert 3 - o == 2
|
|
|
|
assert o/2 == 0
|
|
assert o/2. == 0.5
|
|
assert -o/2 == -1
|
|
assert -o/2. == -0.5
|
|
assert 2/o == 2
|
|
assert 2/-o == -2
|
|
|
|
|
|
def test_mat_one(self):
|
|
|
|
o = Identity()
|
|
S = sdiag(np.r_[2,3])
|
|
def check(exp,ans):
|
|
assert np.all((exp).todense() == ans)
|
|
|
|
check(S * o, [[2,0],[0,3]])
|
|
check(o * S, [[2,0],[0,3]])
|
|
check(S * -o, [[-2,0],[0,-3]])
|
|
check(-o * S, [[-2,0],[0,-3]])
|
|
check(S/o, [[2,0],[0,3]])
|
|
check(S/-o, [[-2,0],[0,-3]])
|
|
self.assertRaises(NotImplementedError, lambda:o/S)
|
|
|
|
check(S + o, [[3,0],[0,4]])
|
|
check(o + S, [[3,0],[0,4]])
|
|
|
|
check(S + - o, [[1,0],[0,2]])
|
|
check(S - o, [[1,0],[0,2]])
|
|
check(- o + S, [[1,0],[0,2]])
|
|
|
|
def test_mat_shape(self):
|
|
o = Identity()
|
|
S = sdiag(np.r_[2,3])[:1,:]
|
|
self.assertRaises(ValueError, lambda:S + o)
|
|
def check(exp,ans):
|
|
assert np.all((exp).todense() == ans)
|
|
check(S * o, [[2,0]])
|
|
check(S * -o, [[-2,0]])
|
|
|
|
def test_numpy_one(self):
|
|
o = Identity()
|
|
n = np.r_[2.,3]
|
|
assert np.all(n+1 == n+o)
|
|
assert np.all(1+n == o+n)
|
|
assert np.all(n-1 == n-o)
|
|
assert np.all(1-n == o-n)
|
|
assert np.all(n/1 == n/o)
|
|
assert np.all(n/-1 == n/-o)
|
|
assert np.all(1/n == o/n)
|
|
assert np.all(-1/n == -o/n)
|
|
assert np.all(n*1 == n*o)
|
|
assert np.all(n*-1 == n*-o)
|
|
assert np.all(1*n == o*n)
|
|
assert np.all(-1*n == -o*n)
|
|
|
|
def test_both(self):
|
|
z = Zero()
|
|
o = Identity()
|
|
assert o*z == 0
|
|
assert o*z + o == 1
|
|
assert o-z == 1
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|
|
|
|
|
|
|
|
|
|
|