要注意一点的就是:Caffe中彩色图像的通道是BGR格式,图像存储是【0,255】
1.caffe.io.load_image方式 view plai cop
- image = caffe.io.load_image(image_file)
使用caffe.io.load_image()读进来的是RGB格式和0~1(float)
所以在进行识别之前要在transformer中设置transformer.set_raw_scale('data',255)(缩放至0~255)
以及transformer.set_channel_swap('data',(2,1,0)(将RGB变换到BGR)
-
- transformer.set_raw_scale('data', 255)
- transformer.set_channel_swap('data', (2,1,0))
2.使用cv2.imread()来读取图片
cv2.imread()接口读图像,读进来直接是BGR 格式and 0~255
所以不需要再缩放到【0,255】和通道变换【2,1,0】,不需要transformer.set_raw_scale('data',255)和transformer.set_channel_swap('data',(2,1,0))
3.使用PIL来读取图片
对于彩色图像,不管其图像格式是PNG,还是BMP,或者JPG,在PIL中,使用Image模块的open()函数打开后,返回的图像对象的模式都是“RGB”。而对于灰度图像,不管其图像格式是PNG,还是BMP,或者JPG,打开后,其模式为“L”。所以需要转换格式,但不需要缩放到[0,255]
- data = np.array(Image.open(self.dataRoot+img_list))
- data = np.transpose(data,(2,0,1))
- data[[0,2],...] = data[[2,0],...]
4.对于matlab来说
Caffe中的blobs格式是N*C*H*W,分别是数量Number,通道数Channel,以及宽度Height和宽度Width
而matlab中是先宽后高,即[w,h],图像的通道是RGB
所以需要进行相应的转换:
im_data = im (:,:,[3,2,1]) ; %RGB to BGR
im_data = permute(im_data, [2,1,3]); %旋转高度和宽度
最后,分享一个Caffe的典型python识别代码:
-
-
-
-
-
- import numpy as np
- import caffe
- import sys
- caffe_root = 'F:/Caffe'
- sys.path.insert(0, caffe_root + '/python')
-
- size = 227
- image_file = 'F:/.../.../nihao.jpg'
- model_def = 'F:/.../.../deploy.prototxt'
- model_weights = 'F:/.../.../_iter_20000.caffemodel'
- net = caffe.Net(model_def, model_weights, caffe.TEST)
-
-
- mu = np.load(caffe_root + '/python/caffe/imagenet/ilsvrc_2012_mean.npy')
- mu = mu.mean(1).mean(1)
-
-
-
-
-
-
-
-
- transformer = caffe.io.Transformer({'data': net.blobs['data'].data.shape})
-
- transformer.set_transpose('data', (2,0,1))
- transformer.set_mean('data', mu)
-
-
- transformer.set_raw_scale('data', 255)
- transformer.set_channel_swap('data', (2,1,0))
- net.blobs['data'].reshape(1,3,size, size)
-
-
- image = caffe.io.load_image(image_file)
-
- net.blobs['data'].data[...] = transformer.preprocess('data', image)
-
-
- caffe.set_mode_cpu()
- output = net.forward()
-
- output_prob = output['prob'][0].argmax()