Semarchy GenAI Gemini enricher
The Semarchy GenAI Gemini enricher generates a single text response based on a user prompt.
Description
The GenAI Gemini enricher is designed to enhance text data using Google Gemini language models. Users can leverage this enricher to improve the quality, relevance, and depth of their text data using advanced AI capabilities.
Prerequisites
To authenticate with the Vertex AI API, you need to have a Google Cloud service account and must configure xDM to integrate Gemini models.
- 
Create a Google Cloud service account. 
 For detailed information, see the official Vertex AI documentation.
- 
At the end of the account creation process, download the service account key file. 
- 
In xDM’s startup configuration, set the environment variable GOOGLE_APPLICATION_CREDENTIALSto the path of the service account key file that contains your credentials.
For additional information on how to get started with Vertex AI, see the LangChain4j documentation.
Plugin parameters
The following table lists the plugin parameters.
| Parameter name | Mandatory | Type | Description | ||
|---|---|---|---|---|---|
| Project | Yes | String | A globally unique, permanent identifier generated by the Google Cloud console. The project ID can be a combination of lowercase letters, numbers, and hyphens. 
 | ||
| Location | Yes | String | Geographical region where the Gemini model will be deployed and used. The following regions are supported: 
 | ||
| Model Name | Yes | String | Language model to be used. 
 | ||
| Temperature | No | Number | Value ranging from 0.0 to 1.0 for balancing between conservative and coherent outputs (0) and creative variations (1) during text generation. | ||
| Max Output Tokens | No | Integer | Maximum number of tokens allowed in the generated output during text generation. 
 | ||
| Top K | No | Number | Value ranging from 1 to 40 for limiting the model’s predictions to the most probable tokens at each step of generation. | ||
| Top P | No | Number | Value ranging from 0.0 to 1.0 for defining the cumulative probability threshold for nucleus sampling (i.e., token selection). 
 | ||
| Max Retries | No | Integer | Maximum number of attempts allowed for API requests before considering them unsuccessful. | 
Language models
Language models are AI systems trained on vast amounts of text data to understand and generate human-like language, enabling tasks like text completion, translation, summarization, and sentiment analysis.
The Vertex AI API offers a range of models with distinct capabilities. For more information on Gemini models and a list of stable model versions, see the official Vertex AI documentation.
Tokens
Tokens are units of text that language models use to process and generate language. They can range from individual characters to entire words, depending on the language and the specific model being used.
For more information about tokens, see the official Vertex AI documentation.
Plugin inputs
The following table lists the plugin inputs.
| Input name | Mandatory | Type | Description | 
|---|---|---|---|
| User Prompt | Yes | String | Input query specifying the user’s particular needs, intentions, or requests for the generated text. | 
Plugin outputs
The following table lists the plugin outputs.
| Output name | Type | Description | 
|---|---|---|
| Response | String | Generated response applied to a designated attribute. | 
Examples and use cases
Imagine a scenario where a user needs a condensed version of a detailed product description for social media, where character or space limits apply. In practice, during record creation or editing, the user wants a brief social media blurb to be generated based on the Description field’s content.
For instance, consider the Velocity Pro Carbon Bike product record with the following description:
"Introducing the Velocity Pro Carbon Bike from Italy, a high-performance masterpiece meticulously crafted for speed enthusiasts. This aerodynamic marvel boasts cutting-edge design and lightweight materials, providing an unparalleled riding experience. Elevate your cycling adventures with the pinnacle of Italian engineering. Price: 134."
Suppose the enricher is configured as follows:
- 
In the plugin input properties: - 
User Prompt: 'Summarize the following description in less than 150 characters: ' || Description
 
- 
- 
In the plugin output properties: - 
Attribute Name: SocialMediaBlurb 
 
- 
In this setup, the response provided by the enricher will populate the Social Media Blurb field of the Velocity Pro Carbon Bike record with the following:
"Introducing the Velocity Pro Carbon Bike from Italy: a high-performance marvel, aerodynamic design, lightweight materials, ultimate riding experience. Price: $134."
Below are just a few examples of the diverse range of use cases that the GenAI OpenAI enricher can support:
- 
Content generation: create detailed descriptions of products or customer personas; generate captions for social media posts, ads, or campaigns. 
- 
Content synthesis: capture the essence of a text to create titles or names for products, services, or features. 
- 
Content quality: enhance clarity, refine structure, and adjust tone to meet specific communication goals; correct spelling and grammar errors to adhere to standard language conventions. 
- 
Custom tone of voice: adapt the tone of the text to align with specific communication objectives, conveying neutrality, professionalism, empathy, education, or casualness. 
- 
Language translation: translate text into one or several other languages. 
- 
Price conversion: convert product prices from one currency to another.