|
| 1 | +import tkinter as tk |
1 | 2 | import unittest
|
2 | 3 |
|
3 | 4 | import h5py
|
| 5 | +import numpy as np |
4 | 6 |
|
5 | 7 | from diffpy.fourigui.fourigui import Gui
|
6 | 8 |
|
@@ -146,5 +148,81 @@ def test_fft_111(self):
|
146 | 148 | self.assertTrue(self.test_gui.transformed and self.test_gui.transcutted)
|
147 | 149 |
|
148 | 150 |
|
| 151 | +def test_applycutoff(mocker): |
| 152 | + root = tk.Tk() |
| 153 | + fg = Gui() |
| 154 | + # qmin of 1 and qmax of 2 is expected to leave the central pixel and corner |
| 155 | + # pixels as NaN's |
| 156 | + mocker.patch.object(fg.qminentry, "get", return_value=1.0) |
| 157 | + mocker.patch.object(fg.qmaxentry, "get", return_value=2.0) |
| 158 | + mocker.patch.object(fg, "plot_plane") # we don't want it to plot anything so intercept |
| 159 | + fg.cutted = False |
| 160 | + fg.cube = np.ones((5, 5, 5)) |
| 161 | + expected_ones = np.ones((5, 5, 5)) |
| 162 | + expected_recip = np.array( |
| 163 | + [ |
| 164 | + [ |
| 165 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 166 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 167 | + [np.nan, np.nan, 1, np.nan, np.nan], |
| 168 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 169 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 170 | + ], |
| 171 | + [ |
| 172 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 173 | + [np.nan, 1, 1, 1, np.nan], |
| 174 | + [np.nan, 1, 1, 1, np.nan], |
| 175 | + [np.nan, 1, 1, 1, np.nan], |
| 176 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 177 | + ], |
| 178 | + [ |
| 179 | + [np.nan, np.nan, 1, np.nan, np.nan], |
| 180 | + [np.nan, 1, 1, 1, np.nan], |
| 181 | + [1, 1, np.nan, 1, 1], |
| 182 | + [np.nan, 1, 1, 1, np.nan], |
| 183 | + [np.nan, np.nan, 1, np.nan, np.nan], |
| 184 | + ], |
| 185 | + [ |
| 186 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 187 | + [np.nan, 1, 1, 1, np.nan], |
| 188 | + [np.nan, 1, 1, 1, np.nan], |
| 189 | + [np.nan, 1, 1, 1, np.nan], |
| 190 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 191 | + ], |
| 192 | + [ |
| 193 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 194 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 195 | + [np.nan, np.nan, 1, np.nan, np.nan], |
| 196 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 197 | + [np.nan, np.nan, np.nan, np.nan, np.nan], |
| 198 | + ], |
| 199 | + ] |
| 200 | + ) |
| 201 | + # test the case where fg.space is 0 |
| 202 | + fg.applycutoff() |
| 203 | + np.testing.assert_array_equal(fg.cube_reci, expected_ones) |
| 204 | + np.testing.assert_array_equal(fg.cube_recicut, expected_recip) |
| 205 | + root.destroy() # Clean up Tkinter instance |
| 206 | + |
| 207 | + # test the case where fg.space is 1 |
| 208 | + root = tk.Tk() |
| 209 | + fg = Gui() |
| 210 | + # qmin of 1 and qmax of 2 is expected to leave the central pixel and corner |
| 211 | + # pixels as NaN's |
| 212 | + mocker.patch.object(fg.qminentry, "get", return_value=1) |
| 213 | + mocker.patch.object(fg.qmaxentry, "get", return_value=2) |
| 214 | + mocker.patch.object( |
| 215 | + fg, "fft" |
| 216 | + ) # we don't want it to do the fft so intercept. Should be tested separately (fixme). |
| 217 | + fg.cutted = False |
| 218 | + fg.cube_reci = np.ones((5, 5, 5)) |
| 219 | + fg.cube = np.ones((5, 5, 5)) |
| 220 | + mocker.patch.object(fg.space, "get", return_value=1) |
| 221 | + fg.applycutoff() |
| 222 | + np.testing.assert_array_equal(fg.cube_real, expected_ones) |
| 223 | + np.testing.assert_array_equal(fg.cube_recicut, expected_recip) |
| 224 | + root.destroy() # Clean up Tkinter instance |
| 225 | + |
| 226 | + |
149 | 227 | if __name__ == "__main__":
|
150 | 228 | unittest.main()
|
0 commit comments