ویژهچهره
چهره های ویژه (به انگلیسی: Eigenface) به یک سری از بردارویژه ها گفته میشود که برای حل مسئله تشخیص چهره در بینایی ماشین استفاده میشوند.[۱] این روش توسط Sirovich and Kirby ابداع شده است. [۲] [۳]بردار ویژه های استفاده شده در این روش با استفاده از ماتریس کوواریانس داده های در ابعاد بالا تولید میشوند. این روش به ما کمک میکند تا داده ها را از بعد بالا به یک بعد پایین تر بیاوریم.
تولید بردار های ویژه
[ویرایش]برای تولید بردار ویژه های کافی که فضای مسئله را توصیف کنند نیاز به داده های چهره های انسان داریم که از نظر شرایط نوری و زاویه دید و محل قرارگیری چهره و اجزای آن مانند بینی و چشم شرایط مشابهی داشته باشند. ما از روش بررسی مولفه های اصلی (به انگلیسی: : Principal Component Analysis) یا PCA استفاده میکنیم. [۴]
در واقع چهره های به دست آمده از PCA یک سری پایه برای فضای تمامی چهره ها میتوان در نظر گرفت به طوری که تمامی چهره ها را به صورت ترکیب خطی مولفههای اصلی مینویسیم. این روش ها قابل استفاده در کاربرد های دیگر همچون لبخوانی، تشخیص صوت و تشخیص دست نوشته نیز است.
درواقع اگر بخواهیم پنچ گام اصلی به دست آوردن چهره های ویژه را توصیف کنیم به صورت زیر است:
- آماده کردن یک مجموعه از داده که شرایط ذکر شده (نوری، زاویه دید و...) را داشته باشند
- میانگین داده ها را صفر میکنیم. (با کم کردن عکس میانگین از تمامی عکس های مجموعه داده ها)
- بردار ویژه و مقدار ویژه های ماتریس کوواریانس را حساب میکنیم.
- مولفه های اصلی به ترتیب مربوط به بزگرترین مقادیر ویژه هستند و آن ها را با مرتب سازی به دست می آوریم. جمع مقادیر ویژه را مینامیم.
- k را پیدا میکنیم به طوری که بیشتر شود. اپسیلون بستگی به مقدار دقت ما قابل تنظیم است.
نمونه کد پایتون
[ویرایش]import numpy as np
import math
#gamma_v is the dataset images
mean_vector = np.mean(gamma_v, axis = 1)
phi = []
for i in range(OBSERVATION):
phi.append(gamma_v[:,i] - mean_vector)
phi = np.array(phi).T
gram = phi.T @ phi
v,s_2,v_T = np.linalg.svd(gram)
indices = s_2.argsort()
v = v[indices[::-1]]
#A = u s vT => u = A v sT
u = phi @ v @ np.linalg.inv(np.diag(np.sqrt(s_2)))
eigen_face = u[:,0:5]
print(eigen_face)
نمونه کد متلب
[ویرایش]clear all;
close all;
load yalefaces
[h, w, n] = size(yalefaces);
d = h * w;
% vectorize images
x = reshape(yalefaces, [d n]);
x = double(x);
% subtract mean
mean_matrix = mean(x, 2);
x = bsxfun(@minus, x, mean_matrix);
% calculate covariance
s = cov(x');
% obtain eigenvalue & eigenvector
[V, D] = eig(s);
eigval = diag(D);
% sort eigenvalues in descending order
eigval = eigval(end: - 1:1);
V = fliplr(V);
% show mean and 1st through 15th principal eigenvectors
figure, subplot(4, 4, 1)
imagesc(reshape(mean_matrix, [h, w]))
colormap gray
for i = 1:15
subplot(4, 4, i + 1)
imagesc(reshape(V(:, i), h, w))
end
محسابه بهینه بردار ویژه
[ویرایش]خیلی از اوقات محسابه بردارویژه ها هزینه بر و عملا غیر ممکن است. زیرا اندازه ماتریس کوواریانس برابر با که ��عداد پیکسل های عکس است میشود. برای حل این مشکل از رویکرد زیر استفاده میکنیم.
فرض کنید ماتریس ورودی ها که میانگینش صفر است میباشد. بنا به تعریف ماتریس کوواریانس برابر است. میدانیم بردار ویژه ها از رابطه زیر به دست میآیند.
ماتریس ماتریس از ابعاد است. بجای بردار ویژه های ، بردار ویژه های را بدست می آوریم.
با ضرب در دو طرف رابطه به رابطه زیر میرسیم.
درواقع با بدست آوردن بردار ویژه های می توان با ضرب به بردار ویژه های رسید.[۵]
استفاده در سیستم های تشخیص چهره
[ویرایش]انگیزه ما برای تبدیل عکس به یک سری بردارویژه، استفاده از آن ها برای تشخیص چهره بود. ابتدا با استفاده از یک مجموعه داده که داده هایی هستند که باید آن ها را تایید کنیم یک سری بردار ویژه برای توصیف فضای تمامی عکس ها میسازیم. سپس با استفاده از رابطه زیر عکس جدیدی که باید وجود یا عدم وجود آن در مجموعه دادههای خود تایید کنیم را در فضای جدید بدست می آوریم. ها ضرایب در فضای جدید هستند.[۳]
بردار عکس میانگین و بردار ویژه i ام است.
سپس با استفاده از یک متریک مانند فاصله L2 یا ضریب پیرسن میتوانیم نزدیک بودن عکس جدید به عکس های مجموعه خود را تایید کنیم. برای مثال استفاده از نرم L2 به شکل زیر میشود.
سپس با استفاده از یک آستانه مانند وجود داده در مجموعه خود را رد میکنیم. همچنین از این الگوریتم برای تشخیص این که تصویر چهره انسان است یا خیر نیز میتوان استفاده کرد . کافی است دو آستانه مانند و را در نظر بگیریم و هایی که از بیشتر هستند را عکس غیرانسان (چهره) و هایی که بین و هستند را عکس هایی که در مجموعه داده نیستند اما همچنان مربوط به چهره یک انسان ناشناخته هستند در نظر بگیریم.
منابع
[ویرایش]- ↑ "سیستم تشخیص چهره". ویکیپدیا، دانشنامهٔ آزاد. 2022-10-09.
- ↑ Sirovich, L.; Kirby, M. (1987-03-01). "Low-dimensional procedure for the characterization of human faces". Journal of the Optical Society of America A (به انگلیسی). 4 (3): 519. doi:10.1364/JOSAA.4.000519. ISSN 1084-7529.
- ↑ ۳٫۰ ۳٫۱ Yang, M.-H.; Ahuja, N.; Kriegman, D. (2009). "Face recognition using kernel eigenfaces". Proceedings 2000 International Conference on Image Processing (Cat. No.00CH37101). 1: 37–40 vol.1. doi:10.1109/ICIP.2000.900886.
- ↑ "تحلیل مؤلفههای اصلی". ویکیپدیا، دانشنامهٔ آزاد. 2022-10-17.
- ↑ Pattern Recognition and Machine Learning (Information Science and Statistics).