Template:AI

From SmartWiki
Revision as of 12:01, 16 November 2023 by Ann Vincent (talk | contribs) (Automation Mode)

Jump to: navigation, search

The SmartSimple Cloud +AI integration gives you the ability to utilize large language models (LLM) from within our business process automation platform. LLMs may be utilized to improve productivity, processes, and outcomes. This article will walk-through how-to setup the integration, outline the two modes (automation and interactive), and delineate some sample scenarios.


Overview

There are two modes of operation when using SmartSimple Cloud +AI:

  • Interactive Mode: This mode of operation occurs on a single object such as a grant application or review. In this scenario, the user can interact with the AI using a call-and-response model. The user might ask the AI to help them rewrite content, translate content into another language, or make content more concise. The user can ask questions (prompts) and follow up with more related questions. The user can also be presented with optional predefined templates to streamline common tasks.
  • Automation Mode: This mode of operation can occur in various areas of the platform. In this scenario, the system is configured to automatically interact with your chosen 3rd party LLM vendor to do something with or without manual intervention. For example, the system can be configured to automatically generate an executive summary of an application or a summary of the reviewers’ comments. Applications could be prescreened and recommended or the AI could suggest reviewers with subject matter expertise related to the application.

Configuration - Essentials

Setting up +AI Integration

Before you can start using +AI functionality within your SmartSimple Cloud environment, you must reach out to your account manager as there may be an additional fee. To set up the +AI integration, follow these steps:

  1. SmartSimple will enable the +AI feature within your environment by going to Menu Icon > Global Settings > Integrations tab > Toggle on Enable AI.
    A SmartSimple representative will enable the +AI feature using the above toggle.
  2. Next, you will need to purchase your own license from your desired third-party LLM vendor. For example, if you wanted to use OpenAI for the currently supported chat feature, you can go to openai.com to see the available pricing options.
  3. Add your license to an integration key by going to Menu Icon > Global Settings > Integrations tab > Integration Key Management > Add an integration key with the Type set to "OpenAI".
  4. Enter the API key provided by OpenAI and click Save.
    As part of the Integration Key configuration, you will be required to get an API key from OpenAI.


Interactive Mode

The AI interactive mode can be enabled on organization profiles, user profiles, and UTA records. In this example, we can configure interactive mode on a UTA to streamline the application process. 

Configuring Interactive Mode

As an example, we will configure the AI on a particular UTA by the following steps:

  1. Go to UTA > Configuration Settings > Level 1/2/3 tab > AI. On this page, custom instructions and templates can be set up.
    The instruction text will be displayed to users who use the Work with +AI feature on a particular record. Clicking the Sample Instructions link will auto-populate the field with default instructions.
  2. On the Permissions & Availability tab, set access to the feature by role, record type, or record status.
  3. Click Save.

Using Interactive Mode

  1. Navigate to the desired UTA record and select Tools > Work with +AI in the top action bar.
    Users with permission may access the interactive AI mode from record pages via the Tools menu.
  2. This will open a modal window into which you can enter your prompts and adjust the Temperature setting.
    In the interactive mode users can enter prompts using natural language, refine the responses by asking follow-up related questions in a conversational format. Users may also select from predefined prompts.

Setting up Templates

Templates can be created to streamline common processes. As an example, let's set up a template that will automatically translate the objectives of a record into another language. We will use a variable to achieve this goal.

Creating a Template

  1. Go to UTA > Configuration Settings > Level 1/2/3 tab > AI > Click the New Template button.
  2. Under the General tab, give the template a Name and a Caption. The Caption is what will be surfaced to users during template selection.
  3. Enter the template contents in the Template field. When referencing specific record fields, be sure to use the Field Name rather than the Caption. In our example, we can ask the AI to translate the content of a specific field into French by referencing the field name in quotations.
    Templates allow you to reference field names.
  4. Set who has access to use this template under the Permissions & Availability tab.
  5. Click Save.


Selecting a Template

  1. Go to the desired UTA record > Tools > Work with +AI.
  2. Select the preferred template from the dropdown.
    When selecting a template, any variables used will automatically resolve in the prompt window.
  3. Set the desired Temperature. This setting controls the level of randomness desired from the AI's response. A lower number correlates to a more consistent and repeatable response.
  4. Click the Send button. After a moment, the AI will respond to the request.
    Once the AI returns with a response, you can give it further prompts or select another template.

Best Practices for Template Prompts

When deciding which prompts to use in a template, it can be helpful to test the variables by going to any UTA record and clicking Tools > Configuration Mode > Variable Syntax Helper. Here, you can test your expressions and see if your variables resolve correctly.

Some best practices for prompt engineering according to OpenAI are:

  • Put the instructions at the start of the prompt and use double quotation marks ( " " ) to separate the instructions from the context
  • Be specific and descriptive about the desired outcome, including details about context, length, format, style, etc
  • Provide an example or desired format in the prompt if necessary

Automation Mode

Configuring Automation Mode

Once +AI integration has been set up, the automation mode can be used in various areas of the system. The existing SmartSimple variable processor has been modified in order to allow you to interface with the third-party AI vendor. To familiarize yourself with the syntax and possible statements, you can test the syntax using the Variable Syntax Helper by opening a object record and going to Tools > Configuration Mode > Variable Syntax Helper.

Syntax

The syntax used for prompts in web page views and workflows is:

AI Syntax Format.png

These parameters are explained as follows:

  • AI model: (Optional) The name of the AI model being used by the service. If the service is OpenAI and the model is left unspecified, ChatGPT-3.5 will be used by default.
  • text/edit: Use the "text" function to generate new text based on a given prompt. Use the "edit" function to request improvements to existing text.
    Note: The "edit" function is only available for OpenAI model ChatGPT-3.5.
  • temperature: Sets the desired level of randomness of the generated text, where a value of "0" is the most conservative while a value of "9" is the most random.
  • instruction: The natural language prompt for the AI. For example, "fix the grammar", "make this in the style of a poem", or "translate this into Japanese".
  • edit content: The input text sent to the AI for editing.
Example Scenario Syntax
Ask AI to write an email for a specific user
AI-Syntax-Prompt-Example-1.png
Ask AI to write an email for a specific user using model gpt-3.5-turbo-instruct
Ask AI to fix the spelling of a message
AI-Syntax-Prompt-Example-2.png
Ask the AI to write a grant application summary
AI-Syntax-Prompt-Example-3.png

Frequently Asked Questions

Which AI vendor does SmartSimple use?

SmartSimple is flexible enough to integrate with different third-party AI vendors. Currently, our integration supports OpenAI's text-davinci-003 model by default.

Can we use a different vendor other than OpenAI?

If you would like to integrate with a different vendor, reach out to our Platform Solutions team or your account manager for more details.

Can we use our own finetuned model or a different model with OpenAI?

Yes. You can use your preferred custom model within the AI's automation mode by modifying the opening syntax. For example, if you wanted to use ChatGPT, you could specify it in the syntax like so:

AI-Syntax-Prompt-Example-4.png

If you wanted to use your own custom model, you can specify the name with the following syntax:

AI-Syntax-Prompt-Example-5.png
Who is responsible for the data that is used with the AI feature?

As with any third-party service accessible through SmartSimple, it is up the the data controller (client) to understand the implications of using any data processor.

Settings Explained

These settings are found within the interactive mode of +AI.

General Tab

The following settings are available on the General tab:

Setting Description
Instruction Caption The title given to the instruction box that appears above the AI chat window.
Instruction Content Any instructions to be displayed. Clicking the "Sample Instructions" link will populate this field with default instruction text.

Template Settings

This following settings are available when creating a template:

Setting Description
Display Order The order in which the template appears in the Template dropdown with smaller numbers corresponding to being listed closer to the top.
Name The name of the template. It is not displayed to the end user.
Caption The name of the template as it appears in the Template dropdown.
Template The content of the template or what you want to ask the AI to do. For example, "Summarize the project goals in 50 words or less".