Generieren Sie intelligente Antworten mit ML Kit auf Android

Sie können ML Kit verwenden, um Nachrichtenantworten mithilfe eines Modells auf dem Gerät zu generieren.

Um intelligente Antworten zu generieren, übergeben Sie ML Kit ein Protokoll der letzten Nachrichten in einer Konversation. Wenn ML Kit feststellt, dass die Konversation auf Englisch stattfindet und dass die Konversation keinen potenziell sensiblen Inhalt hat, generiert ML Kit bis zu drei Antworten, die Sie Ihrem Benutzer vorschlagen können.

Bevor Sie beginnen

  1. Fügen Sie Ihrem Android-Projekt Firebase hinzu, falls Sie dies noch nicht getan haben .
  2. Fügen Sie die Abhängigkeiten für die ML Kit-Android-Bibliotheken zu Ihrer Modul-Gradle-Datei (auf App-Ebene) hinzu (normalerweise app/build.gradle ):
    apply plugin: 'com.android.application'
    apply plugin: 'com.google.gms.google-services'
    
    dependencies {
      // ...
      implementation 'com.google.firebase:firebase-ml-natural-language:22.0.0'
      implementation 'com.google.firebase:firebase-ml-natural-language-smart-reply-model:20.0.7'
    }
    
  3. Deaktivieren Sie auch in Ihrer build.gradle -Datei auf App-Ebene die Komprimierung von tflite -Dateien:
    android {
        // ...
        aaptOptions {
            noCompress "tflite"
        }
    }
    

1. Erstellen Sie ein Konversationsverlaufsobjekt

Um intelligente Antworten zu generieren, übergeben Sie ML Kit eine chronologisch geordnete List von FirebaseTextMessage -Objekten mit dem frühesten Zeitstempel zuerst.

Immer wenn der Benutzer eine Nachricht sendet, fügen Sie die Nachricht und ihren Zeitstempel zum Konversationsverlauf hinzu:

Java

conversation.add(FirebaseTextMessage.createForLocalUser(
        "heading out now", System.currentTimeMillis()));

Kotlin

conversation.add(FirebaseTextMessage.createForLocalUser(
        "heading out now", System.currentTimeMillis()))

Immer wenn der Benutzer eine Nachricht erhält, fügen Sie die Nachricht, ihren Zeitstempel und die Benutzer-ID des Absenders zum Konversationsverlauf hinzu. Die Benutzer-ID kann eine beliebige Zeichenfolge sein, die den Absender innerhalb der Konversation eindeutig identifiziert. Die Benutzer-ID muss keinen Benutzerdaten entsprechen, und die Benutzer-ID muss zwischen Gesprächen oder Aufrufen des Smart-Reply-Generators nicht konsistent sein.

Java

conversation.add(FirebaseTextMessage.createForRemoteUser(
        "Are you coming back soon?", System.currentTimeMillis(), userId));

Kotlin

conversation.add(FirebaseTextMessage.createForRemoteUser(
        "Are you coming back soon?", System.currentTimeMillis(), userId))

Ein Konversationsverlaufsobjekt sieht wie im folgenden Beispiel aus:

Zeitstempel Benutzeridentifikation Lokaler Benutzer? Nachricht
Donnerstag, 21. Februar, 13:13:39 PST 2019 Stimmt bist du auf dem Weg?
Donnerstag, 21. Februar, 13:15:03 PST 2019 FREUND0 FALSCH Verspätung, tut mir leid!

Beachten Sie, dass die neueste Nachricht im obigen Beispiel von einem nicht lokalen Benutzer stammt. Dies ist wichtig, da ML Kit Antworten vorschlägt, die vom Benutzer Ihrer App gesendet werden sollen: dem lokalen Benutzer. Sie sollten sicherstellen, dass Sie ML Kit ein Konversationsprotokoll übergeben, das mit einer Nachricht endet, auf die Ihr Benutzer möglicherweise antworten möchte.

2. Nachrichtenantworten erhalten

Um intelligente Antworten auf eine Nachricht zu generieren, rufen Sie eine Instanz von FirebaseSmartReply ab und übergeben Sie den Konversationsverlauf an die Methode suggestReplies() :

Java

FirebaseSmartReply smartReply = FirebaseNaturalLanguage.getInstance().getSmartReply();
smartReply.suggestReplies(conversation)
        .addOnSuccessListener(new OnSuccessListener<SmartReplySuggestionResult>() {
            @Override
            public void onSuccess(SmartReplySuggestionResult result) {
                if (result.getStatus() == SmartReplySuggestionResult.STATUS_NOT_SUPPORTED_LANGUAGE) {
                    // The conversation's language isn't supported, so the
                    // the result doesn't contain any suggestions.
                } else if (result.getStatus() == SmartReplySuggestionResult.STATUS_SUCCESS) {
                    // Task completed successfully
                    // ...
                }
            }
        })
        .addOnFailureListener(new OnFailureListener() {
            @Override
            public void onFailure(@NonNull Exception e) {
                // Task failed with an exception
                // ...
            }
        });

Kotlin

val smartReply = FirebaseNaturalLanguage.getInstance().smartReply
smartReply.suggestReplies(conversation)
        .addOnSuccessListener { result ->
            if (result.getStatus() == SmartReplySuggestionResult.STATUS_NOT_SUPPORTED_LANGUAGE) {
                // The conversation's language isn't supported, so the
                // the result doesn't contain any suggestions.
            } else if (result.getStatus() == SmartReplySuggestionResult.STATUS_SUCCESS) {
                // Task completed successfully
                // ...
            }
        }
        .addOnFailureListener {
            // Task failed with an exception
            // ...
        }

Wenn der Vorgang erfolgreich ist, wird ein SmartReplySuggestionResult Objekt an den Erfolgshandler übergeben. Dieses Objekt enthält eine Liste mit bis zu 3 Antwortvorschlägen, die Sie Ihrem Benutzer präsentieren können:

Java

for (SmartReplySuggestion suggestion : result.getSuggestions()) {
    String replyText = suggestion.getText();
}

Kotlin

for (suggestion in result.suggestions) {
    val replyText = suggestion.text
}

Beachten Sie, dass ML Kit möglicherweise keine Ergebnisse zurückgibt, wenn das Modell nicht von der Relevanz der vorgeschlagenen Antworten überzeugt ist, die Eingabekonversation nicht auf Englisch ist oder wenn das Modell sensible Themen erkennt.