Spisu treści:
2025 Autor: John Day | [email protected]. Ostatnio zmodyfikowany: 2025-01-13 06:58
Głównym celem tej instrukcji jest pokazanie, jak łatwe będzie przetwarzanie obrazu przy pomocy MATLAB
Wykrywanie i śledzenie twarzy było ważną i aktywną dziedziną badań, dlatego wyjaśnię, jak można to zrobić za pomocą Matlaba.
W poniższym tutorialu zrobię poniższe rzeczy:
1.wykrywanie twarzy na obrazie i liczenie.
2.wykrywanie ludzkich oczu na obrazie i liczenie.
3.wykrywanie ust człowieka na obrazie i liczenie.
4.detecting twarze w filmie i liczenie.
5.wykrywanie ludzkich oczu w filmie i liczenie.
6. wykrywanie ludzkich ust w filmie i liczenie.
Krok 1: Wykrywanie twarzy na obrazie i liczenie
SCENARIUSZ MATLABOWY:
wyczyść wszystko % wyczyść wszystkie obiektyclc % wyczyść ekran
FDetect = wizja. CascadeObjectDetector; %Wykryj obiekty za pomocą algorytmu Viola-Jones
% Przeczytaj obraz wejściowy
image = imread('c:\Deskotp\HarryPotter.jpg'); % załaduj obraz za pomocą imread('lokalizacja pliku\nazwa.jpg')
BB = krok (FDetect, obraz); %Zwraca wartości obwiedni na podstawie liczby obiektów
rysunek, imshow(I);
trzymać się
dla i = 1:rozmiar(BB, 1)
prostokąt('Pozycja', BB(i,:), 'Szerokość Linii', 5, 'Styl Linii', '-', 'Kolor Krawędzi', 'r'); %r -czerwony, g-zielony, b-niebieski
kończyć się
title('Wykrywanie twarzy'); %tytuł figury wyłączony;
Wynik będzie podobny do obrazu, który został dołączony w tym kroku
Aby policzyć liczbę wykrytych twarzy:
wyczyść wszystko % wyczyść wszystkie obiektyclc % wyczyść ekran
FDetect = wizja. CascadeObjectDetector; %Wykryj obiekty za pomocą algorytmu Viola-Jones %Odczytaj obraz wejściowy
image = imread('c:\Deskotp\HarryPotter.jpg'); % załaduj obraz za pomocą imread('lokalizacja pliku\nazwa.jpg')
BB = krok (FDetect, obraz); %Zwraca wartości obwiedni na podstawie liczby obiektów
postać,
imshow(I);
trzymać się
dla i = 1:rozmiar(BB, 1)
prostokąt('Pozycja', BB(i,:), 'Szerokość Linii', 5, 'Styl Linii', '-', 'Kolor Krawędzi', 'r'); %r -czerwony, g-zielony, b-niebieski
kończyć się
text(10, 10, strcat('\kolor{czerwony} Liczba twarzy =', num2str(długość(BB)))); Ta linia daje ci liczbę
title('Wykrywanie twarzy'); % tytuł figury
wstrzymaj się;
Krok 2: Wykrywanie ludzkich oczu na obrazie i liczenie
SCENARIUSZ MATLABOWY:
Wyczyść wszystko;
kl;
%Aby wykryć EyesEyeDetect = vision. CascadeObjectDetector('EyePairBig');
% Przeczytaj dane wejściowe
image = imread('c:\Deskotp\HarryPotter.jpg'); % załaduj obraz za pomocą imread('lokalizacja pliku\nazwa.jpg')
BB=krok(Wykrywanie oczu, obraz);
postać,
imshow(obraz);
prostokąt('Pozycja', BB, 'Szerokość Linii', 4, 'Styl Linii', '-', 'Kolor Krawędzi', 'b');
title('Wykrywanie oczu');
Wynik będzie podobny do obrazu, który został dołączony w tym kroku
Aby policzyć liczbę wykrytych oczu:
wyczyść wszystko;clc; % Aby wykryć oczy
EyeDetect = vision. CascadeObjectDetector('EyePairBig');
image = imread('c:\Deskotp\HarryPotter.jpg'); % załaduj obraz za pomocą imread('lokalizacja pliku\nazwa.jpg')
BB=step(EyeDetect, obraz);figura, imshow(obraz); prostokąt('Pozycja', BB, 'Szerokość Linii', 4, 'Styl Linii', '-', 'Kolor Krawędzi', 'b');
text(10, 10, strcat('\kolor{czerwony} Liczba oczu =', num2str(długość(BB))));
title('Wykrywanie oczu');
Krok 3: Wykrywanie ust człowieka na obrazie i liczenie
SCENARIUSZ MATLABOWY:
Wyczyść wszystko;
kl;
%Aby wykryć usta
MouthDetect = wizja. CascadeObjectDetector('Usta', 'MergeThreshold', 16);
%Odczytaj obraz wejściowy = imread('c:\Deskotp\HarryPotter.jpg'); % załaduj obraz za pomocą imread('lokalizacja pliku\nazwa.jpg')
BB=krok(Wykrywanie ust, obraz);
rysunek, imshow(obraz);
trzymać się
dla i = 1:rozmiar(BB, 1)
prostokąt('Pozycja', BB(i,:), 'Szerokość Linii', 4, 'Styl Linii', '-', 'Kolor Krawędzi', 'r');
kończyć się
title('Wykrywanie ust');
wstrzymaj się;
Wynik będzie podobny do obrazu, który został dołączony w tym kroku
Aby policzyć liczbę wykrytych ust:
Wyczyść wszystko; kl; %Aby wykryć usta
MouthDetect = wizja. CascadeObjectDetector('Usta', 'MergeThreshold', 16); % Przeczytaj dane wejściowe
image = imread('c:\Deskotp\HarryPotter.jpg'); % załaduj obraz używając imread('lokalizacja pliku\name.jpg') BB=step(MouthDetect, image);
rysunek, imshow(obraz);
trzymać się
dla i = 1:rozmiar(BB, 1)
prostokąt('Pozycja', BB(i,:), 'Szerokość Linii', 4, 'Styl Linii', '-', 'Kolor Krawędzi', 'r');
kończyć się
text(10, 10, strcat('\kolor{czerwony} Liczba ust =', num2str(długość(BB))));
title('Wykrywanie ust');
wstrzymaj się;
Krok 4: Wykrywanie twarzy, oczu, ust w filmie i liczenie
Wyczyść wszystko;
zamknij wszystko;
kl;
% Przechwytywanie klatek wideo przy użyciu funkcji wejścia wideo % Musisz zmienić rozdzielczość i nazwę zainstalowanego adaptera.
a=wizja. CascadeObjectDetector; % wykryć twarz
% a=vision. CascadeObjectDetector('Usta', 'MergeThreshold', 16); % wykryć usta
% a=vision. CascadeObjectDetector('ParaOczyDuże'); % do wykrywania oczu
% używaj tylko jednego (twarz/oczy/usta)
vid = videoinput('winvideo', 1, 'yuy2_320x240'); % Ustaw właściwości obiektu wideo
set(vid, 'FramesPerTrigger', Inf);
set(vid, 'Zwrócona przestrzeń kolorów', 'rgb');
vid. FrameGrabInterval = 5; %rozpocznij pobieranie wideo tutaj
start(vid) % Ustawia pętlę, która zatrzymuje się po 100 klatkach akwizycji
while(vid. FramesAcquired<=200) % Pobierz zrzut bieżącej klatki
dane = pobieranapshot(vid);
imshow(dane);
b=krok(a, dane);
trzymać się
dla i=1:rozmiar(b, 1)
prostokąt('pozycja', b(i,:), 'szerokość linii', 2, 'styl linii', '-', 'Kolor krawędzi', 'r');
kończyć się
wstrzymaj się
text(10, 10, strcat('\color{green} Liczba twarzy =', num2str(length(b))));
kończyć się
stop(vid); % Zatrzymaj akwizycję wideo