Insight Segmentation and Registration Toolkit
Das Insight Segmentation and Registration Toolkit (ITK) ist eine Open-Source-C++-Programmbibliothek für die Segmentierung und Registrierung von Bildern.
ITK | |
---|---|
Basisdaten
| |
Entwickler | National Library of Medicine, Kitware Inc. und diverse Universitäten |
Aktuelle Version | 5.4[1] (20. Mai 2024) |
Betriebssystem | Unix-Derivate (Linux, macOS), Windows |
Programmiersprache | C, C++, Python[2] |
Kategorie | Bildverarbeitung |
Lizenz | Apache 2.0 Lizenz[3] |
deutschsprachig | nein |
www.itk.org |
Allgemeines
BearbeitenDie Entwicklung von ITK wurde ab 1999 von der National Library of Medicine gestartet, um offene Klassenbibliotheken und Schnittstellen für die Auswertung des Visible Human Projects zu schaffen.[4] Typische Anwendungsgebiete von ITK sind z. B. die Verarbeitung von medizinischen Daten aus der Computertomographie und der Magnetresonanztomografie. Als Build-System kommt CMake zum Einsatz, welches speziell für ITK entwickelt wurde.[5]
Beispiele
BearbeitenGlättung mithilfe von einem Gaußfilter
Bearbeiten#include <itkImage.h>
#include <itkImageFileReader.h>
#include <itkImageFileWriter.h>
#include <itkDiscreteGaussianImageFilter.h>
int main(int argc, char *argv[])
{
typedef itk::Image<unsigned char, 2> ImageType;
typedef itk::ImageFileReader<ImageType> ReaderType;
typedef itk::ImageFileWriter<ImageType> WriterType;
typedef itk::DiscreteGaussianImageFilter<ImageType, ImageType> GaussianFilterType;
ReaderType::Pointer reader = ReaderType::New();
reader->SetFileName("test.jpg");
GaussianFilterType::Pointer smoothFilter = GaussianFilterType::New();
smoothFilter->SetInput(reader->GetOutput());
smoothFilter->SetVariance(3);
WriterType::Pointer writer = WriterType::New();
writer->SetInput(smoothFilter->GetOutput());
writer->SetFileName("smoothImage.png");
try
{
writer->Update();
}
catch( itk::ExceptionObject & excp )
{
std::cerr << excp << std::endl;
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}
Region Growing Segmentierung
Bearbeiten#include <itkImage.h>
#include <itkImageFileReader.h>
#include <itkImageFileWriter.h>
#include <itkConnectedThresholdImageFilter.h>
int main(int argc, char *argv[])
{
typedef itk::Image<unsigned char, 3> ImageType;
typedef itk::ImageFileReader<ImageType> ReaderType;
typedef itk::ImageFileWriter<ImageType> WriterType;
typedef itk::ConnectedThresholdImageFilter<ImageType, ImageType> RegionFilterType;
ReaderType::Pointer reader = ReaderType::New();
reader->SetFileName("test.nii");
ImageType::IndexType seed;
seed[0] = 142;
seed[1] = 97;
seed[2] = 63;
RegionFilterType::Pointer regionFilter = RegionFilterType::New();
regionFilter->SetInput(reader->GetOutput());
regionFilter->SetSeed(seed);
WriterType::Pointer writer = WriterType::New();
writer->SetInput(regionFilter->GetOutput());
writer->SetFileName("region.nii");
try
{
writer->Update();
}
catch( itk::ExceptionObject & excp )
{
std::cerr << excp << std::endl;
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}
Siehe auch
BearbeitenWeblinks
Bearbeiten- www.itk.org (englisch)
- Startseite zu ITK Tutorials (englisch)
Einzelnachweise
Bearbeiten- ↑ Release 5.4.0. 20. Mai 2024 (abgerufen am 8. Dezember 2024).
- ↑ Insight Software Consortium / ITK - GitHub. Abgerufen am 10. Juni 2020 (englisch).
- ↑ License. Abgerufen am 10. Juni 2020 (englisch).
- ↑ History. Abgerufen am 10. Juni 2020 (englisch).
- ↑ Overview. Abgerufen am 10. Juni 2020 (englisch).