Volání rozhraní API pro predikce
Po vytrénování modelu ho můžete programově otestovat odesláním obrázků do koncového bodu rozhraní API pro predikce. V této příručce se dozvíte, jak volat rozhraní API pro predikce k určení skóre obrázku. Dozvíte se různé způsoby, jak můžete nakonfigurovat chování tohoto rozhraní API tak, aby vyhovovalo vašim potřebám.
Poznámka:
Tento dokument ukazuje použití klientské knihovny .NET pro jazyk C# k odeslání obrázku do rozhraní API pro predikce. Další informace a příklady najdete v referenčních informacích k rozhraní API pro predikce.
Nastavení
Publikování vytrénované iterace
Na webu Custom Vision vyberte projekt a pak vyberte kartu Výkon.
Pokud chcete odeslat obrázky do rozhraní API pro predikce, musíte nejprve publikovat iteraci pro predikci, kterou můžete provést výběrem možnosti Publikovat a zadáním názvu publikované iterace. Díky tomu bude váš model přístupný pro rozhraní API pro predikce vašeho prostředku Azure Custom Vision.
Po úspěšném publikování modelu se vedle iterace na levém bočním panelu zobrazí publikovaný popisek a jeho název se zobrazí v popisu iterace.
Získání adresy URL a klíče předpovědi
Po publikování modelu můžete požadované informace načíst výběrem adresy URL předpovědi. Otevře se dialogové okno s informacemi o použití rozhraní API pro predikce, včetně adresy URL předpovědi a prediktivního klíče.
Odeslání dat do služby
V této příručce se předpokládá, že jste už vytvořili objekt CustomVisionPredictionClient s názvem predictionClient
, s klíčem pro predikci služby Custom Vision a adresou URL koncového bodu. Pokyny k nastavení této funkce najdete v jednom z rychlých startů.
V této příručce použijete místní image, proto si stáhněte obrázek, který chcete odeslat do natrénovaného modelu. Následující kód vyzve uživatele k zadání místní cesty a získá bajtstream souboru v této cestě.
Console.Write("Enter image file path: ");
string imageFilePath = Console.ReadLine();
byte[] byteData = GetImageAsByteArray(imageFilePath);
Zahrňte následující pomocnou metodu:
private static byte[] GetImageAsByteArray(string imageFilePath)
{
FileStream fileStream = new FileStream(imageFilePath, FileMode.Open, FileAccess.Read);
BinaryReader binaryReader = new BinaryReader(fileStream);
return binaryReader.ReadBytes((int)fileStream.Length);
}
Metoda ClassifyImageAsync přebírá ID projektu a místně uloženou image a vyhodnotí obrázek podle daného modelu.
// Make a prediction against the new project
Console.WriteLine("Making a prediction:");
var result = predictionApi.ClassifyImageAsync(project.Id, publishedModelName, byteData);
Určení způsobu zpracování dat
Volitelně můžete nakonfigurovat způsob, jakým služba provede operaci vyhodnocování, a to výběrem alternativních metod. Podrobnosti najdete v metodě CustomVisionPredictionClient.
Pro jednoduchost můžete použít nesynchronní verzi předchozí metody, ale může to způsobit, že se program uzamkne po znatelnou dobu.
Metody -WithNoStore
vyžadují, aby služba po dokončení předpovědi nezachovává obrázek předpovědi. Za normálních okolností si služba tyto image uchovává, takže máte možnost je přidat jako trénovací data pro budoucí iterace modelu.
Metody -WithHttpMessages
vrátí nezpracovanou odpověď HTTP volání rozhraní API.
Získání výsledků ze služby
Služba vrátí výsledky ve formě ImagePrediction objektu. Vlastnost Predictions
obsahuje seznam PredictionModel objekty, které každý představuje jednu předpověď objektu. Zahrnují název popisku a souřadnice ohraničujícího rámečku, kde byl objekt zjištěn na obrázku. Vaše aplikace pak může tato data analyzovat, například zobrazit obrázek s poli označenými objekty na obrazovce.
Další krok
V této příručce jste zjistili, jak odeslat obrázky do vlastního klasifikátoru nebo detektoru obrázků a získat odpověď prostřednictvím kódu programu pomocí sady C# SDK. Dále se dozvíte, jak dokončit kompletní scénáře pomocí jazyka C# nebo začít používat jinou jazykovou sadu SDK.