|
6 | 6 |
|
7 | 7 | import kimimaro.intake
|
8 | 8 | import kimimaro.skeletontricks
|
| 9 | +from kimimaro.utility import moving_average |
9 | 10 |
|
10 | 11 | def test_empty_image():
|
11 | 12 | labels = np.zeros( (256, 256, 256), dtype=bool)
|
@@ -469,7 +470,37 @@ def test_cross_sectional_area():
|
469 | 470 | assert np.all(skel.cross_sectional_area == 9)
|
470 | 471 |
|
471 | 472 |
|
| 473 | +def test_moving_average(): |
472 | 474 |
|
| 475 | + data = np.array([]) |
| 476 | + assert np.all(moving_average(data, 1) == data) |
| 477 | + assert np.all(moving_average(data, 2) == data) |
| 478 | + |
| 479 | + data = np.array([1,1,1,1,1,1,1,1,1,1,1]) |
| 480 | + assert np.all(moving_average(data, 1) == data) |
| 481 | + |
| 482 | + data = np.array([1,1,1,1,1,1,1,1,1,1,1,1]) |
| 483 | + assert np.all(moving_average(data, 1) == data) |
| 484 | + |
| 485 | + data = np.array([1,1,1,1,1,10,1,1,1,1,1]) |
| 486 | + assert np.all(moving_average(data, 1) == data) |
| 487 | + |
| 488 | + data = np.array([1,1,1,1,1,1,1,1,1,1,1]) |
| 489 | + assert np.all(moving_average(data, 2) == data) |
| 490 | + |
| 491 | + data = np.array([0,1,1,1,1,1,1,1,1,1,0]) |
| 492 | + ans = np.array([ |
| 493 | + 0,0.5,1,1,1,1,1,1,1,1,0.5 |
| 494 | + ]) |
| 495 | + assert np.all(moving_average(data, 2) == ans) |
| 496 | + |
| 497 | + data = np.array([0,1,1,1,1,1,1,1,1,1,0]) |
| 498 | + ans = np.array([ |
| 499 | + 1/3,1/3,2/3,1,1,1,1,1,1,1,2/3 |
| 500 | + ]) |
| 501 | + res = moving_average(data, 3) |
| 502 | + assert np.all(res == ans) |
| 503 | + assert len(ans) == len(data) |
473 | 504 |
|
474 | 505 |
|
475 | 506 |
|
|
0 commit comments