SVM за разпознаване на пола

Работих тази седмица в проект за разпознаване на пола (в Python), използвайки първоначално: Fisherfaces като метод за извличане на функции и 1-NN класификатор с евклидово разстояние, но сега реших, че не беше достатъчно надежден (по мое скромно мнение), така че Ще използвам SVM, но се губя, когато трябва да създам и обуча модел, за да го използвам в моя набор от данни от изображения, но не мога да намеря решението за командите, от които се нуждая в http://scikit-learn.org. Опитах с този код, но не работи, не знам защо имам тази грешка при изпълнение:

  File "prueba.py", line 46, in main
    clf.fit(R, r)
  File "/Users/Raul/anaconda/lib/python2.7/site-packages/sklearn/svm/base.py", line 139, in fit    
 X = check_array(X, accept_sparse='csr', dtype=np.float64, order='C')
  File "/Users/Raul/anaconda/lib/python2.7/site-packages/sklearn/utils/validation.py", line 350, in check_array
    array.ndim)
ValueError: Found array with dim 3. Expected <= 2

И това е моят код:

import os, sys
import numpy as np
import PIL.Image as Image
import cv2
from sklearn import svm


def read_images(path, id, sz=None):
    c = id
    X,y = [], []
    for dirname, dirnames, filenames in os.walk(path):
        for subdirname in dirnames:
            subject_path = os.path.join(dirname, subdirname)
            for filename in os.listdir(subject_path):
                try:
                    im = Image.open(os.path.join(subject_path, filename))
                    im = im.convert("L")
                    # resize to given size (if given)
                    if (sz is not None):
                        im = im.resize(sz, Image.ANTIALIAS)
                    X.append(np.asarray(im, dtype=np.uint8))
                    y.append(c)
                except IOError as e:
                    print "I/O error({0}): {1}".format(e.errno, e.strerror)
                except:
                    print "Unexpected error:", sys.exc_info()[0]
                    raise
                        #c = c+1
    return [X,y]


def main():
    # check arguments
    if len(sys.argv) != 3:
        print "USAGE: example.py </path/to/images/males> </path/to/images/females>"
        sys.exit()
    # read images and put them into Vectors and id's
    [X,x] = read_images(sys.argv[1], 1)
    [Y, y] = read_images(sys.argv[2], 0)
    # R all images and r all id's
    [R, r] = [X+Y, x+y]
    clf = svm.SVC()
    clf.fit(R, r)





if __name__ == '__main__':
    main()

Ще се радвам на всякакъв вид помощ за това как мога да направя разпознаване на пола със SVM. Благодаря за четенето


person Raul S    schedule 29.04.2015    source източник


Отговори (1)


X.append(np.asarray(im, dtype=np.uint8))

Предполагам, че това е добавяне на 2d-масив. Може да искате да изравните го, преди да добавите, така че всеки екземпляр да изглежда така:

array([255, 255, 255, ..., 255, 255, 255], dtype=uint8)

вместо:

array([
   [255, 255, 255, ..., 255, 255, 255],
   [255, 255, 255, ..., 255, 255, 255],
   [255,   0,   0, ...,   0,   0,   0],
   ..., 
   [255,   0,   0, ...,   0,   0,   0],
   [255, 255, 255, ..., 255, 255, 255],
   [255, 255, 255, ..., 255, 255, 255]], dtype=uint8)

Опитайте тази:

X.append(np.asarray(im, dtype=np.uint8).ravel())
person greeness    schedule 30.04.2015
comment
Благодаря @greeness, сега мога да създам модела, за да правя прогнози. Сега всичко, което трябва да направя, е да заредя изображението на лицето, което искам да анализирам, и да направя clf.predict(на изображението) и ако резултатът, който получавам, е 1 е мъж и жена, ако получа 0? Благодаря за отговора - person Raul S; 30.04.2015