Delen via


Zelfstudie: Een vooraf getraind afbeeldingsclassificatiemodel implementeren in Azure Functions met PyTorch

In dit artikel leert y hoe u Python, PyTorch en Azure Functions gebruikt om een vooraf getraind model te laden om een afbeelding te classificeren op basis van de inhoud ervan. Omdat u allemaal lokaal werkt en geen Azure-resources in de cloud maakt, zijn er geen kosten verbonden aan het voltooien van deze zelfstudie.

  • Initialiseer een lokale omgeving voor het ontwikkelen van Azure Functions in Python.
  • Importeer een vooraf getraind machine learning-model van PyTorch in een functie-app.
  • Bouw een serverloze HTTP API om een afbeelding te classificeren als een van 1000 klassen van ImageNet.
  • Gebruik de API van een web-app.

Vereisten

Controle van vereisten

  1. Voer in een terminal- of opdrachtvenster func --version uit om te controleren of de Azure Functions Core Tools versie 2.7.1846 of hoger zijn.
  2. Voer python --version (Linux/macOS) of py --version (Windows) uit om uw Python-versierapporten 3.7.x te controleren.

De zelfstudie-opslagplaats klonen

  1. Kloon in een terminal- of opdrachtvenster de volgende opslagplaats met Git:

    git clone https://github.com/Azure-Samples/functions-python-pytorch-tutorial.git
    
  2. Navigeer naar de map en bekijk de inhoud ervan.

    cd functions-python-pytorch-tutorial
    
    • start is de werkmap voor de zelfstudie.
    • end is het uiteindelijke resultaat en de volledige implementatie voor uw referentie.
    • resources bevatten het machine learning-model en de helper-bibliotheken.
    • frontend is een website waarmee de functie-app wordt aangeroepen.

Een virtuele Python-omgeving maken en activeren

Ga naar de start-folder en voer de volgende opdrachten uit om een virtuele omgeving met de naam .venv te maken en te activeren.

cd start
python -m venv .venv
source .venv/bin/activate

Als Python het venv-pakket niet heeft geïnstalleerd in uw Linux-distributie, voert u de volgende opdracht uit:

sudo apt-get install python3-venv

U voert alle volgende opdrachten uit in deze geactiveerde virtuele omgeving. (Voer deactivate uit om de virtuele omgeving te sluiten.)

Een lokaal Functions-project maken

In Azure Functions is een functieproject een container voor een of meer afzonderlijke functies die elk op een bepaalde trigger reageren. Alle functies in een project delen dezelfde lokale configuratie en hostingconfiguratie. In deze sectie maakt u een functieproject met een individuele standaardfunctie met de naam classify die een HTTP-eindpunt biedt. U kunt meer specifieke code toevoegen in een latere sectie.

  1. Gebruik in de map start de Azure Functions Core Tools om een Python-functie-app te initialiseren:

    func init --worker-runtime python
    

    Na initialisatie bevat de map start verschillende bestanden voor het project,waaronder configuratiebestanden met de naam local.settings.json en host.json. Omdat local.settings.json geheimen kan bevatten die zijn gedownload vanuit Azure, wordt het bestand standaard uitgesloten van broncodebeheer in het bestand .gitignore.

    Tip

    Omdat een functieproject is gekoppeld aan een specifieke runtime, moeten alle functies in het project met dezelfde taal worden geschreven.

  2. Voeg een functie toe aan uw project met behulp van de volgende opdracht, waarbij het argument --name de unieke naam van de functie is en het argument --template de trigger van de functie. Maak met func new een submap met de naam van de functie die een codebestand bevat dat geschikt is voor de taal van het project en een configuratiebestand met de naam function.json.

    func new --name classify --template "HTTP trigger"
    

    Met deze opdracht maakt u een map die overeenkomt met de naam van de functie, classify. In die map bevinden zich twee bestanden: __init__.py, die de functiecode bevat en function.json, waarin de trigger van de functie en de bijbehorende invoer- en uitvoerbindingen worden beschreven. Zie programmeermodel in de Ontwikkelaarshandleiding voor Python voor meer informatie over de inhoud van deze bestanden.

De functie lokaal uitvoeren

  1. Start de functie door de lokale Azure Functions runtime host te starten in de map start:

    func start
    
  2. Zodra het eindpunt classify wordt weergegeven in de uitvoer, gaat u naar de URL, http://localhost:7071/api/classify?name=Azure. Het bericht 'Hallo Azure!' wordt weergegeven in de uitvoer.

  3. Gebruik Ctrl-C om de host te stoppen.

Het PyTorch-model importeren en helpercode toevoegen

Als u de functie classify wilt wijzigen om een afbeelding te classificeren op basis van de inhoud, gebruikt u een vooraf getraind ResNet-model. Met het vooraf getrainde model, dat afkomstig is van PyTorch, wordt een afbeelding in 1 van 1000 ImageNet-klassen geclassificeerd. U voegt vervolgens een helpercode en afhankelijkheden toe aan uw project.

  1. Voer in de map start de volgende opdracht uit om de voorspellingscode en labels te kopiëren naar de map classify.

    cp ../resources/predict.py classify
    cp ../resources/labels.txt classify
    
  2. Controleer of de map classify de bestanden bevat met de naam predict.py en labels.txt. Als dat niet het geval is, controleert u of u de opdracht hebt uitgevoerd in de map start.

  3. Open start/requirements.txt in een teksteditor en voeg de afhankelijkheden toe die vereist zijn voor de helpercode. Deze moet er als volgt uitzien:

    azure-functions
    requests
    -f https://download.pytorch.org/whl/torch_stable.html
    torch==1.13.0+cpu
    torchvision==0.14.0+cpu
    

    Tip

    De versies van torch en torchvision moeten overeenkomen met waarden die worden vermeld in de versietabel van de PyTorch Vision-opslagplaats.

  4. Sla requirements.txt op en voer vervolgens de volgende opdracht uit vanuit de map start om de afhankelijkheden te installeren.

    pip install --no-cache-dir -r requirements.txt
    

De installatie kan enkele minuten duren. Intussen u kunt doorgaan met het wijzigen van de functie in de volgende sectie.

Tip

In Windows kan de fout optreden 'Kan pakketten niet installeren vanwege een EnvironmentError: [Errno 2] Geen bestand of map met die naam:' gevolgd door een lange padnaam naar een bestand zoals sharded_mutable_dense_hashtable.cpython-37.pyc. Deze fout treedt meestal op omdat de diepte van het mappad te lang wordt. In dit geval moet u de registersleutel HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem@LongPathsEnabled instellen op 1 om lange paden in te schakelen. U kunt ook controleren waar uw Python-interpreter is geïnstalleerd. Als deze locatie een lang pad heeft, moet u proberen het opnieuw te installeren in een map met een korter pad.

De functie bijwerken voor het uitvoeren van voorspellingen

  1. Open classificeren/__init__.py in een teksteditor en voeg de volgende regels toe na de bestaande import instructies om de standaard JSON-bibliotheek en de voorspellingshelpers te importeren:

    import logging
    import azure.functions as func
    import json
    
    # Import helper script
    from .predict import predict_image_from_url
    
  2. Vervang de volledige inhoud van de functie main door de volgende code:

    def main(req: func.HttpRequest) -> func.HttpResponse:
        image_url = req.params.get('img')
        logging.info('Image URL received: ' + image_url)
    
        results = predict_image_from_url(image_url)
    
        headers = {
            "Content-type": "application/json",
            "Access-Control-Allow-Origin": "*"
        }
    
        return func.HttpResponse(json.dumps(results), headers = headers)
    

    Deze functie ontvangt een afbeeldings-URL in een queryreeks parameter met de naam img. Vervolgens wordt predict_image_from_url aangeroepen vanuit de helperbibliotheek om de afbeelding te downloaden en classificeren met behulp van het PyTorch-model. De functie retourneert vervolgens een HTTP-antwoord met de resultaten.

    Belangrijk

    Omdat dit HTTP-eindpunt wordt aangeroepen door een webpagina die wordt gehost op een ander domein, bevat het antwoord een Access-Control-Allow-Origin-header om te voldoen aan de vereisten voor CORS (Cross-Origin Resource Sharing) van de browser.

    Wijzig in een productietoepassing * naar de specifieke oorsprong van de webpagina voor extra beveiliging.

  3. Sla de wijzigingen op en start de lokale functiehost opnieuw met func start, ervan uitgaand dat de installatie van de afhankelijkheden is voltooid. Zorg ervoor dat u de host uitvoert in de map starten met de virtuele omgeving geactiveerd. Anders wordt de host gestart, maar u ziet fouten bij het aanroepen van de functie.

    func start
    
  4. Open in een browser de volgende URL om de functie aan te roepen met de URL van een afbeelding van een Berner sennenhond en te controleren of de geretourneerde JSON de afbeelding als een Berner sennenhond heeft geclassificeerd.

    http://localhost:7071/api/classify?img=https://raw.githubusercontent.com/Azure-Samples/functions-python-pytorch-tutorial/master/resources/assets/Bernese-Mountain-Dog-Temperament-long.jpg
    
  5. Zorg ervoor dat de host actief blijft omdat u deze in de volgende stap gebruikt.

Voer de frontend van de lokale web-app uit om de functie te testen

Als u het aanroepen van het functie-eindpunt vanuit een andere web-app wilt testen, is er een eenvoudige app in de map frontend van de opslagplaats.

  1. Open een nieuwe terminal of opdrachtprompt en activeer de virtuele omgeving (zoals eerder beschreven onder Een virtuele Python-omgeving maken en activeren).

  2. Ga naar de map frontend van de opslagplaats.

  3. Een HTTP-server starten met Python:

    python -m http.server
    
  4. Ga in een browser naar localhost:8000 en voer een van de volgende foto-URL's in het tekstvak in of gebruik de URL van een openbaar toegankelijke afbeelding.

    • https://raw.githubusercontent.com/Azure-Samples/functions-python-pytorch-tutorial/master/resources/assets/Bernese-Mountain-Dog-Temperament-long.jpg
    • https://github.com/Azure-Samples/functions-python-pytorch-tutorial/blob/master/resources/assets/bald-eagle.jpg?raw=true
    • https://raw.githubusercontent.com/Azure-Samples/functions-python-pytorch-tutorial/master/resources/assets/penguin.jpg
  5. Selecteer Verzenden om het functie-eindpunt aan te roepen voor het classificeren van de afbeelding.

    Schermopname van voltooid project

    Als de browser een fout meldt bij het verzenden van de afbeeldings-URL, controleert u de terminal waarin u de functie-app uitvoert. Als er een foutbericht wordt weergegeven als 'Geen module gevonden 'PIL'', hebt u de functie-app mogelijk gestart in de map start zonder eerst de virtuele omgeving te activeren die u eerder hebt gemaakt. Als u nog steeds fouten ziet, voert u pip install -r requirements.txt opnieuw uit met de virtuele omgeving geactiveerd en zoekt u naar fouten.

Resources opschonen

Omdat deze hele zelfstudie lokaal op uw computer wordt uitgevoerd, zijn er geen Azure-resources of -services om op te schonen.

Volgende stappen

In deze zelfstudie hebt u geleerd hoe u een HTTP API-eindpunt kunt bouwen en aanpassen met Azure Functions om afbeeldingen te classificeren met behulp van een PyTorch-model. U hebt ook geleerd hoe u de API aanroept vanuit een web-app. U kunt de technieken in deze zelfstudie gebruiken om meer en minder complexe API's te ontwikkelen, die alle worden uitgevoerd op het serverloze rekenmodel dat wordt geleverd door Azure Functions.

Zie ook: