io.imread和cv2.imread以及 transform.resize和cv2.resize区别




Tensorflow中,在训练图片数据之前,需要先对图片进行预处理,读图和裁剪是最基本的两步。常见的的读图何裁剪分别有两种方式,这里小编将和大家分享下这几种方式的实现以及他们之间的区别。

一、常见的两种读图方式 io.imread() 和 cv2.imread()

1.io.imread 读出的图片格式是uint8,value是numpy array 类型。对于RGB 图片,图像数据是以RGB 的格式进行存储的。



2.cv2.imread读出的图片格式是uint8 ,value也是numpy array 类型。唯一的区别是,图像数据格式是以BGR的格式进行存储的。需要将存储类型改成RGB 的形式才能正常显示原图的颜色。特别是制作tfrecord 时,需要将图片通道改成RGB,具体代码如下。


   
   
  1. import cv2
  2. import matplotlib.pyplot as plt
  3. from skimage import transform
  4. import numpy as np
  5. import skimage.io as io
  6. train_dir = 'E:/TensorFlow/Project_TF/flower_tfrecord/data/test/roses/timg.jpg'
  7. '''以cv2方式读取图片'''
  8. image=cv2.imread(train_dir)
  9. b,g,r = cv2.split(image) #将图像通道分离开
  10. rgb_image = cv2.merge([r,g,b]) #以RGB的形式重新组合
  11. #image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) 也可以使用这个函数直接转换成RGB 形式
  12. plt.imshow(rgb_image)
  13. '''以io.imread方式读取图片'''
  14. #image = io.imread(train_dir) #读图并显示
  15. #plt.imshow(image)

二、常见的两种图片裁剪方式 cv2.resize() 和 transform.resize()

1.通过cv2.resize()裁剪后的图片还是以 numpy array 的方式保存的, 数值的取值范围是(0~255)


2.通过transform.resize()裁剪后的图片是以 float64的格式存储的,数值的取值范围是(0~1)。通常在制作tfrecord 数据集的过程中,我们需要将其转换成numpy array的形式,具体代码如下


   
   
  1. '''以io.imread方式读取图片并使用transform形式裁剪图片'''
  2. image = io.imread(train_dir) #读图并显示
  3. plt.imshow(image)
  4. image =transform.resize(image, ( 208, 208))
  5. img = image * 255 #将图片的取值范围改成(0~255)
  6. img = img.astype(np.uint8)
  7. plt.imshow(img)




Tensorflow中,在训练图片数据之前,需要先对图片进行预处理,读图和裁剪是最基本的两步。常见的的读图何裁剪分别有两种方式,这里小编将和大家分享下这几种方式的实现以及他们之间的区别。

一、常见的两种读图方式 io.imread() 和 cv2.imread()

1.io.imread 读出的图片格式是uint8,value是numpy array 类型。对于RGB 图片,图像数据是以RGB 的格式进行存储的。



2.cv2.imread读出的图片格式是uint8 ,value也是numpy array 类型。唯一的区别是,图像数据格式是以BGR的格式进行存储的。需要将存储类型改成RGB 的形式才能正常显示原图的颜色。特别是制作tfrecord 时,需要将图片通道改成RGB,具体代码如下。


   
   
  1. import cv2
  2. import matplotlib.pyplot as plt
  3. from skimage import transform
  4. import numpy as np
  5. import skimage.io as io
  6. train_dir = 'E:/TensorFlow/Project_TF/flower_tfrecord/data/test/roses/timg.jpg'
  7. '''以cv2方式读取图片'''
  8. image=cv2.imread(train_dir)
  9. b,g,r = cv2.split(image) #将图像通道分离开
  10. rgb_image = cv2.merge([r,g,b]) #以RGB的形式重新组合
  11. #image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) 也可以使用这个函数直接转换成RGB 形式
  12. plt.imshow(rgb_image)
  13. '''以io.imread方式读取图片'''
  14. #image = io.imread(train_dir) #读图并显示
  15. #plt.imshow(image)

二、常见的两种图片裁剪方式 cv2.resize() 和 transform.resize()

1.通过cv2.resize()裁剪后的图片还是以 numpy array 的方式保存的, 数值的取值范围是(0~255)


2.通过transform.resize()裁剪后的图片是以 float64的格式存储的,数值的取值范围是(0~1)。通常在制作tfrecord 数据集的过程中,我们需要将其转换成numpy array的形式,具体代码如下


   
   
  1. '''以io.imread方式读取图片并使用transform形式裁剪图片'''
  2. image = io.imread(train_dir) #读图并显示
  3. plt.imshow(image)
  4. image =transform.resize(image, ( 208, 208))
  5. img = image * 255 #将图片的取值范围改成(0~255)
  6. img = img.astype(np.uint8)
  7. plt.imshow(img)

https://blog.csdn.net/qq_24193303/article/details/79970819

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值