|
24 | 24 | }, |
25 | 25 | { |
26 | 26 | "cell_type": "code", |
27 | | - "execution_count": 2, |
| 27 | + "execution_count": 1, |
28 | 28 | "metadata": {}, |
29 | 29 | "outputs": [], |
30 | 30 | "source": [ |
|
40 | 40 | }, |
41 | 41 | { |
42 | 42 | "cell_type": "code", |
43 | | - "execution_count": 3, |
| 43 | + "execution_count": 2, |
44 | 44 | "metadata": {}, |
45 | 45 | "outputs": [], |
46 | 46 | "source": [ |
47 | 47 | "import os\n", |
48 | 48 | "import torch\n", |
49 | 49 | "\n", |
| 50 | + "from pathlib import Path\n", |
| 51 | + "\n", |
50 | 52 | "from monai.apps import download_and_extract\n", |
51 | 53 | "from monai.apps.auto3dseg import (\n", |
52 | 54 | " DataAnalyzer,\n", |
|
69 | 71 | }, |
70 | 72 | { |
71 | 73 | "cell_type": "code", |
72 | | - "execution_count": 4, |
| 74 | + "execution_count": 3, |
73 | 75 | "metadata": {}, |
74 | 76 | "outputs": [ |
75 | | - { |
76 | | - "name": "stderr", |
77 | | - "output_type": "stream", |
78 | | - "text": [ |
79 | | - "Task09_Spleen.tar: 1.50GB [00:43, 36.7MB/s] \n" |
80 | | - ] |
81 | | - }, |
82 | 77 | { |
83 | 78 | "name": "stdout", |
84 | 79 | "output_type": "stream", |
85 | 80 | "text": [ |
86 | | - "2022-09-29 03:49:02,357 - INFO - Downloaded: Task09_Spleen.tar\n", |
87 | | - "2022-09-29 03:49:02,359 - INFO - Expected md5 is None, skip md5 check for file Task09_Spleen.tar.\n", |
88 | | - "2022-09-29 03:49:02,359 - INFO - Writing into directory: ./.\n" |
| 81 | + "2022-10-18 08:14:33,395 - INFO - Expected md5 is None, skip md5 check for file Task04_Hippocampus.tar.\n", |
| 82 | + "2022-10-18 08:14:33,395 - INFO - File exists: Task04_Hippocampus.tar, skipped downloading.\n", |
| 83 | + "2022-10-18 08:14:33,396 - INFO - Non-empty folder exists in Task04_Hippocampus, skipped extracting.\n" |
89 | 84 | ] |
90 | 85 | } |
91 | 86 | ], |
92 | 87 | "source": [ |
93 | | - "root = \"./\"\n", |
| 88 | + "root = str(Path(\".\"))\n", |
94 | 89 | "work_dir = os.path.join(root, 'ref_api_work_dir')\n", |
95 | 90 | "if not os.path.isdir(work_dir):\n", |
96 | 91 | " os.makedirs(work_dir)\n", |
97 | 92 | "\n", |
98 | | - "msd_task = \"Task09_Spleen\"\n", |
| 93 | + "msd_task = \"Task04_Hippocampus\"\n", |
99 | 94 | "dataroot = os.path.join(root, msd_task)\n", |
100 | 95 | "datalist_file = os.path.join(\"..\", \"tasks\", \"msd\", msd_task, \"msd_\" + msd_task.lower() + \"_folds.json\")\n", |
101 | 96 | "\n", |
|
114 | 109 | }, |
115 | 110 | { |
116 | 111 | "cell_type": "code", |
117 | | - "execution_count": 5, |
| 112 | + "execution_count": 4, |
118 | 113 | "metadata": {}, |
119 | 114 | "outputs": [], |
120 | 115 | "source": [ |
|
157 | 152 | "name": "stderr", |
158 | 153 | "output_type": "stream", |
159 | 154 | "text": [ |
160 | | - "100%|██████████| 40/40 [01:34<00:00, 2.37s/it]" |
161 | | - ] |
162 | | - }, |
163 | | - { |
164 | | - "name": "stdout", |
165 | | - "output_type": "stream", |
166 | | - "text": [ |
167 | | - "2022-09-29 01:43:36,891 - WARNING - Data is not completely uniform. MONAI transforms may provide unexpected result\n" |
168 | | - ] |
169 | | - }, |
170 | | - { |
171 | | - "name": "stderr", |
172 | | - "output_type": "stream", |
173 | | - "text": [ |
174 | | - "\n" |
| 155 | + "100%|██████████| 30/30 [00:00<00:00, 71.04it/s]\n" |
175 | 156 | ] |
176 | 157 | } |
177 | 158 | ], |
|
188 | 169 | "Besides the Python API call, user can also use command line interface (CLI) provided by the user's OS. One example is the following bash commands:\n", |
189 | 170 | "\n", |
190 | 171 | "```bash\n", |
191 | | - "python -m monai.apps.auto3dseg DataAnalyzer get_all_case_stats --datalist=\"../tasks/msd/Task09_Spleen/msd_task09_spleen_folds.json\" --dataroot=\"./Task09_Spleen\" --output_path=\"./ref_api_work_dir/data_stats.yaml\"\n", |
| 172 | + "python -m monai.apps.auto3dseg DataAnalyzer get_all_case_stats --datalist=\"../tasks/msd/Task04_Hippocampus/msd_task04_hippocampus_folds.json\" --dataroot=\"./Task04_Hippocampus\" --output_path=\"./ref_api_work_dir/data_stats.yaml\"\n", |
192 | 173 | "```" |
193 | 174 | ] |
194 | 175 | }, |
|
214 | 195 | "name": "stderr", |
215 | 196 | "output_type": "stream", |
216 | 197 | "text": [ |
217 | | - "algo_templates.tar.gz: 100%|██████████| 280k/280k [00:00<00:00, 607kB/s] " |
| 198 | + "algo_templates.tar.gz: 296kB [00:01, 247kB/s] " |
218 | 199 | ] |
219 | 200 | }, |
220 | 201 | { |
221 | 202 | "name": "stdout", |
222 | 203 | "output_type": "stream", |
223 | 204 | "text": [ |
224 | | - "2022-09-29 01:43:37,829 - INFO - Downloaded: /tmp/tmpodiia3qq/algo_templates.tar.gz\n", |
225 | | - "2022-09-29 01:43:37,830 - INFO - Expected md5 is None, skip md5 check for file /tmp/tmpodiia3qq/algo_templates.tar.gz.\n", |
226 | | - "2022-09-29 01:43:37,830 - INFO - Writing into directory: ./ref_api_work_dir.\n" |
| 205 | + "2022-10-18 08:14:35,703 - INFO - Downloaded: /tmp/tmps2pt5u7y/algo_templates.tar.gz\n", |
| 206 | + "2022-10-18 08:14:35,705 - INFO - Expected md5 is None, skip md5 check for file /tmp/tmps2pt5u7y/algo_templates.tar.gz.\n", |
| 207 | + "2022-10-18 08:14:35,706 - INFO - Writing into directory: ./ref_api_work_dir.\n" |
227 | 208 | ] |
228 | 209 | }, |
229 | 210 | { |
|
237 | 218 | "name": "stdout", |
238 | 219 | "output_type": "stream", |
239 | 220 | "text": [ |
240 | | - "2022-09-29 01:43:38,651 - INFO - ./ref_api_work_dir/segresnet2d_0\n", |
241 | | - "2022-09-29 01:43:39,029 - INFO - ./ref_api_work_dir/segresnet2d_1\n", |
242 | | - "2022-09-29 01:43:39,411 - INFO - ./ref_api_work_dir/segresnet2d_2\n", |
243 | | - "2022-09-29 01:43:39,916 - INFO - ./ref_api_work_dir/segresnet2d_3\n", |
244 | | - "2022-09-29 01:43:40,373 - INFO - ./ref_api_work_dir/segresnet2d_4\n", |
245 | | - "2022-09-29 01:43:41,656 - INFO - ./ref_api_work_dir/dints_0\n", |
246 | | - "2022-09-29 01:43:42,284 - INFO - ./ref_api_work_dir/dints_1\n", |
247 | | - "2022-09-29 01:43:42,678 - INFO - ./ref_api_work_dir/dints_2\n", |
248 | | - "2022-09-29 01:43:43,172 - INFO - ./ref_api_work_dir/dints_3\n", |
249 | | - "2022-09-29 01:43:43,681 - INFO - ./ref_api_work_dir/dints_4\n", |
250 | | - "2022-09-29 01:43:44,448 - INFO - ./ref_api_work_dir/swinunetr_0\n", |
251 | | - "2022-09-29 01:43:44,807 - INFO - ./ref_api_work_dir/swinunetr_1\n", |
252 | | - "2022-09-29 01:43:45,177 - INFO - ./ref_api_work_dir/swinunetr_2\n", |
253 | | - "2022-09-29 01:43:45,687 - INFO - ./ref_api_work_dir/swinunetr_3\n", |
254 | | - "2022-09-29 01:43:48,313 - INFO - ./ref_api_work_dir/swinunetr_4\n", |
255 | | - "2022-09-29 01:43:48,983 - INFO - ./ref_api_work_dir/segresnet_0\n", |
256 | | - "2022-09-29 01:43:49,597 - INFO - ./ref_api_work_dir/segresnet_1\n", |
257 | | - "2022-09-29 01:43:50,008 - INFO - ./ref_api_work_dir/segresnet_2\n", |
258 | | - "2022-09-29 01:43:50,393 - INFO - ./ref_api_work_dir/segresnet_3\n", |
259 | | - "2022-09-29 01:43:51,990 - INFO - ./ref_api_work_dir/segresnet_4\n" |
| 221 | + "2022-10-18 08:14:36,019 - INFO - ./ref_api_work_dir/segresnet2d_0\n", |
| 222 | + "2022-10-18 08:14:36,270 - INFO - ./ref_api_work_dir/segresnet2d_1\n", |
| 223 | + "2022-10-18 08:14:36,616 - INFO - ./ref_api_work_dir/segresnet2d_2\n", |
| 224 | + "2022-10-18 08:14:36,879 - INFO - ./ref_api_work_dir/segresnet2d_3\n", |
| 225 | + "2022-10-18 08:14:37,142 - INFO - ./ref_api_work_dir/segresnet2d_4\n", |
| 226 | + "2022-10-18 08:14:37,412 - INFO - ./ref_api_work_dir/dints_0\n", |
| 227 | + "2022-10-18 08:14:37,799 - INFO - ./ref_api_work_dir/dints_1\n", |
| 228 | + "2022-10-18 08:14:38,071 - INFO - ./ref_api_work_dir/dints_2\n", |
| 229 | + "2022-10-18 08:14:38,343 - INFO - ./ref_api_work_dir/dints_3\n", |
| 230 | + "2022-10-18 08:14:38,717 - INFO - ./ref_api_work_dir/dints_4\n", |
| 231 | + "2022-10-18 08:14:38,975 - INFO - ./ref_api_work_dir/swinunetr_0\n", |
| 232 | + "2022-10-18 08:14:39,233 - INFO - ./ref_api_work_dir/swinunetr_1\n", |
| 233 | + "2022-10-18 08:14:39,492 - INFO - ./ref_api_work_dir/swinunetr_2\n", |
| 234 | + "2022-10-18 08:14:39,849 - INFO - ./ref_api_work_dir/swinunetr_3\n", |
| 235 | + "2022-10-18 08:14:40,106 - INFO - ./ref_api_work_dir/swinunetr_4\n", |
| 236 | + "2022-10-18 08:14:40,398 - INFO - ./ref_api_work_dir/segresnet_0\n", |
| 237 | + "2022-10-18 08:14:40,771 - INFO - ./ref_api_work_dir/segresnet_1\n", |
| 238 | + "2022-10-18 08:14:41,042 - INFO - ./ref_api_work_dir/segresnet_2\n", |
| 239 | + "2022-10-18 08:14:41,309 - INFO - ./ref_api_work_dir/segresnet_3\n", |
| 240 | + "2022-10-18 08:14:41,574 - INFO - ./ref_api_work_dir/segresnet_4\n" |
260 | 241 | ] |
261 | 242 | } |
262 | 243 | ], |
|
318 | 299 | }, |
319 | 300 | { |
320 | 301 | "cell_type": "code", |
321 | | - "execution_count": 6, |
| 302 | + "execution_count": null, |
322 | 303 | "metadata": {}, |
323 | | - "outputs": [ |
324 | | - { |
325 | | - "name": "stdout", |
326 | | - "output_type": "stream", |
327 | | - "text": [ |
328 | | - "{'num_iterations': 32000, 'num_iterations_per_validation': 16000, 'num_images_per_batch': 2, 'num_epochs': 2000, 'num_warmup_iterations': 16000}\n" |
329 | | - ] |
330 | | - } |
331 | | - ], |
| 304 | + "outputs": [], |
332 | 305 | "source": [ |
333 | 306 | "# The training params are optional. If you don't want to change the default settings, you can use either `train()` or `train({})` in 2.3.2 \n", |
334 | 307 | "\n", |
335 | | - "max_epochs = 2000\n", |
| 308 | + "max_epochs = 2 # change epoch number to 2 to cut down the notebook running time\n", |
336 | 309 | "\n", |
337 | 310 | "# safeguard to ensure max_epochs is greater or equal to 2\n", |
338 | 311 | "max_epochs = max(max_epochs, 2)\n", |
|
370 | 343 | }, |
371 | 344 | { |
372 | 345 | "cell_type": "code", |
373 | | - "execution_count": null, |
| 346 | + "execution_count": 9, |
374 | 347 | "metadata": {}, |
375 | 348 | "outputs": [], |
376 | 349 | "source": [ |
|
438 | 411 | }, |
439 | 412 | { |
440 | 413 | "cell_type": "code", |
441 | | - "execution_count": null, |
| 414 | + "execution_count": 10, |
442 | 415 | "metadata": {}, |
443 | 416 | "outputs": [], |
444 | 417 | "source": [ |
|
466 | 439 | "name": "python", |
467 | 440 | "nbconvert_exporter": "python", |
468 | 441 | "pygments_lexer": "ipython3", |
469 | | - "version": "3.8.12" |
| 442 | + "version": "3.8.13" |
470 | 443 | }, |
471 | 444 | "vscode": { |
472 | 445 | "interpreter": { |
|
0 commit comments