SimpleITK图像基础(二)——三维图像resize到固定尺寸

文章目录

前言

Resize是图像处理中经常使用的一个操作,就是将图像缩放到一个固定尺寸,比如分类神经网络的输入大小必须保持一致,就要用到resize;比如有的网络训练学习需要整个图像,但计算机显卡资源不足,不能将整幅图像输入网络,这时也可用到resize。

python代码

SimpleITK中一般采用ResampleImageFilter过滤器,需要注意的是resize前后的图像应遵循以下公式,即:originsize * originspacing = newsize * newspacing。

import numpy as np
import SimpleITK as sitk
from glob import glob

def resize_image_itk(itkimage, newSize, resamplemethod=sitk.sitkNearestNeighbor):

    resampler = sitk.ResampleImageFilter()
    originSize = itkimage.GetSize()  //获取原图size
    originSpacing = itkimage.GetSpacing()  //获取原图spacing
    newSize = np.array(newSize,float)
    factor = originSize / newSize
    newSpacing = originSpacing * factor
    newSize = newSize.astype(np.int)   //spacing格式转换
    resampler.SetReferenceImage(itkimage)   //指定需要重新采样的目标图像
    resampler.SetSize(newSize.tolist())
    resampler.SetOutputSpacing(newSpacing.tolist())
    resampler.SetTransform(sitk.Transform(3, sitk.sitkIdentity))
    resampler.SetInterpolator(resamplemethod)
    itkimgResampled = resampler.Execute(itkimage)  //得到重新采样后的图像
    return itkimgResampled


image_path = 'F:\\image'    //文件夹路径
image_file = glob(image_path +"/*")   //遍历该文件夹下所有的文件
for i in range(len(image_file)):
    itkimage = sitk.ReadImage(image_file[i])    //遍历文件夹下每一张图片
    itkimgResampled = resize_image_itk(itkimage, (128,128,128),
                                   resamplemethod= sitk.sitkNearestNeighbor)
                                    //目标size为(128,128,128)
                                    //这里要注意:mask用最近邻插值,CT图像用线性插值
    sitk.WriteImage(itkimgResampled,'F:\\image' + image_file[i][len(image_path):])
  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Qt中显示维光谱图像,你可以使用Qt中的QCustomPlot库。这个库可以让你在一个QWidget中显示图像,并且支持缩放和平移等常见操作。 下面是一个简单的示例代码,用于在Qt中显示一个维光谱图像: ```c++ #include <QApplication> #include "qcustomplot.h" int main(int argc, char *argv[]) { QApplication a(argc, argv); // 创建一个QWidget对象,用于显示图像 QWidget *widget = new QWidget; widget->resize(800, 600); // 创建一个QCustomPlot对象,用于绘制图像 QCustomPlot *customPlot = new QCustomPlot(widget); customPlot->setGeometry(0, 0, 800, 600); // 生成一些测试数据 QVector<double> x(101), y(101), z(101*101); for (int i=0; i<101; ++i) { x[i] = i/50.0 - 1; y[i] = i/50.0 - 1; } for (int i=0; i<101; ++i) { for (int j=0; j<101; ++j) { z[i*101+j] = qCos(qSqrt(x[i]*x[i]+y[j]*y[j]))*qExp(-qSqrt(x[i]*x[i]+y[j]*y[j])/5); } } // 设置图像的颜色映射 QCPColorMap *colorMap = new QCPColorMap(customPlot->xAxis, customPlot->yAxis); colorMap->data()->setSize(101, 101); colorMap->data()->setRange(QCPRange(-1, 1), QCPRange(-1, 1)); for (int i=0; i<101; ++i) { for (int j=0; j<101; ++j) { colorMap->data()->setCell(i, j, z[i*101+j]); } } colorMap->setGradient(QCPColorGradient::gpJet); // 将颜色映射添加到QCustomPlot中,并刷新图像 customPlot->addPlottable(colorMap); customPlot->rescaleAxes(); customPlot->replot(); // 将QWidget显示出来 widget->show(); return a.exec(); } ``` 这个例子中使用了QCPColorMap来绘制维光谱图像,并且将它添加到了QCustomPlot中。你可以根据自己的需求来修改这个例子中的数据和绘图参数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值