tensorflow中两种读图及裁剪图片的区别(io.imread和cv2.imread)以及(transform.resize和cv2.resize)

原创 2018年04月17日 11:16:05

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,具体代码如下。

import cv2
import matplotlib.pyplot as plt
from skimage import transform 
import numpy as np
import skimage.io as io  

train_dir = 'E:/TensorFlow/Project_TF/flower_tfrecord/data/test/roses/timg.jpg'

'''以cv2方式读取图片'''
image=cv2.imread(train_dir)
b,g,r = cv2.split(image)     #将图像通道分离开
rgb_image = cv2.merge([r,g,b]) #以RGB的形式重新组合

#image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)  也可以使用这个函数直接转换成RGB 形式
plt.imshow(rgb_image)

'''以io.imread方式读取图片'''
#image = io.imread(train_dir)  #读图并显示  
#plt.imshow(image)
 

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

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


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

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

plt.imshow(img) 
读图和裁剪图片在制作tfrecord数据集时,是很基础的步骤,在接下来,我还将进一步更新如何制作自己的tfrecord数据集,以及tfrecord的读取。如有谬误,还请大家斧正。还望共同进步  大笑大笑



嵌入式读图基础

只要是嵌入式,不管是硬件设计还是软件设计,其实都面临着怎么读图这样一个问题。 在这套课程里主要讲解分立器件,由浅入深的讲解,结合一些比较简单的、有代表性的电路,达到实战性的目的。 课程特色: 1)结合简单的、有代表性的电路; 2)由浅入深、通俗易懂;
  • 2018年04月18日 15:32

python 图像的形变, 旋转与缩放 (transform) (1)

http://blog.csdn.net/denny2015/article/details/50532971 图像的形变与缩放,使用的是skimage的transform模块,...
  • wuguangbin1230
  • wuguangbin1230
  • 2017-05-03 09:49:50
  • 3825

Tensorflow中图像处理函数(图像大小调整)

图像大小的调整方式:在Tensorflow中通过tf.image.resize_images函数实现; 1.双线性插值算法(Bilinear interpolation);Method取值为:0; ...
  • zSean
  • zSean
  • 2017-07-30 14:46:51
  • 4091

tensorflow里面用于改变图像大小的函数

tensorflow里面用于改变图像大小的函数是tf.image.resize_images(image, (w, h), method):image表示需要改变此存的图像,第二个参数改变之后图像的大...
  • UESTC_C2_403
  • UESTC_C2_403
  • 2017-05-24 19:16:48
  • 7268

人脸识别(2)--Python3.6+OpenCV3.2识别实例

这里提供两个简单实例: 调用摄像头获取图片进行实时检测 本地获取图片进行人脸检测并保存图片 前提条件: 确保python+opencv环境已经搭建成功。搭建步骤可以参考上一篇博客:http://bl...
  • u012842255
  • u012842255
  • 2017-04-16 11:59:43
  • 6913

OpenCV(3.2)+Python(3.6)学习(基于官方API)(一)

OpenCV+Python学习(基于官方API)  博主决定将OpenCV官方文档完全理解一遍,力求不放过任何一行代码,并且用博客记录学习的过程(官方文档的第一部分是关于opencv的安装,这里不做介...
  • qq_31136635
  • qq_31136635
  • 2017-02-28 10:36:43
  • 4191

vim+python+OpenCV学习六 : 形态学初级

#coding=utf-8 import cv2 import numpy as np img=cv2.imread(r'test1.jpg') ''' NpKernel = np.uint8(...
  • shawncheer
  • shawncheer
  • 2016-03-05 20:59:40
  • 445

[数字图像处理实验][python+opencv]'module' object has no attribute 'cv'

数字图像处理实验五-图像分割、表示与特征提取 做到旋转的边界矩形时,cv2.cv.BoxPoints()函数处出现'module' object has no attribute 'cv' 的错误 i...
  • lostbear_hyl
  • lostbear_hyl
  • 2015-05-08 23:32:37
  • 7253

小强学Python+OpenCV之-1.4.1平移、旋转、缩放、翻转-之实践

平移、旋转、缩放、翻转-之实践
  • eric_pycv
  • eric_pycv
  • 2017-05-23 09:38:33
  • 8028

vim+python+OpenCV学习六 : 滤波初级

#coding=utf-8 #用低通滤波来平滑图像,低通滤波器的目标是降低图像的变化率。 #将每个像素替换为该像素周围像素的均值。 #这样就可以平滑并替代那些强度变化明显的区域 import cv...
  • shawncheer
  • shawncheer
  • 2016-03-05 22:39:15
  • 280
收藏助手
不良信息举报
您举报文章:tensorflow中两种读图及裁剪图片的区别(io.imread和cv2.imread)以及(transform.resize和cv2.resize)
举报原因:
原因补充:

(最多只允许输入30个字)