Heim > Backend-Entwicklung > Python-Tutorial > Verwendung der Web-API für FLUX [pro]: Das neueste KI-Modell zur Bilderzeugung vom Originalteam von Stable Diffusion

Verwendung der Web-API für FLUX [pro]: Das neueste KI-Modell zur Bilderzeugung vom Originalteam von Stable Diffusion

Mary-Kate Olsen
Freigeben: 2024-10-20 12:38:02
Original
591 Leute haben es durchsucht

Einführung

Zuvor habe ich einen Artikel mit dem Titel „Ausführen des KI-Modells der Generation FLUX.1 Image ([dev]/[schnell]) von den Originalentwicklern von Stable Diffusion auf einem MacBook (M2)“ geschrieben. Es demonstrierte das Bilderzeugungsmodell FLUX.1 von Black Forest Labs, gegründet von den Machern von Stable Diffusion.

Jetzt, zwei Monate später, wurde FLUX 1.1 [pro] (Codename Blueberry) veröffentlicht, zusammen mit öffentlichem Zugriff auf seine Web-API, obwohl es sich noch in der Betaphase befindet.

Heute veröffentlichen wir FLUX1.1 [pro], unser bisher fortschrittlichstes und effizientestes Modell, zusammen mit der allgemeinen Verfügbarkeit der Beta-BFL-API. Diese Veröffentlichung stellt einen bedeutenden Schritt vorwärts in unserer Mission dar, Schöpfer, Entwickler und Unternehmen mit skalierbarer, hochmoderner generativer Technologie auszustatten.

Referenz: Ankündigung von FLUX1.1 [pro] und der BFL API – Black Forest Labs

In diesem Beitrag werde ich zeigen, wie man die FLUX 1.1 [pro] Web-API verwendet.

Alle Codebeispiele sind in Python geschrieben.

Erstellen eines Kontos und eines API-Schlüssels

Registrieren Sie zunächst ein Konto und melden Sie sich auf der API-Seite unter der Option Registrieren an.

Credits kosten jeweils 0,01 $ und ich habe bei der Registrierung 50 Credits erhalten (dies kann variieren).

Basierend auf der Preisseite sind die Modellkosten wie folgt:

  • FLUX 1.1 [pro]: 0,04 $ pro Bild
  • FLUX.1 [pro]: 0,05 $ pro Bild
  • FLUX.1 [dev]: 0,025 $ pro Bild

Sobald Sie angemeldet sind, generieren Sie einen API-Schlüssel, indem Sie Schlüssel hinzufügen auswählen und einen Namen Ihrer Wahl eingeben.

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Ihr Schlüssel wird wie unten dargestellt angezeigt.

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Umgebungseinrichtung

Ich verwende macOS 14 Sonoma als mein Betriebssystem.

Die Python-Version ist:

$ python --version
Python 3.12.2
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Um den Beispielcode auszuführen, habe ich Requests installiert:

$ pip install requests
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Ich habe die installierte Version bestätigt:

$ pip list | grep -e requests 
requests           2.31.0
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Um Hardcodierung zu vermeiden, habe ich den API-Schlüssel als Umgebungsvariable gespeichert, indem ich die zshrc-Datei bearbeitet habe.

$ open ~/.zshrc
Nach dem Login kopieren
Nach dem Login kopieren

Ich habe die Umgebungsvariable BFL_API_KEY:
benannt

export BFL_API_KEY=<Your API Key Here>
Nach dem Login kopieren
Nach dem Login kopieren

Beispielcode

Unten finden Sie den Beispielcode aus „Erste Schritte“ mit einigen zusätzlichen Kommentaren. Im Idealfall sollte es Fehler mithilfe des Status behandeln, aber ich habe es der Einfachheit halber unverändert gelassen.

import os
import requests
import time

# Request
request = requests.post(
    'https://api.bfl.ml/v1/flux-pro-1.1',
    headers={
        'accept': 'application/json',
        'x-key': os.environ.get("BFL_API_KEY"),
        'Content-Type': 'application/json',
    },
    json={
        'prompt': 'A cat on its back legs running like a human is holding a big silver fish with its arms. The cat is running away from the shop owner and has a panicked look on his face. The scene is situated in a crowded market.',
        'width': 1024,
        'height': 768,
    },
).json()
print(request)
request_id = request["id"]

# Wait for completion
while True:
    time.sleep(0.5)
    result = requests.get(
        'https://api.bfl.ml/v1/get_result',
        headers={
            'accept': 'application/json',
            'x-key': os.environ.get("BFL_API_KEY"),
        },
        params={
            'id': request_id,
        },
    ).json()
    if result["status"] == "Ready":
        print(f"Result: {result['result']['sample']}")
        break
    else:
        print(f"Status: {result['status']}")
Nach dem Login kopieren
Nach dem Login kopieren

In diesem Beispiel lautet die Eingabeaufforderung:

Eine Katze, die wie ein Mensch auf den Hinterbeinen rennt, hält mit ihren Armen einen großen silbernen Fisch. Die Katze rennt vor dem Ladenbesitzer davon und macht einen panischen Gesichtsausdruck. Die Szene befindet sich auf einem überfüllten Markt.

Das Format des endgültigen Ergebnisses sieht folgendermaßen aus. Die Reaktionszeit war schneller im Vergleich zu anderen APIs, die ich getestet habe.

$ python --version
Python 3.12.2
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Das Beispiel enthält die URL des generierten Bildes, das auf bflapistorage.blob.core.windows.net gehostet wurde, als ich es getestet habe.

Hier ist das generierte Bild:

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Das Ergebnis entspricht genau der Aufforderung und spiegelt das Gefühl der Dringlichkeit wider.

Experimentieren mit alternativen Eingabeaufforderungen

Ich habe verschiedene Eingabeaufforderungen ausprobiert, um abwechslungsreiche Bilder zu erstellen.

Japanische Moe-Heldin

Eingabeaufforderung: „Japanische Moe-Heldin“, im Anime-Stil.

$ pip install requests
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Süßigkeiten aus dem beliebten japanischen Anime

Eingabeaufforderung: „Süßigkeiten, die in beliebten japanischen Animes vorkommen“, im Anime-Stil.

$ pip list | grep -e requests 
requests           2.31.0
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Männlicher Gymnasiast auf Klassenfahrt

Eingabeaufforderung: „Männlicher Gymnasiast auf Klassenfahrt“, im Anime-Stil.

$ open ~/.zshrc
Nach dem Login kopieren
Nach dem Login kopieren

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Eine Prinzessin, die Gitarre spielt

Eingabeaufforderung: „Eine Prinzessin spielt Gitarre“, im Fantasy-Art-Stil.

export BFL_API_KEY=<Your API Key Here>
Nach dem Login kopieren
Nach dem Login kopieren

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Eine süße Fee auf einem weißen Laptop

Eingabeaufforderung: „Eine süße Fee auf einem weißen Laptop“, im fotografischen Stil.

import os
import requests
import time

# Request
request = requests.post(
    'https://api.bfl.ml/v1/flux-pro-1.1',
    headers={
        'accept': 'application/json',
        'x-key': os.environ.get("BFL_API_KEY"),
        'Content-Type': 'application/json',
    },
    json={
        'prompt': 'A cat on its back legs running like a human is holding a big silver fish with its arms. The cat is running away from the shop owner and has a panicked look on his face. The scene is situated in a crowded market.',
        'width': 1024,
        'height': 768,
    },
).json()
print(request)
request_id = request["id"]

# Wait for completion
while True:
    time.sleep(0.5)
    result = requests.get(
        'https://api.bfl.ml/v1/get_result',
        headers={
            'accept': 'application/json',
            'x-key': os.environ.get("BFL_API_KEY"),
        },
        params={
            'id': request_id,
        },
    ).json()
    if result["status"] == "Ready":
        print(f"Result: {result['result']['sample']}")
        break
    else:
        print(f"Status: {result['status']}")
Nach dem Login kopieren
Nach dem Login kopieren

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

28-jährige Japanerin mit schwarzem Bob-Haar

Eingabeaufforderung: „28-jährige hübsche Japanerin mit schwarzem Bob-Haar“, im fotografischen Stil.

$ python --version
Python 3.12.2
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Hongkong Downtown in den 1980er Jahren

Eingabeaufforderung: „Hong Kong Downtown in den 1980er Jahren“, im fotografischen Stil.

$ pip install requests
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Shinjuku Kabukicho im Jahr 2020

Eingabeaufforderung: „Shinjuku Kabukicho im Jahr 2020“, unter Verwendung von fotografischem Stil.

$ pip list | grep -e requests 
requests           2.31.0
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Using the Web API for FLUX  [pro]: The Latest Image Generation AI Model by the Original Team of Stable Diffusion

Alle generierten Bilder waren von außergewöhnlicher Qualität.

Nachdem so viele hochwertige KI-Bilder erstellt wurden, fühlt sich die Realität fast surreal an.

Abschluss

Black Forest Labs entwickelt und verbessert weiterhin seine KI-Modelle.

Ich freue mich auf die zukünftige Veröffentlichung der Videogenerierungsfunktionen.

Originaler japanischer Artikel

Stabile Diffusion, AI, FLUX 1.1 [pro] und Web像を生成してみた

Das obige ist der detaillierte Inhalt vonVerwendung der Web-API für FLUX [pro]: Das neueste KI-Modell zur Bilderzeugung vom Originalteam von Stable Diffusion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage