1 '''=========================================================================
3 ' Copyright Insight Software Consortium
5 ' Licensed under the Apache License, Version 2.0 (the "License");
6 ' you may not use this file except in compliance with the License.
7 ' You may obtain a copy of the License at
9 ' http://www.apache.org/licenses/LICENSE-2.0.txt
11 ' Unless required by applicable law or agreed to in writing, software
12 ' distributed under the License is distributed on an "AS IS" BASIS,
13 ' WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 ' See the License for the specific language governing permissions and
15 ' limitations under the License.
17 '========================================================================='''
19 from __future__
import print_function
21 import SimpleITK
as sitk
29 if len( sys.argv ) < 7:
30 print(
"Usage: NeighborhoodConnectedImageFilter inputImage outputImage lowerThreshold upperThreshold seedX seedY [seed2X seed2Y ... ]")
38 reader.SetFileName( sys.argv[1] )
39 image = reader.Execute();
46 blurFilter.SetNumberOfIterations( 5 )
47 blurFilter.SetTimeStep( 0.125 )
48 image = blurFilter.Execute( image )
54 segmentationFilter.SetLower( float(sys.argv[3]) )
55 segmentationFilter.SetUpper( float(sys.argv[4]) )
56 segmentationFilter.SetReplaceValue( 255 )
59 segmentationFilter.SetRadius( radius )
61 for i
in range( 5, len(sys.argv)-1, 2 ):
62 seed = [int(sys.argv[i]), int(sys.argv[i+1])]
63 segmentationFilter.AddSeed( seed )
64 print(
"Adding seed at: ", seed,
" with intensity: ", image.GetPixel(*seed) )
67 image = segmentationFilter.Execute( image )
73 writer.SetFileName( sys.argv[2] )
74 writer.Execute( image )
78 if (
not "SITK_NOSHOW" in os.environ ):
79 sitk.Show( image,
"NeighborhoodConnectedThreshold" )