SimpleITK  2.0.0
N4BiasFieldCorrection/N4BiasFieldCorrection.py
1 #!/usr/bin/env python
2 # =========================================================================
3 #
4 # Copyright NumFOCUS
5 #
6 # Licensed under the Apache License, Version 2.0 (the "License");
7 # you may not use this file except in compliance with the License.
8 # You may obtain a copy of the License at
9 #
10 # http://www.apache.org/licenses/LICENSE-2.0.txt
11 #
12 # Unless required by applicable law or agreed to in writing, software
13 # distributed under the License is distributed on an "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 # See the License for the specific language governing permissions and
16 # limitations under the License.
17 #
18 # =========================================================================
19 
20 from __future__ import print_function
21 
22 import SimpleITK as sitk
23 import sys
24 import os
25 
26 if len(sys.argv) < 2:
27  print("Usage: N4BiasFieldCorrection inputImage " +
28  "outputImage [shrinkFactor] [maskImage] [numberOfIterations] " +
29  "[numberOfFittingLevels]")
30  sys.exit(1)
31 
32 inputImage = sitk.ReadImage(sys.argv[1])
33 
34 if len(sys.argv) > 4:
35  maskImage = sitk.ReadImage(sys.argv[4], sitk.sitkUint8)
36 else:
37  maskImage = sitk.OtsuThreshold(inputImage, 0, 1, 200)
38 
39 if len(sys.argv) > 3:
40  inputImage = sitk.Shrink(inputImage,
41  [int(sys.argv[3])] * inputImage.GetDimension())
42  maskImage = sitk.Shrink(maskImage,
43  [int(sys.argv[3])] * inputImage.GetDimension())
44 
45 inputImage = sitk.Cast(inputImage, sitk.sitkFloat32)
46 
48 
49 numberFittingLevels = 4
50 
51 if len(sys.argv) > 6:
52  numberFittingLevels = int(sys.argv[6])
53 
54 if len(sys.argv) > 5:
55  corrector.SetMaximumNumberOfIterations([int(sys.argv[5])]
56  * numberFittingLevels)
57 
58 output = corrector.Execute(inputImage, maskImage)
59 
60 sitk.WriteImage(output, sys.argv[2])
61 
62 if ("SITK_NOSHOW" not in os.environ):
63  sitk.Show(output, "N4 Corrected")
itk::simple::OtsuThreshold
Image OtsuThreshold(const Image &image, uint8_t insideValue=1u, uint8_t outsideValue=0u, uint32_t numberOfHistogramBins=128u, bool maskOutput=true, uint8_t maskValue=255u, bool returnBinMidpoint=false)
Threshold an image using the Otsu Threshold.
itk::simple::WriteImage
SITKIO_EXPORT void WriteImage(const Image &image, const std::vector< std::string > &fileNames, bool useCompression=false, int compressionLevel=-1)
WriteImage is a procedural interface to the ImageSeriesWriter. class which is convenient for many ima...
itk::simple::Show
void SITKIO_EXPORT Show(const Image &image, const std::string &title="", const bool debugOn=ProcessObject::GetGlobalDefaultDebug())
itk::simple::ReadImage
SITKIO_EXPORT Image ReadImage(const std::vector< std::string > &fileNames, PixelIDValueEnum outputPixelType=sitkUnknown, const std::string &imageIO="")
ReadImage is a procedural interface to the ImageSeriesReader class which is convenient for most image...
itk::simple::N4BiasFieldCorrectionImageFilter
Implementation of the N4 bias field correction algorithm.
Definition: sitkN4BiasFieldCorrectionImageFilter.h:74
itk::simple::Shrink
Image Shrink(const Image &image1, std::vector< unsigned int > shrinkFactors=std::vector< unsigned int >(3, 1))
Reduce the size of an image by an integer factor in each dimension.
itk::simple::Cast
Image Cast(const Image &image, PixelIDValueEnum pixelID)