python读入图像是四维,需要将其转换为三维图像

作者分享了解决图像文件中多余透明度通道的经历,通过分析发现并移除无效通道,成功将SPECT和MRI的四个通道压缩为三个,确保了数据的有效使用。

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

其实之前就遇到过一次了,但是由于当时图片过多,我避免了去解决这种问题。但是今天又遇到一次,而且是老师发给我的,这几组图像是必须要用的,那么意味着必须要解决这个问题了。。。

from scipy.misc import imread, imsave
path1 = 'test_imgs/replenish/spect/1.png'
path2 = 'test_imgs/replenish/mri/1.png'
pet = imread(path1) / 255.0
mri = imread(path2) / 255.0

print("petShape:",pet.shape,"mriShape",mri.shape)
# petShape: (256, 256, 4) mriShape (256, 256, 4)

接下来试试能不能看

import matplotlib.pyplot as plt
fig=plt.figure()
f1 = fig.add_subplot(121)
f2 = fig.add_subplot(122)
f1.imshow(pet)
f2.imshow(mri)
plt.show() # 发现查看是没有任何问题的

在这里插入图片描述
先看看SPECT的四个通道的图像

fig=plt.figure()
f1 = fig.add_subplot(221)
f2 = fig.add_subplot(222)
f3 = fig.add_subplot(223)
f4 = fig.add_subplot(224)
f1.imshow(pet[:,:,0],cmap='gray')
f2.imshow(pet[:,:,1],cmap='gray')
f3.imshow(pet[:,:,2],cmap='gray')
f4.imshow(pet[:,:,3],cmap='gray')
plt.show()

通过观察可以发现,第四个维度图像是全黑的
在这里插入图片描述
再查看一下第四个通道的像素值

print(pet[:,:,3])
# 得到以下结果
[[1. 1. 1. ... 1. 1. 1.]
 [1. 1. 1. ... 1. 1. 1.]
 [1. 1. 1. ... 1. 1. 1.]
 ...
 [1. 1. 1. ... 1. 1. 1.]
 [1. 1. 1. ... 1. 1. 1.]
 [1. 1. 1. ... 1. 1. 1.]]

全1是原因是因为我做了归一化,255像素就会变为1,说明最后一个通道是没有任何作用的,应该是传说中的透明度通道。

接下来再看看MRI灰度图的四通道图像

fig=plt.figure()
f1 = fig.add_subplot(221)
f2 = fig.add_subplot(222)
f3 = fig.add_subplot(223)
f4 = fig.add_subplot(224)
f1.imshow(mri[:,:,0],cmap='gray')
f2.imshow(mri[:,:,1],cmap='gray')
f3.imshow(mri[:,:,2],cmap='gray')
f4.imshow(mri[:,:,3],cmap='gray')
plt.show()

在这里插入图片描述
通过观察可以发现前三个通道其实都是同一张图,而第四个通道也是全黑的,即透明度通道(别管为啥叫透明度,我也只是听说过这个概念,在本文中我就把它当做透明度通道了),那么我们只需要存其中一张就可以了。

找到问题所在了,那么就开始改通道了
我目前能想到的办法就是新建一个空的三维数组,然后把三通道值依次存放进去。

h, w,_= pet.shape
import numpy as np
h, w,_= pet.shape
img_pet = np.zeros((h,w,3)) # 创建一个全0数组
img_mri = np.zeros((h,w))
print("petShape:",img_pet.shape,"mriShape",img_mri.shape)
# petShape: (256, 256, 3) mriShape (256, 256)

开始存

img_pet [:,:,0]=pet[:,:,0]
img_pet [:,:,1]=pet[:,:,1]
img_pet [:,:,2]=pet[:,:,2]

img_mri = mri[:,:,0]

查看一下

fig=plt.figure()
f1 = fig.add_subplot(121)
f2 = fig.add_subplot(122)
f1.imshow(img_pet)
f2.imshow(img_mri,cmap='gray')
plt.show()

在这里插入图片描述

问题解决!

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

果子当夜宵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值