-
Notifications
You must be signed in to change notification settings - Fork 1.5k
Expand file tree
/
Copy pathtest_rand_scale_intensity_fixed_meand.py
More file actions
61 lines (52 loc) · 2.38 KB
/
test_rand_scale_intensity_fixed_meand.py
File metadata and controls
61 lines (52 loc) · 2.38 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# Copyright (c) MONAI Consortium
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from __future__ import annotations
import unittest
import numpy as np
from monai.transforms import RandScaleIntensityFixedMeand
from tests.test_utils import TEST_NDARRAYS, NumpyImageTestCase2D, assert_allclose
class TestRandScaleIntensityFixedMeand(NumpyImageTestCase2D):
def test_value(self):
key = "img"
for p in TEST_NDARRAYS:
scaler = RandScaleIntensityFixedMeand(keys=[key], factors=0.5, prob=1.0)
scaler.set_random_state(seed=0)
result = scaler({key: p(self.imt)})
np.random.seed(0)
# simulate the randomize function of transform
np.random.random()
im = self.imt
mn = im.mean()
im = im - mn
expected = (1 + np.random.uniform(low=-0.5, high=0.5)) * im
expected = expected + mn
assert_allclose(result[key], p(expected), type_test="tensor", atol=1e-6)
def test_channel_wise(self):
key = "img"
for p in TEST_NDARRAYS:
scaler = RandScaleIntensityFixedMeand(keys=[key], factors=0.5, prob=1.0, channel_wise=True)
scaler.set_random_state(seed=0)
im = p(self.imt)
result = scaler({key: im})
np.random.seed(0)
# simulate the randomize function of transform
np.random.random()
channel_num = self.imt.shape[0]
factor = np.random.uniform(low=-0.5, high=0.5, size=(channel_num,))
expected = np.stack(
[
np.asarray((self.imt[i] - self.imt[i].mean()) * (1 + factor[i]) + self.imt[i].mean())
for i in range(channel_num)
]
).astype(np.float32)
assert_allclose(result[key], p(expected), atol=1e-4, rtol=1e-4, type_test=False)
if __name__ == "__main__":
unittest.main()