ITK学习笔记-2:图像采样

本文介绍了一种使用ITK库对RGB图像进行采样的方法。该方法通过调整图像尺寸实现采样,并展示了如何使用最近邻插值进行图像重采样。代码示例包括图像读取、重采样和可视化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

主要是利用ITK对RBG图像进行采样处理。至于ITK的管道结构等基础概念不在此进行讨论,本文直接给出代码。

#include "itkImage.h"
#include "itkIdentityTransform.h"
#include "itkImageFileReader.h"
#include "itkVectorResampleImageFilter.h"
#include "itkVectorNearestNeighborInterpolateImageFunction.h"
#include "itkRGBPixel.h"

#include "QuickView.h"

typedef itk::Image<itk::RGBPixel<unsigned char>, 2> ImageType;

static void CreateImage(ImageType::Pointer image);

int main(int argc, char *argv[])
{
	double factor = 2.0;

	// Create input image
	ImageType::Pointer input;
	if(argc < 2)
	{
		input = ImageType::New();
		CreateImage(input);
	}
	else
	{
		typedef itk::ImageFileReader<ImageType> ReaderType;
		ReaderType::Pointer reader = ReaderType::New();
		reader->SetFileName(argv[1]);
		reader->Update();
		input = reader->GetOutput();
		if (argc > 2)
		{
			factor = atof(argv[2]);
		}
	}

	ImageType::SizeType inputSize = input->GetLargestPossibleRegion().GetSize();

	std::cout << "Input size: " << inputSize << std::endl;

	// Resize
	ImageType::SizeType outputSize;
	outputSize[0] = inputSize[0] * factor;
	outputSize[1] = inputSize[1] * factor;

	ImageType::SpacingType outputSpacing;
	outputSpacing[0] = input->GetSpacing()[0] * (static_cast<double>(inputSize[0]) / static_cast<double>(outputSize[0]));
	outputSpacing[1] = input->GetSpacing()[1] * (static_cast<double>(inputSize[1]) / static_cast<double>(outputSize[1]));

	typedef itk::IdentityTransform<double, 2> TransformType;
	typedef itk::VectorResampleImageFilter<ImageType, ImageType> ResampleImageFilterType;
	ResampleImageFilterType::Pointer resample = ResampleImageFilterType::New();
	resample->SetInput(input);
	resample->SetSize(outputSize);
	resample->SetOutputSpacing(outputSpacing);
	resample->SetTransform(TransformType::New());
	resample->UpdateLargestPossibleRegion();

	typedef itk::VectorNearestNeighborInterpolateImageFunction<
		ImageType, double >  NearestInterpolatorType;
	NearestInterpolatorType::Pointer nnInterpolator =
		NearestInterpolatorType::New();

	ResampleImageFilterType::Pointer resampleNN =
		ResampleImageFilterType::New();
	resampleNN->SetInput(input);
	resampleNN->SetSize(outputSize);
	resampleNN->SetOutputSpacing(outputSpacing);
	resampleNN->SetTransform(TransformType::New());
	resampleNN->SetInterpolator(nnInterpolator);//相比较于,多了最近邻插值
	resampleNN->UpdateLargestPossibleRegion();

	ImageType::Pointer output = resample->GetOutput();

	std::cout << "Output size: " << output->GetLargestPossibleRegion().GetSize() << std::endl;

	QuickView viewer;

	viewer.AddRGBImage(input.GetPointer(),
		true,
		"Original");
	viewer.AddRGBImage(output.GetPointer(),
		true,
		"Resampled");

	viewer.AddRGBImage(resampleNN->GetOutput(),
		true,
		"Resampled NN");

	viewer.Visualize();

	return EXIT_SUCCESS;
}

void CreateImage(ImageType::Pointer image)
{
	// Create a black image with 2 white regions

	ImageType::IndexType start;
	start.Fill(0);

	ImageType::SizeType size;
	size.Fill(200);

	ImageType::RegionType region(start,size);
	image->SetRegions(region);
	image->Allocate();
	image->FillBuffer( itk::NumericTraits< ImageType::PixelType >::Zero);

	ImageType::PixelType pixel;
	pixel.SetRed(200);
	pixel.SetGreen(50);
	pixel.SetBlue(50);

	// Make a square
	for(unsigned int r = 20; r < 80; r++)
	{
		for(unsigned int c = 30; c < 100; c++)
		{
			ImageType::IndexType pixelIndex;
			pixelIndex[0] = r;
			pixelIndex[1] = c;

			image->SetPixel(pixelIndex, pixel);

		}
	}

}

运行时候界面如下图所示:


因为主程序中所采样的是int main(int argc, char*argv[])

所以在执行exe的时候,通过dos窗口进行exe所在的目录,后续的两个参数分别为F:\DIPcode\SIMC\imagesrc\2.jpg  0.2

第一个参数用于指定待处理的图像,第二个参数说明采样率。此处设置为0.2,则采样后的图像为原始图像尺寸的0.2倍。如上图可以看到,原始图像是512X512的图像,采样之后图像的尺寸变为102X102,约为512*0.2。

运行结果如下图所示:






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值