Author: Google Cloud (https://cloud.google.com)
Description: Performs AI/ML tasks on text, customizable with prompt engineering, using PaLM API and Firestore.
Details: >
Please ensure that you have already signed up for the waitlist and have been approved before installing the extension.
This extension allows you to perform language tasks using the PaLM API, a custom prompt, and Firestore.
On installation, you will be asked to provide the following information:
- Prompt: This is the text that you want the PaLM API to generate a response for. It can be free-form text or it can use handlebars variables to substitute values from the Firestore document.
- Firestore collection path: This is the path to the Firestore collection that contains the documents that you want to perform the language task on.
- Response field: This is the name of the field in the Firestore document where you want the extension to store the response from the PaLM API.
This extension will listen to the specified collection for new documents. When such a document is added, the extension will:
- Substitute any variables from the document into the prompt.
- Query the PaLM API to generate a response based on the prompt.
- Write the response from the PaLM API back to the triggering document in the response field.
Each instance of the extension should be configured to perform one particular task. If you have multiple tasks, you can install multiple instances.
For example, you could use this extension to:
- Predict star ratings on a collection of product reviews.
- Classify customer feedback as positive, negative, or neutral.
- Summarize long articles.
- Extract named entities from text.
- Generate creative text, such as poems or code.
Here’s an example prompt used for predicting star ratings on a collection of product reviews:
Provide a star rating from 1-5 of the following review text: “This is a truly incredible water bottle, I keep it with me all the time when I’m traveling and it has never let me down.”
5
Provide a star rating from 1-5 of the following review text: “I really enjoyed the water bottle, I just wish they carried this in a larger size as I go for long hikes. But overall the aesthetic, manufacturing, and functional design are great for what I needed.”
4
Provide a star rating from 1-5 of the following review text: “The water bottle was fine, although the design was a bit lacking and could be improved.”
3
Provide a star rating from 1-5 of the following review text: “Please don’t get this water bottle, there are major design flaws, for example the cap doesn’t screw on fully so water leaks into my backpack all the time.”
1
Provide a star rating from 1-5 of the following review text: \“{{review_text}}\”
In this case, review_text is a field of the Firestore document and will be substituted into the prompt when querying PaLM.
Changing the state field of a completed document's status from COMPLETED
to anything else will retrigger the extension for that document.
If you have not already done so, you will first need to apply for access to the PaLM API via this waitlist.
Once you have access, please enable the Generative Language API in your Google Cloud Project before installing this extension.
Ensure you have a Cloud Firestore database set up in your Firebase project, and enabled the Generative Language API in your Google Cloud Project before installing this extension.
To install an extension, your project must be on the Blaze (pay as you go) plan. You will be charged a small amount (typically around $0.01/month) for the Firebase resources required by this extension (even if it is not used). This extension uses other Firebase and Google Cloud Platform services, which have associated charges if you exceed the service’s no-cost tier:
- Cloud Firestore
- Cloud Functions (See FAQs)
Learn more about Firebase billing.
Additionally, this extension uses the PaLM API, which is currently in public preview. During the preview period, developers can try the PaLM API at no cost. Pricing will be announced closer to general availability. For more information on the PaLM API public preview, see the PaLM API documentation.
Configuration Parameters:
-
Collection Path: Path to the Firestore collection where text will be generated.
-
Prompt: Prompt. Use {{ handlebars }} for variable substitution from the created or updated doc.
-
Variable fields: A comma separated list of fields to substitute as variables in the prompt.
-
Response Field: The field in the message document into which to put the response.
-
Cloud Functions location: Where do you want to deploy the functions created for this extension? For help selecting a location, refer to the location selection guide.
-
Language model: Which language model do you want to use?
-
Temperature: Controls the randomness of the output. Values can range over [0,1], inclusive. A value closer to 1 will produce responses that are more varied, while a value closer to 0 will typically result in less surprising responses from the model.
-
Nucleus sampling probability: If specified, nucleus sampling will be used as the decoding strategy. Nucleus sampling considers the smallest set of tokens whose probability sum is at least a fixed value. Enter a value between 0 and 1.
-
Sampling strategy parameter: If specified, top-k sampling will be used as the decoding strategy. Top-k sampling considers the set of topK most probable tokens.
-
Candidate count: The default value is one. When set to an integer higher than one, additional candidate responses, up to the specified number, will be stored in Firestore under the 'candidates' field.
-
Candidates field: The field in the message document into which to put the other candidate responses if the candidate count parameter is greater than one.
Cloud Functions:
- generateText: Listens to Firestore data writes to generate conversations.
Access Required:
This extension will operate with the following project IAM roles:
- datastore.user (Reason: Allows this extension to access Cloud Firestore to read and process added messages.)