Uczenie maszynowe do przetwarzania obrazów

Ukończone

Możliwość stosowania filtrów do stosowania efektów do obrazów jest przydatna w zadaniach przetwarzania obrazów, takich jak w przypadku oprogramowania do edycji obrazów. Jednak celem przetwarzania obrazów jest często wyodrębnianie znaczenia lub przynajmniej praktycznych szczegółowych informacji z obrazów; które wymaga utworzenia modeli uczenia maszynowego, które są szkolone do rozpoznawania funkcji na podstawie dużych ilości istniejących obrazów.

Napiwek

W tej lekcji założono, że znasz podstawowe zasady uczenia maszynowego i masz koncepcyjną wiedzę na temat uczenia głębokiego z sieciami neuronowymi. Jeśli dopiero zaczynasz korzystać z uczenia maszynowego, rozważ ukończenie modułu Podstawy uczenia maszynowego w usłudze Microsoft Learn.

Splotowe sieci neuronowe (CNN)

Jedną z najpopularniejszych architektur modelu uczenia maszynowego do przetwarzania obrazów jest splotowa sieć neuronowa (CNN), typ architektury uczenia głębokiego. Sieci CNN używają filtrów do wyodrębniania map funkcji liczbowych z obrazów, a następnie podawania wartości funkcji do modelu uczenia głębokiego w celu wygenerowania przewidywania etykiety. Na przykład w scenariuszu klasyfikacji obrazów etykieta reprezentuje główny temat obrazu (innymi słowy, co to jest obraz?). Możesz wytrenować model CNN z obrazami różnych rodzajów owoców (takich jak jabłko, banan i pomarańczowy), aby etykieta, która jest przewidywana, jest typem owoców na danym obrazie.

Podczas procesu trenowania sieci CNN jądra filtrów są początkowo definiowane przy użyciu losowo wygenerowanych wartości wagowych. Następnie w miarę postępu procesu trenowania przewidywania modeli są oceniane względem znanych wartości etykiet, a wagi filtrów są dostosowywane w celu zwiększenia dokładności. W końcu wytrenowany model klasyfikacji obrazów owoców używa wag filtrów, które najlepiej wyodrębniają cechy, które pomagają zidentyfikować różne rodzaje owoców.

Na poniższym diagramie przedstawiono sposób działania sieci CNN dla modelu klasyfikacji obrazów:

Diagram splotowej sieci neuronowej.

  1. Obrazy ze znanymi etykietami (na przykład 0: jabłko, 1: banan lub 2: pomarańczowy) są przekazywane do sieci w celu wytrenowania modelu.
  2. Co najmniej jedna warstwa filtrów służy do wyodrębniania funkcji z każdego obrazu, ponieważ jest on podawany za pośrednictwem sieci. Jądra filtru zaczynają się od losowo przypisanych wag i generują tablice wartości liczbowych nazywanych mapami funkcji.
  3. Mapy funkcji są spłaszczone w jednowymiarową tablicę wartości cech.
  4. Wartości funkcji są wprowadzane do w pełni połączonej sieci neuronowej.
  5. Warstwa wyjściowa sieci neuronowej używa softmax lub podobnej funkcji, aby wygenerować wynik zawierający wartość prawdopodobieństwa dla każdej możliwej klasy, na przykład [0.2, 0.5, 0.3].

Podczas trenowania prawdopodobieństwa danych wyjściowych są porównywane z rzeczywistą etykietą klasy — na przykład obraz bananu (klasa 1) powinien mieć wartość [0.0, 1.0, 0.0]. Różnica między przewidywanymi i rzeczywistymi ocenami klas służy do obliczania straty w modelu, a wagi w w pełni połączonej sieci neuronowej i jądra filtrów w warstwach wyodrębniania cech są modyfikowane w celu zmniejszenia utraty.

Proces trenowania powtarza się w wielu epokach do momentu uzyskania optymalnego zestawu wag. Następnie wagi są zapisywane i model może służyć do przewidywania etykiet dla nowych obrazów, dla których etykieta jest nieznana.

Uwaga

Architektury sieci CNN zwykle obejmują wiele warstw filtrów splotowych i dodatkowych warstw, aby zmniejszyć rozmiar map funkcji, ograniczyć wyodrębnione wartości i w inny sposób manipulować wartościami funkcji. Te warstwy zostały pominięte w tym uproszczonym przykładzie, aby skupić się na kluczowej koncepcji, która polega na tym, że filtry są używane do wyodrębniania cech liczbowych z obrazów, które są następnie używane w sieci neuronowej do przewidywania etykiet obrazów.

Transformatory i modele wielomodalne

Sieci CNN są podstawą rozwiązań do przetwarzania obrazów od wielu lat. Chociaż są one często używane do rozwiązywania problemów z klasyfikacją obrazów zgodnie z wcześniejszym opisem, są one również podstawą bardziej złożonych modeli przetwarzania obrazów. Na przykład modele wykrywania obiektów łączą warstwy wyodrębniania cech CNN z identyfikacją regionów zainteresowania obrazami w celu zlokalizowania wielu klas obiektów na tym samym obrazie.

Transformatory

Większość postępów w przetwarzaniu obrazów w ciągu dziesięcioleci jest napędzany przez ulepszenia modeli opartych na sieci CNN. Jednak w innej dyscyplinie sztucznej inteligencji — przetwarzanie języka naturalnego (NLP), inny typ architektury sieci neuronowej, nazywany transformatorem umożliwił opracowywanie zaawansowanych modeli języka. Transformatory działają przez przetwarzanie ogromnych ilości danych i tokenów języka kodowania (reprezentujących poszczególne wyrazy lub frazy) jako osadzanie oparte na wektorach (tablice wartości liczbowych). Osadzanie można traktować jako reprezentujące zestaw wymiarów, które każdy z nich reprezentuje jakiś atrybut semantyczny tokenu. Osadzanie jest tworzone w taki sposób, że tokeny, które są często używane w tym samym kontekście, są bliżej siebie wymiarowo niż niepowiązane wyrazy.

W prostym przykładzie na poniższym diagramie przedstawiono kilka wyrazów zakodowanych jako wektory trójwymiarowe i wykreślionych w przestrzeni 3D:

Diagram wektorów tokenu w przestrzeni 3D.

Tokeny, które są semantycznie podobne, są kodowane w podobnych pozycjach, tworząc semantyczny model języka, który umożliwia tworzenie zaawansowanych rozwiązań NLP do analizy tekstu, tłumaczenia, generowania języka i innych zadań.

Uwaga

Użyliśmy tylko trzech wymiarów, ponieważ jest to łatwe do wizualizacji. W rzeczywistości kodery w sieciach przekształcania tworzą wektory o wielu innych wymiarach, definiując złożone relacje semantyczne między tokenami na podstawie obliczeń algebraicznych liniowych. Matematyka jest złożona, podobnie jak architektura modelu przekształcania. Naszym celem jest tylko zapewnienie koncepcyjnego zrozumienia sposobu tworzenia modelu, który hermetyzuje relacje między jednostkami.

Modele wielomodalne

Sukces przekształcania jako sposobu tworzenia modeli językowych skłonił badaczy sztucznej inteligencji do rozważenia, czy takie samo podejście byłoby skuteczne w przypadku danych obrazowych. Wynikiem jest opracowywanie modeli wielomodalnych , w których model jest trenowany przy użyciu dużej liczby podpisów obrazów, bez stałych etykiet. Koder obrazu wyodrębnia funkcje z obrazów na podstawie wartości pikseli i łączy je z osadzaniem tekstu utworzonym przez koder języka. Ogólny model hermetyzuje relacje między osadzaniem tokenów języka naturalnego i funkcjami obrazu, jak pokazano poniżej:

Diagram modelu wielomodalnego, który hermetyzuje relacje między wektorami języka naturalnego i cechami obrazu.

Model Microsoft Florence jest tylko takim modelem. Trenowane przy użyciu ogromnych ilości podpisów obrazów z Internetu, obejmuje zarówno koder języka, jak i koder obrazu. Florencja jest przykładem modelu podstawowego. Innymi słowy, wstępnie wytrenowany ogólny model, na którym można tworzyć wiele modeli adaptacyjnych na potrzeby zadań specjalistycznych. Na przykład można użyć Florencji jako modelu podstawowego dla modeli adaptacyjnych, które wykonują:

  • Klasyfikacja obrazów: identyfikowanie kategorii, do której należy obraz.
  • Wykrywanie obiektów: lokalizowanie pojedynczych obiektów na obrazie.
  • Podpisy: generowanie odpowiednich opisów obrazów.
  • Tagowanie: kompilowanie listy odpowiednich tagów tekstowych dla obrazu.

Diagram modelu Florencji jako modelu podstawowego z wieloma modelami adaptacyjnymi zbudowanymi na nim.

Modele wielomodalne, takie jak Florence, są ogólnie najnowocześniejsze w przetwarzaniu obrazów i sztucznej inteligencji i oczekuje się, że będą napędzać postępy w rodzajach rozwiązań, które sztuczna inteligencja umożliwia.