2015-11-20 9 views
6

Voglio implementare VGG Face Descriptor in python. Ma continuo a ricevere un errore:VGG Face Descriptor in python con caffe

TypeError: can only concatenate list (not "numpy.ndarray") to list

Il mio codice:

import numpy as np 
import cv2 
import caffe 
img = cv2.imread("ak.png") 
img = cv2.cvtColor(img, cv2.COLOR_RGB2BGR) 
net = caffe.Net("VGG_FACE_deploy.prototxt","VGG_FACE.caffemodel", caffe.TEST) 
print net.forward(img) 

mi potete aiutare?

UPDATE 1

codice Questo lavoro è esempio in MATLAB

% Copyright (c) 2015, Omkar M. Parkhi 
% All rights reserved. 
img = imread('ak.png'); 
img = single(img); 

    Img = [129.1863,104.7624,93.5940] ; 

img = cat(3,img(:,:,1)-averageImage(1),... 
    img(:,:,2)-averageImage(2),... 
    img(:,:,3)-averageImage(3)); 

img = img(:, :, [3, 2, 1]); % convert from RGB to BGR 
img = permute(img, [2, 1, 3]); % permute width and height 

model = 'VGG_FACE_16_deploy.prototxt'; 
weights = 'VGG_FACE.caffemodel'; 
caffe.set_mode_cpu(); 
net = caffe.Net(model, weights, 'test'); % create net and load weights 

res = net.forward({img}); 
prob = res{1}; 

caffe_ft = net.blobs('fc7').get_data(); 
+0

perché non stai usando 'caffe.io.load_image'? – Shai

+0

Se provo 'caffe.io.load_image' ho lo stesso errore' TypeError: posso solo concatenare lista (non "numpy.ndarray") per elencare'. Se provo a passare un singolo elenco di elementi al metodo ottengo errore 'TypeError: tipo non disattivabile: 'numpy.ndarray'' – Iwn

+0

prova' net.forward_all' invece di 'forward'. – Shai

risposta

7

usare l'interfaccia Python è necessario per trasformare l'immagine in ingresso prima di alimentazione alla rete

img = caffe.io.load_image("ak.png") 
img = img[:,:,::-1]*255.0 # convert RGB->BGR 
avg = np.array([93.5940, 104.7624, 129.1863]) # BGR mean values 
img = img - avg # subtract mean (numpy takes care of dimensions :) 

Ora img è H -by- W -da-3 serie NumPy.
Caffe si aspetta i suoi ingressi come 4D: batch_index x canale x larghezza x altezza.
Pertanto è necessario transpose l'ingresso e aggiungere una dimensione Singleton per rappresentare il "batch_index" leader dimensione

img = img.transpose((2,0,1)) 
img = img[None,:] # add singleton dimension 

Ora è possibile eseguire il passo in avanti

out = net.forward_all(data = img) 
+0

@Iwn siete i benvenuti;) – Shai

+0

da dove viene questa media? – maxbellec

+0

@maxou era parte della domanda. – Shai

0

Prova a passare un elenco unico elemento al metodo.

net.forward ([img]) 
+1

Whetn lo provo, ricevo questo errore: TypeError: inhindable type: 'numpy.ndarray ' – Iwn

1

OpenCV legge in BGR e scalato a 255 per impostazione predefinita, quindi:

img = cv2.imread('ak.png') 
avg = np.array([93.5940,104.7624,129.1863]) # BGR mean from VGG 
img -= avg # subtract mean 
img = img.transpose((2,0,1)) # to match image input dimension: 3x224x224 
img = img[None,:] # add singleton dimension to match batch dimension 
out = net.forward_all(data = img)