Insight Segmentation and Registration Toolkit

From Wikipedia, the free encyclopedia

ITK
Developer: Insight Software Consortium
Latest release: 3.0.1 / November 1, 2006
OS: Cross-platform
Available language(s): C++, Tcl, Python, Java
Use: Development Library
License: [http://www.itk.org/HTML/Copyright.htm
Website: ITK Homepage, Wiki page

In computer programming, ITK is a cross-platform application development framework, widely used for the development of image segmentation and image registration programs. ITK was developed with funding from the National Library of Medicine (U.S.) as an open resource of algorithms for analyzing the images of the Visible Human Project. ITK stands for The Insight Segmentation and Registration Toolkit. The toolkit provides leading-edge segmentation and registration algorithms in two, three, and more dimensions. The software is implemented in C++ and it is wrapped for Tcl, Python and Java.

Contents

[edit] Introduction

[edit] Origins

In 1999 the US National Library of Medicine of the National Institutes of Health awarded a three-year contract to develop an open-source registration and segmentation toolkit, which eventually came to be known as the Insight Toolkit (ITK). ITK's NLM Project Manager was Dr. Terry Yoo, who coordinated the six prime contractors who made up the Insight Software Consortium. These consortium members included the three commercial partners GE Corporate R&D, Kitware, Inc., and MathSoft (the company name is now Insightful); and the three academic partners University of North Carolina (UNC), University of Tennessee (UT), and University of Pennsylvania (UPenn). The Principle Investigators for these partners were, respectively, Bill Lorensen at GE CRD, Will Schroeder at Kitware, Vikram Chalana at Insightful, Stephen Aylward with Luis Ibanez at UNC (Luis is now at Kitware), Ross Whitaker with Josh Cates at UT (both now at Utah), and Dimitri Metaxas at UPenn. In addition, several subcontractors rounded out the consortium including Peter Raitu at Brigham & Women's Hospital, Celina Imielinska and Pat Molholt at Columbia University, Jim Gee at UPenn's Grasp Lab, and George Stetten at University of Pittsburgh. Who are the developers? The best way to determine the names of developers is to view the CVS source code repository logs. Most of the early developers are listed in the following, however, many developers beyond those listed here will participate in the development of ITK as the code grows and becomes publicly accessible.

[edit] Technical Details

ITK is an open-source software toolkit for performing registration and segmentation. Segmentation is the process of identifying and classifying data found in a digitally sampled representation. Typically the sampled representation is an image acquired from such medical instrumentation as CT or MRI scanners. Registration is the task of aligning or developing correspondences between data. For example, in the medical environment, a CT scan may be aligned with a MRI scan in order to combine the information contained in both.

ITK is implemented in C++. ITK is cross-platform, using the CMake build environment to manage the compilation process. In addition, an automated wrapping process generates interfaces between C++ and interpreted programming languages such as Tcl, Java, and Python (using CableSwig). This enables developers to create software using a variety of programming languages. ITK's C++ implementation style is referred to as generic programming (i.e., using templated code). Such C++ templating means that the code is highly efficient, and that many software problems are discovered at compile-time, rather than at run-time during program execution.

Because ITK is an open-source project, developers from around the world can use, debug, maintain, and extend the software. ITK uses a model of software development referred to as extreme programming. Extreme programming collapses the usual software creation methodology into a simultaneous and iterative process of design-implement-test-release. The key features of extreme programming are communication and testing. Communication among the members of the ITK community is what helps manage the rapid evolution of the software. Testing is what keeps the software stable. In ITK, an extensive testing process (using Dart) is in place that measures the quality on a daily basis. The ITK Testing Dashboard is posted continuously reflecting the quality of the software.

[edit] Developers and Contributors

The Insight Toolkit was initially developed by six principal organizations

  • Kitware
  • GE Corporate R&D
  • Insightful
  • UNC Chapel Hill
  • University of Utah
  • University of Pennsylvania

After its inception the software continued growing with contributions from other institutions including

  • Harvard Brigham & Women's Hospital
  • University of Pittsburgh
  • Columbia University
  • University of Iowa
  • Georgetown University
  • Standford University
  • King's College of London
  • Creatis INSA

[edit] Funding

The funding for the project is from the National Library of Medicine at the National Institutes of Health. NLM in turn was supported by member institutions of NIH (see sponsors).

The goals for the project include the following:

  • Support the Visible Human Project.
  • Establish a foundation for future research.
  • Create a repository of fundamental algorithms.
  • Develop a platform for advanced product development.
  • Support commercial application of the technology.
  • Create conventions for future work.
  • Grow a self-sustaining community of software users and developers.

The source code of the Insight Toolkit is distributed under a BSD-like License

The philosophy of Open Source of the Insight Toolkit was extended to support Open Science, in particular by providing Open Access to publications in the domain of Medical Image Processing. These publications are made freely available through the Insight Journal

[edit] Community Participation

Because ITK is an open-source system, anybody can make contributions to the project. This contributions however are organized by an oversight committee. A person interested in contributing to ITK can take the following actions

  1. Read this document and especially the ITK Software Guide. (This book can be purchased from Kitware's store.)
  2. Obtain access to the CVS repository (read-only, anonymous access), and obtain the distribution using the following procedure outlined here.
  3. If you wish to contribute code, find the Insight/Documents/InsightDeveloperStart.pdf (in the source distribution) and read it thoroughly.
  4. As this document suggests, join the insight-developers list. You will have to contact a developer for permission (will.schroeder@kitware.com)
  5. Contribute code or fix bugs by mailing code to the list or contacting a developer directly.
  6. Once you demonstrate your abilities, obtain read-write access to the repository. Access can be obtained following the instructions outlined in the Insight/Documents/InsightDeveloperStart.pdf document.

[edit] Copyright and License

ITK carries a copyright by the Insight Software Consortium, a non-profit alliance of organizations and individuals interested in supporting ITK. The copyright is a generous Berkeley-style open-source license. It allows use for any purpose, with the possible exception of code found in the patented directory, and with proper recognition. The full terms of the copyright and the license are available at http://www.itk.org/HTML/Copyright.htm.

[edit] Technical Summary

The following sections summarize the technical features of the NLM's Insight ITK toolkit. Design Philosophy The following are key features of the toolkit design philosophy.

  • The toolkit provides data representation and algorithms for performing segmentation and registration. The focus is on medical applications; although the toolkit is capable of processing other data types.
  • The toolkit provides data representations in general form for images (arbitrary dimension) and (unstructured) meshes.
  • The toolkit does not address visualization or graphical user interface. These are left to other toolkits (such as VTK, VisPack, 3DViewnix, MetaImage, etc.)
  • The toolkit provides minimal tools for file interface. Again, this is left to other toolkits/libraries to provide.
  • Multi-threaded (shared memory) parallel processing is supported.
  • The development of the toolkit is based on principles of extreme programming. That is, design, implementation, and testing is performed in a rapid, iterative process. Testing forms the core of this process. In Insight, testing is performed continuously as files are checked in, and every night across multiple platforms and compilers. The ITK testing dashboard, where testing results are posted, is central to this process.

[edit] Architecture

The following are key features of the toolkit architecture.

  • The toolkit is organized around a data-flow architecture. That is, data is represented using data objects which are in turn processed by process objects (filters). Data objects and process objects are connected together into pipelines. Pipelines are capable of processing the data in pieces according to a user-specified memory limit set on the pipeline.
  • Object factories are used to instantiate objects. Factories allow run-time extension of the system.
  • A command/observer design pattern is used for event processing.

[edit] Implementation Philosophy

The following are key features of the toolkit implementation philosophy.

  • The toolkit is implemented using generic programming principles. Such heavily templated C++ code challenges many compilers; hence development was carried out with the latest versions of the MSVC, Sun, gcc, Intel, and SGI compilers.
  • The toolkit is cross-platform (Unix, Windows and MacOSX).
  • The toolkit supports multiple language bindings, including such languages as Tcl, Python, and Java. These bindings are generated automatically using an auto-wrap process. CableSwig the tool we use for wrapping the code.
  • The memory model depends on "smart pointers" that maintain a reference count to objects. Smart pointers can be allocated on the stack, and when scope is exited, the smart pointers disappear and decrement their reference count to the object that they refer to.

[edit] Build Environment

ITK uses the CMake (cross-platform make) build environment. CMake is an operating system and compiler independent build process that produces native build files appropriate to the OS and compiler that it is run with. On Unix CMake produces makefiles and on Windows CMake generates projects and workspaces. Testing Environment ITK supports an extensive testing environment. The code is tested daily (and even continuously) on many hardware/operating system/compiler combinations and the results are posted daily on the ITK testing dashboard. We use Dart to manage the testing process, and to post the results to the dashboard. Background References C++ Patterns and Generics ITK uses many advanced design patterns and generic programming. You may find these references useful in understanding the design and syntax of Insight.

  • Design Patterns. by Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides, Grady Booch
  • Generic Programming and the Stl : Using and Extending the C++ Standard Template Library (Addison-Wesley Professional Computing Series) by Matthew H. Austern
  • Advanced C++ Programming Styles and Idioms by James O. Coplien
  • C/C++ Users Journal
  • C++ Report

[edit] Examples

[edit] Hello World

 #include "itkImage.h"
 int main()
   {
   typedef itk::Image< unsigned char, 3 > ImageType;
   typedef itk::ImageFileReader< ImageType >  ReaderType;
   typedef itk::ImageFileWriter< ImageType >  WriterType;
   typedef itk::GradientRecursiveGaussianImageFilter< ImageType, ImageType > FilterType;
   ReaderType::Pointer reader  = ReaderType::New();
   WriterType::Pointer writer  = WriterType::New();
   reader->SetFileName("lungCT.dcm");
   writer->SetFileName("smoothedLung.hdr");
   FilterType::Pointer filter = FilterType::New();
   filter->SetInput( reader->GetOutput() );
   writer->SetInupt( filter->GetOutput() );
   filter->SetSigma();
   try
     {
     writer->Update();
     }
   catch( itk::ExceptionObject & excp )
     {
     std::cerr << excp << std::endl;
     return EXIT_FAILURE;
     }
   }

[edit] Region Growing Segmentation

 #include "itkImage.h"
 int main()
   {
   typedef itk::Image< signed short,  3 >  InputImageType;
   typedef itk::Image< unsigned char, 3 >  OutputImageType;
   typedef itk::ImageFileReader< InputImageType >  ReaderType;
   typedef itk::ImageFileWriter< OutputImageType >  WriterType;
   typedef itk::ConnectedThresholdImageFilter< InputImageType, OutputImageType > FilterType;
   ReaderType::Pointer reader  = ReaderType::New();
   WriterType::Pointer writer  = WriterType::New();
   reader->SetFileName("brain.dcm");
   writer->SetFileName("whiteMatter.hdr");
   FilterType::Pointer filter = FilterType::New();
   filter->SetInput( reader->GetOutput() );
   writer->SetInupt( filter->GetOutput() );
   filter->SetMultiplier(2.5);
   ImageType::IndexType seed;
   seed[0] = 142;
   seed[1] =  97;
   seed[2] =  63;
   filter->AddSeed( seed );
   try
     {
     writer->Update();
     }
   catch( itk::ExceptionObject & excp )
     {
     std::cerr << excp << std::endl;
     return EXIT_FAILURE;
     }
   }

[edit] Additional information

[edit] Resources

A number of resources are available to learn more about ITK.

  • The ITK web pages are located http://www.itk.org.
  • Users and developers alike should read the Software Guide
  • Tutorials are available at http://www.itk.org/HTML/Tutorials.htm
  • The software can be downloaded from http://www.itk.org/HTML/Download.php.
  • Developers, or users interested in contributing code, should look in the document Insight/Documentation/InsightDeveloperStart.pdf or InsightDeveloperStart.doc found in the source code distribution.
  • Developers should also look at the ITK style guide Insight/Documentation/Style.pdf found in the source distribution.

[edit] Applications

A great way to learn about ITK is to see how it is used. There are four places to find applications of ITK.

  1. The Insight/Examples/ source code examples distributed with ITK. The source code is available. In addition, it is heavily commented and works in combination with the ITK Software Guide.
  2. The separate InsightApplications checkout.
  3. The Applications web pages. These are extensive descriptions, with images and references, of the examples found in #1 above.
  4. The testing directories distributed with ITK are simple, mainly undocumented examples of how to use the code.

In 2004 ITK-Snap (website) was developed from SNAP and became a popular free segmentation software using ITK and having a nice and simple user interface.

[edit] Data

[edit] Contacts

  • Terry Yoo (NLM/NIH Insight Project Manager yoo@nlm.nih.gov)
  • Will Schroeder (PI Kitware, Inc. will.schroeder@kitware.com)
In other languages