Określanie modelu wykrywania twarzy
W tym przewodniku przedstawiono sposób określania modelu wykrywania twarzy dla usługi rozpoznawania twarzy platformy Azure.
Usługa rozpoznawania twarzy używa modeli uczenia maszynowego do wykonywania operacji na ludzkich twarzach na obrazach. Nadal zwiększamy dokładność naszych modeli na podstawie opinii klientów i postępów w badaniach, a my dostarczamy te ulepszenia jako aktualizacje modelu. Deweloperzy mogą określić, która wersja modelu wykrywania twarzy ma być używana; mogą wybrać model, który najlepiej pasuje do ich przypadku użycia.
Przeczytaj, aby dowiedzieć się, jak określić model wykrywania twarzy w niektórych operacjach rozpoznawania twarzy. Usługa rozpoznawania twarzy używa wykrywania twarzy za każdym razem, gdy konwertuje obraz twarzy na inną formę danych.
Jeśli nie masz pewności, czy używasz najnowszego modelu, przejdź do sekcji Ocena różnych modeli , aby ocenić nowy model i porównać wyniki przy użyciu bieżącego zestawu danych.
Wymagania wstępne
Należy zapoznać się z koncepcją wykrywania twarzy sztucznej inteligencji. Jeśli nie jesteś, zapoznaj się z przewodnikiem koncepcyjnym dotyczącym wykrywania twarzy lub przewodnikiem z instrukcjami:
Ocena różnych modeli
Różne modele wykrywania twarzy są zoptymalizowane pod kątem różnych zadań. Zapoznaj się z poniższą tabelą, aby zapoznać się z omówieniem różnic.
Model | opis | Uwagi dotyczące wydajności | Punkty orientacyjne |
---|---|---|---|
detection_01 | Domyślny wybór dla wszystkich operacji wykrywania twarzy. | Nie jest zoptymalizowany pod kątem małych, bocznych lub rozmytych twarzy. | Zwraca punkty orientacyjne twarzy, jeśli zostały określone w wywołaniu wykrywania. |
detection_02 | Wydana w maju 2019 r. i dostępna opcjonalnie we wszystkich operacjach wykrywania twarzy. | Zwiększona dokładność na małych, bocznych i rozmytych twarzach. | Nie zwraca punktów orientacyjnych twarzy. |
detection_03 | Wydana w lutym 2021 r. i dostępna opcjonalnie we wszystkich operacjach wykrywania twarzy. | Dodatkowo zwiększona dokładność, w tym na mniejszych twarzach (64x64 pikseli) i obróconych orientacji twarzy. | Zwraca punkty orientacyjne twarzy, jeśli zostały określone w wywołaniu wykrywania. |
Atrybuty to zestaw funkcji, które można opcjonalnie wykryć, jeśli zostały określone w wywołaniu wykrywania:
Model | Akcesoria | zacierać | Narażenie | okulary | headPose | Maska | noise | Okluzji | qualityForRecognition |
---|---|---|---|---|---|---|---|---|---|
detection_01 | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ (dla recognition_03 lub 04) | |
detection_02 | |||||||||
detection_03 | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ (dla recognition_03 lub 04) |
Najlepszym sposobem porównania wydajności modeli wykrywania jest użycie ich w przykładowym zestawie danych. Zalecamy wywołanie interfejsu API wykrywania na różnych obrazach, zwłaszcza obrazów wielu twarzy lub twarzy, które są trudne do zobaczenia, przy użyciu każdego modelu wykrywania. Zwróć uwagę na liczbę twarzy zwracanych przez każdy model.
Wykrywanie twarzy przy użyciu określonego modelu
Wykrywanie twarzy znajduje lokalizacje pola ograniczenia ludzkich twarzy i identyfikuje ich wizualne elementy krajobrazu. Wyodrębnia ona funkcje twarzy i przechowuje je do późniejszego użycia w operacjach rozpoznawania .
W przypadku korzystania z interfejsu API wykrywania można przypisać wersję modelu za pomocą parametru detectionModel
. Dostępne wartości to:
detection_01
detection_02
detection_03
Adres URL żądania dla interfejsu API REST detect wygląda następująco:
https://westus.api.cognitive.microsoft.com/face/v1.0/detect?detectionModel={detectionModel}&recognitionModel={recognitionModel}&returnFaceId={returnFaceId}&returnFaceAttributes={returnFaceAttributes}&returnFaceLandmarks={returnFaceLandmarks}&returnRecognitionModel={returnRecognitionModel}&faceIdTimeToLive={faceIdTimeToLive}
Jeśli używasz biblioteki klienta, możesz przypisać jej wartość detectionModel
, przekazując odpowiedni ciąg. Jeśli pozostawisz go bez przypisania, interfejs API używa domyślnej wersji modelu (detection_01
). Zapoznaj się z poniższym przykładem kodu dla biblioteki klienta platformy .NET.
string imageUrl = "https://raw.githubusercontent.com/Azure-Samples/cognitive-services-sample-data-files/master/Face/images/detection1.jpg";
var response = await faceClient.DetectAsync(new Uri(imageUrl), FaceDetectionModel.Detection03, FaceRecognitionModel.Recognition04, returnFaceId: false, returnFaceLandmarks: false);
var faces = response.Value;
Dodawanie twarzy do osoby z określonym modelem
Usługa rozpoznawania twarzy może wyodrębnić dane twarzy z obrazu i skojarzyć je z obiektem Person za pomocą interfejsu API dodawania twarzy osoby grupy osób . W tym wywołaniu interfejsu API można określić model wykrywania w taki sam sposób, jak w obszarze Wykryj.
Zapoznaj się z poniższym przykładem kodu platformy .NET.
// Create a PersonGroup and add a person with face detected by "detection_03" model
string personGroupId = "mypersongroupid";
using (var content = new ByteArrayContent(Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(new Dictionary<string, object> { ["name"] = "My Person Group Name", ["recognitionModel"] = "recognition_04" }))))
{
content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
await httpClient.PutAsync($"{ENDPOINT}/face/v1.0/persongroups/{personGroupId}", content);
}
string? personId = null;
using (var content = new ByteArrayContent(Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(new Dictionary<string, object> { ["name"] = "My Person Name" }))))
{
content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
using (var response = await httpClient.PostAsync($"{ENDPOINT}/face/v1.0/persongroups/{personGroupId}/persons", content))
{
string contentString = await response.Content.ReadAsStringAsync();
personId = (string?)(JsonConvert.DeserializeObject<Dictionary<string, object>>(contentString)?["personId"]);
}
}
string imageUrl = "https://raw.githubusercontent.com/Azure-Samples/cognitive-services-sample-data-files/master/Face/images/detection1.jpg";
using (var content = new ByteArrayContent(Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(new Dictionary<string, object> { ["url"] = imageUrl }))))
{
content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
await httpClient.PostAsync($"{ENDPOINT}/face/v1.0/persongroups/{personGroupId}/persons/{personId}/persistedfaces?detectionModel=detection_03", content);
}
Ten kod tworzy grupę PersonGroup o identyfikatorze mypersongroupid
i dodaje do niego osobę. Następnie dodaje do tej osoby twarz przy użyciu detection_03
modelu. Jeśli nie określisz parametru detectionModel, interfejs API używa modelu domyślnego . detection_01
Uwaga
Nie musisz używać tego samego modelu wykrywania dla wszystkich twarzy w obiekcie Person i nie musisz używać tego samego modelu wykrywania podczas wykrywania nowych twarzy do porównania z obiektem Person (na przykład w interfejsie API identyfikowania z grupy osób).
Dodawanie twarzy do listy FaceList z określonym modelem
Można również określić model wykrywania podczas dodawania twarzy do istniejącego obiektu FaceList . Zapoznaj się z poniższym przykładem kodu platformy .NET.
using (var content = new ByteArrayContent(Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(new Dictionary<string, object> { ["name"] = "My face collection", ["recognitionModel"] = "recognition_04" }))))
{
content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
await httpClient.PutAsync($"{ENDPOINT}/face/v1.0/facelists/{faceListId}", content);
}
string imageUrl = "https://raw.githubusercontent.com/Azure-Samples/cognitive-services-sample-data-files/master/Face/images/detection1.jpg";
using (var content = new ByteArrayContent(Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(new Dictionary<string, object> { ["url"] = imageUrl }))))
{
content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
await httpClient.PostAsync($"{ENDPOINT}/face/v1.0/facelists/{faceListId}/persistedfaces?detectionModel=detection_03", content);
}
Ten kod tworzy wywołaną aplikację FaceList i dodaje do niej twarz z modelemdetection_03
.My face collection
Jeśli nie określisz parametru detectionModel, interfejs API używa modelu domyślnego . detection_01
Uwaga
Nie musisz używać tego samego modelu wykrywania dla wszystkich twarzy w obiekcie FaceList i nie musisz używać tego samego modelu wykrywania podczas wykrywania nowych twarzy w celu porównania z obiektem FaceList .
Następne kroki
W tym artykule przedstawiono sposób określania modelu wykrywania do użycia z różnymi interfejsami API rozpoznawania twarzy. Następnie postępuj zgodnie z przewodnikiem Szybki start, aby rozpocząć wykrywanie i analizę twarzy.