20 from __future__
import print_function
22 import SimpleITK
as sitk
27 def command_iteration(method):
28 print(
"{0:3} = {1:7.5f} : {2}".format(method.GetOptimizerIteration(),
29 method.GetMetricValue(),
30 method.GetOptimizerPosition()))
34 print(
"Usage:", sys.argv[0],
35 "<fixedImageFilter> <movingImageFile> <outputTransformFile>")
38 pixelType = sitk.sitkFloat32
50 R.SetMetricAsJointHistogramMutualInformation()
52 R.SetOptimizerAsGradientDescentLineSearch(learningRate=1.0,
53 numberOfIterations=200,
54 convergenceMinimumValue=1e-5,
55 convergenceWindowSize=5)
59 R.SetInterpolator(sitk.sitkLinear)
61 R.AddCommand(sitk.sitkIterationEvent,
lambda: command_iteration(R))
63 outTx = R.Execute(fixed, moving)
67 print(
"Optimizer stop condition: {0}"
68 .format(R.GetOptimizerStopConditionDescription()))
69 print(
" Iteration: {0}".format(R.GetOptimizerIteration()))
70 print(
" Metric value: {0}".format(R.GetMetricValue()))
74 if (
"SITK_NOSHOW" not in os.environ):
76 resampler.SetReferenceImage(fixed)
77 resampler.SetInterpolator(sitk.sitkLinear)
78 resampler.SetDefaultPixelValue(1)
79 resampler.SetTransform(outTx)
81 out = resampler.Execute(moving)
85 cimg =
sitk.Compose(simg1, simg2, simg1 // 2. + simg2 // 2.)
86 sitk.Show(cimg,
"ImageRegistration2 Composition")