mirror of
				https://github.com/pocketpy/pocketpy
				synced 2025-10-22 20:40:18 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			197 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			197 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from array2d import array2d
 | |
| 
 | |
| # test error args for __init__
 | |
| try:
 | |
|     a = array2d(0, 0)
 | |
|     exit(0)
 | |
| except ValueError:
 | |
|     pass
 | |
| 
 | |
| # test callable constructor
 | |
| a = array2d(2, 4, lambda: 0)
 | |
| 
 | |
| assert a.width == a.n_cols == 2
 | |
| assert a.height == a.n_rows == 4
 | |
| assert a.numel == 8
 | |
| 
 | |
| # test is_valid
 | |
| assert a.is_valid(0, 0)
 | |
| assert a.is_valid(1, 3)
 | |
| assert not a.is_valid(2, 0)
 | |
| assert not a.is_valid(0, 4)
 | |
| assert not a.is_valid(-1, 0)
 | |
| assert not a.is_valid(0, -1)
 | |
| 
 | |
| # test get
 | |
| assert a.get(0, 0) == 0
 | |
| assert a.get(1, 3) == 0
 | |
| assert a.get(2, 0) is None
 | |
| assert a.get(0, 4, 'S') == 'S'
 | |
| 
 | |
| # test __getitem__
 | |
| assert a[0, 0] == 0
 | |
| assert a[1, 3] == 0
 | |
| try:
 | |
|     a[2, 0]
 | |
|     exit(1)
 | |
| except IndexError:
 | |
|     pass
 | |
| 
 | |
| # test __setitem__
 | |
| a[0, 0] = 5
 | |
| assert a[0, 0] == 5
 | |
| a[1, 3] = 6
 | |
| assert a[1, 3] == 6
 | |
| try:
 | |
|     a[0, -1] = 7
 | |
|     exit(1)
 | |
| except IndexError:
 | |
|     pass
 | |
| 
 | |
| # test __iter__
 | |
| a_list = [[5, 0], [0, 0], [0, 0], [0, 6]]
 | |
| assert a_list == a.tolist()
 | |
| 
 | |
| # test __len__
 | |
| assert len(a) == 4*2
 | |
| 
 | |
| # test __eq__
 | |
| x = array2d(2, 4, default=0)
 | |
| b = array2d(2, 4, default=0)
 | |
| assert x == b
 | |
| 
 | |
| b[0, 0] = 1
 | |
| assert x != b
 | |
| 
 | |
| # test __repr__
 | |
| assert repr(a) == f'array2d(2, 4)'
 | |
| 
 | |
| # test map
 | |
| c = a.map(lambda x: x + 1)
 | |
| assert c.tolist() == [[6, 1], [1, 1], [1, 1], [1, 7]]
 | |
| assert a.tolist() == [[5, 0], [0, 0], [0, 0], [0, 6]]
 | |
| assert c.width == c.n_cols == 2
 | |
| assert c.height == c.n_rows == 4
 | |
| assert c.numel == 8
 | |
| 
 | |
| # test copy
 | |
| d = c.copy()
 | |
| assert d == c and d is not c
 | |
| 
 | |
| # test fill_
 | |
| d.fill_(-3)
 | |
| assert d == array2d(2, 4, default=-3)
 | |
| 
 | |
| # test apply_
 | |
| d.apply_(lambda x: x + 3)
 | |
| assert d == array2d(2, 4, default=0)
 | |
| 
 | |
| # test copy_
 | |
| a.copy_(d)
 | |
| assert a == d and a is not d
 | |
| x = array2d(2, 4, default=0)
 | |
| x.copy_(d)
 | |
| assert x == d and x is not d
 | |
| x.copy_([1, 2, 3, 4, 5, 6, 7, 8])
 | |
| assert x.tolist() == [[1, 2], [3, 4], [5, 6], [7, 8]]
 | |
| 
 | |
| # test alive_neighbors
 | |
| a = array2d(3, 3, default=0)
 | |
| a[1, 1] = 1
 | |
| """     Moore    von Neumann
 | |
| 0 0 0   1 1 1    0 1 0
 | |
| 0 1 0   1 0 1    1 0 1
 | |
| 0 0 0   1 1 1    0 1 0
 | |
| """
 | |
| moore_result = array2d(3, 3, default=1)
 | |
| moore_result[1, 1] = 0
 | |
| 
 | |
| von_neumann_result = array2d(3, 3, default=0)
 | |
| von_neumann_result[0, 1] = von_neumann_result[1, 0] = von_neumann_result[1, 2] = von_neumann_result[2, 1] = 1
 | |
| 
 | |
| _0 = a.count_neighbors(1, 'Moore')
 | |
| assert _0 == moore_result
 | |
| _1 = a.count_neighbors(1, 'von Neumann')
 | |
| assert _1 == von_neumann_result
 | |
| 
 | |
| # test slice get
 | |
| a = array2d(5, 5, default=0)
 | |
| b = array2d(3, 2, default=1)
 | |
| 
 | |
| assert a[1:4, 1:4] == array2d(3, 3, default=0)
 | |
| assert a[1:4, 1:3] == array2d(3, 2, default=0)
 | |
| assert a[1:4, 1:3] != b
 | |
| a[1:4, 1:3] = b
 | |
| assert a[1:4, 1:3] == b
 | |
| """
 | |
| 0 0 0 0 0
 | |
| 0 1 1 1 0
 | |
| 0 1 1 1 0
 | |
| 0 0 0 0 0
 | |
| 0 0 0 0 0
 | |
| """
 | |
| assert a.count(1) == 3*2
 | |
| 
 | |
| assert a.find_bounding_rect(1) == (1, 1, 3, 2)
 | |
| assert a.find_bounding_rect(0) == (0, 0, 5, 5)
 | |
| 
 | |
| try:
 | |
|     a.find_bounding_rect(2)
 | |
|     exit(1)
 | |
| except ValueError:
 | |
|     pass
 | |
| 
 | |
| a = array2d(3, 2, default='?')
 | |
| # int/float/str/bool/None
 | |
| 
 | |
| for value in [0, 0.0, '0', False, None]:
 | |
|     a[0:2, 0:1] = value
 | |
|     assert a[2, 1] == '?'
 | |
|     assert a[0, 0] == value
 | |
| 
 | |
| a[:, :] = 3
 | |
| assert a == array2d(3, 2, default=3)
 | |
| 
 | |
| try:
 | |
|     a[:, :] = array2d(1, 1)
 | |
|     exit(1)
 | |
| except ValueError:
 | |
|     pass
 | |
| 
 | |
| try:
 | |
|     a[:, :] = ...
 | |
|     exit(1)
 | |
| except TypeError:
 | |
|     pass
 | |
| 
 | |
| a = array2d(3, 4, default=1)
 | |
| for i, j, x in a:
 | |
|     assert a[i, j] == x
 | |
| 
 | |
| assert len(a) == a.numel
 | |
| 
 | |
| # test _get and _set
 | |
| a = array2d(3, 4, default=1)
 | |
| assert a.unsafe_get(0, 0) == 1
 | |
| a.unsafe_set(0, 0, 2)
 | |
| assert a.unsafe_get(0, 0) == 2
 | |
| 
 | |
| # stackoverflow bug due to recursive mark-and-sweep
 | |
| # class Cell:
 | |
| #     neighbors: list['Cell']
 | |
| 
 | |
| # cells: array2d[Cell] = array2d(192, 108, default=Cell)
 | |
| # OutOfBounds = Cell()
 | |
| # for x, y, cell in cells:
 | |
| #     cell.neighbors = [
 | |
| #         cells.get(x-1, y-1, OutOfBounds),
 | |
| #         cells.get(x  , y-1, OutOfBounds),
 | |
| #         cells.get(x+1, y-1, OutOfBounds),
 | |
| #         cells.get(x-1, y  , OutOfBounds),
 | |
| #         cells.get(x+1, y  , OutOfBounds),
 | |
| #         cells.get(x  , y+1, OutOfBounds),
 | |
| #         cells.get(x+1, y+1, OutOfBounds),
 | |
| #     ]
 | |
| 
 | |
| # import gc
 | |
| # gc.collect() |