Home > ITKv4FEM-Kiran

ITKv4FEM-Kiran

ITKv4FEM-Kiran is a project mainly written in C and C++, it's free.

FEM framework refactoring

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

ITK README File - Overview and further information

An Introduction to the
Insight Segmentation & Registration Toolkit



Welcome to the National Library of Medicine Insight Segmentation and Registration Toolkit (ITK).

This document provides a brief description of the project, its history, and references to additional information describing how to use, develop, and contribute to ITK.

Introduction

What is ITK?

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++. In addition, an automated wrapping process generates interfaces between C++ and interpreted programming languages such as Tcl, Java, and Python. This enables developers to create software using a variety of programming languages. ITK's C++ implementation style is referred to as generic programming. Such C++ templating means that the code is highly efficient, and that the 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 is in place that measures the quality on a daily basis.

What are ITK's 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). The primary purpose of the project is to support the Visible Human Project by providing software tools to process and work with the project data. 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 (now at Rutgers). 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 Stetton 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 Insight as the code grows and becomes publicly accessible.

Some of the early developers include:
  • Elsa Angelini - Columbia, segmentation algorithms
  • Brian Avants - UPenn; FEM classes, registration algorithms
  • Stephen Aylward - UNC; architecture, algorithms
  • Dan Blezek - GE CRD; testing infrastructure
  • Josh Cates - Utah; imaging classes and filters
  • Ting Chen - UPenn, segmentation algorithms
  • Jeffrey Duda - UPenn; FEM classes, registration algorithms
  • James Gee - UPenn; FEM architecture, registration algorithms
  • Bill Hoffman - Kitware; CMake (build process); vxl/vnl numerics; infrastructure (smart pointers, object factories, callback mechanism)
  • Paul Hughett - UPenn; quality, algorithms
  • Luis Ibanez - UNC (now Kitware); imaging classes and filters
  • Celina Imielinska - Columbia, segmentation algorithms
  • Yinpeng Jin - Columbia, segmentation algorithms
  • Brad King - Kitware; Mesh class, autowrapping of C++ code
  • Bill Lorensen - GE CRD; testing, requirements, architecture
  • Ken Martin - Kitware; Build process, architecture, infrastructure
  • Dimitris Metaxas - UPenn, segmentation algorithms
  • Jim Miller - GE CRD; Image classes, iterators, pipeline update mechanism
  • Lydia Ng - Mathsoft (now Insightful); Image filters, clustering/segementation algorithms
  • Aljaz Noe - UPenn; FEM classes
  • Sayan Pathak – MathSoft (now Insightful); image clustering/segementation algorithms
  • Will Schroeder - Kitware; architecture, Mesh classes, documentation, algorithms, core classes
  • Marcelo Siqueira - UPenn; FEM classes
  • George Stetton - Pittsburgh; image filters, algorithms
  • Tessa Sundaram - UPenn; FEM classes, registration algorithms
  • Jayaram Udupa - Upenn, segmentation algorithms
  • Ross Whitaker - Utah; architecture, algorithms
  • Ying Zhuge - UPenn, segmentation algorithms

How do I participate?

Because ITK is an open-source system, you can participate. If you'd like to become involved, here are the following steps that you might consider.
  1. Read this document and the ITK Software Guide. (The book is also available for purchase from Kitware's estore.)
  2. Obtain access to the CVS repository (read-only, anonymous access),  and obtain the distribution using the following procedure (see instructions in For More Information at the end of document).
  3. Find the Insight/Documents/InsightStart.doc and read it thoroughly.
  4. As this document suggests, join the insight-developers list.
  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 CVS repository. Access can be obtained by following the procedure described in the Insight/Documents/InsightDeveloperStart.pdf file.

What are the terms of use?

The ITK copyright is held by the Insight Software Consortium. This non-profit entity promotes the use of ITK for educational and research purposes. The copyright enables both commercial and non-commercial usage. There is a patented code found in the Insight/Code/Patented directory. If you use any of these code in commercial application, you must contact the patent holder to obtain permission.

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 Insight testing dashboard, where testing results are posted, is central to this process.

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.

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 is 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.
  • The Command/Observer design pattern is used for invoking and processing events.

Build Environment

Insight uses the CMake (cross-platform make) build environment. CMake uses configure and make on Unix and generates projects and workspaces in the windows environment.

Testing Environment

Insight 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 Insight testing dashboard. We use Dart to manage the testing process, and to post the results to the dashboard.

Background References

C++ Patterns and Generics

Insight 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

ADDITIONAL INFORMATION

Resources

A number of resources are available to learn more about ITK.
  • The ITK web pages are located http://www.itk.org.
  • The definitive guide to ITK is available from ITK Software Guide. (The book is also available for purchase from Kitware's estore.)
  • Users of the toolkit should look in the file GettingStarted.txt. This file contains information on how to obtain ITK and the basics of compilation and otherwise managing the software.
  • Developers, or users interested in learning more, should look in the document InsightStart.pdf or InsightStart.doc found in the Insight/Documentation directory.
  • Developers should also look at the ITK style guide Style.pdf.

Examples

A great way to learn about ITK is to see how it is used. There are three places to find examples.
  1. The Insight/Examples distributed with ITK. The source code is available. The examples are used in the ITK Software Guide mentioned previously.
  2. The Examples web pages. These are extensive descriptions, with images and references, of the examples found in #1 above.
  3. The Testing directories distributed with ITK are simple, mainly undocumented examples of how to use the code.

Data

  • Data is available via anonymous ftp from: ftp://public.kitware.com/pub/itk/Data/.
  • See also the ITK Data web page.

Contacts