From 0f604247dabf36ca97b958541308b1c33309c603 Mon Sep 17 00:00:00 2001 From: Tom Bocklisch Date: Mon, 18 Sep 2023 09:06:28 +0200 Subject: [PATCH] removed feature flag from rephraser intentless --- docs/docs/concepts/flows.mdx | 4 +- docs/docs/concepts/llm-command-generator.mdx | 10 +- .../llms/contextual-response-rephraser.mdx | 15 +- docs/docs/llms/flow-policy.mdx | 12 +- docs/docs/llms/llm-command-generator.mdx | 208 ------------------ docs/docs/llms/llm-configuration.mdx | 2 +- docs/docs/llms/llm-intentless.mdx | 14 +- docs/sidebars.js | 2 +- 8 files changed, 38 insertions(+), 229 deletions(-) delete mode 100644 docs/docs/llms/llm-command-generator.mdx diff --git a/docs/docs/concepts/flows.mdx b/docs/docs/concepts/flows.mdx index b0254aa99cb4..7c86beb9de2c 100644 --- a/docs/docs/concepts/flows.mdx +++ b/docs/docs/concepts/flows.mdx @@ -62,7 +62,7 @@ The `name` field is a required human readable name for the flow. The `description` field is a summary of the flow. It is required, and should describe the purpose of the flow. Other components, such as the -[LLMCommandGenerator](../llms/llm-command-generator.mdx), use the description to +[LLMCommandGenerator](../concepts/llm-command-generator.mdx), use the description to decide when to start the flow. ### Steps @@ -229,7 +229,7 @@ description matches '/error \d{3}/i' and (severity = 'high' or source contains ' ### Starting a Flow Flows can be triggered by other Rasa components, e.g. the -[LLM Command Generator](../llms/llm-command-generator.mdx). The description of +[LLM Command Generator](../concepts/llm-command-generator.mdx). The description of each flow is very important for the LLM Command Generator, as it uses the description to determine which flow to trigger. diff --git a/docs/docs/concepts/llm-command-generator.mdx b/docs/docs/concepts/llm-command-generator.mdx index 4dc0ef50331f..e74c1a05dada 100644 --- a/docs/docs/concepts/llm-command-generator.mdx +++ b/docs/docs/concepts/llm-command-generator.mdx @@ -7,12 +7,12 @@ abstract: | control. --- -import RasaLabsLabel from "@theme/RasaLabsLabel"; -import RasaLabsBanner from "@theme/RasaLabsBanner"; +:::info New in 3.7 - - - +The *LLM Command Generator* is part of Rasa's new +Conversational AI with Language Models (CALM) approach and available starting +with version `3.7.0`. +::: ## LLMCommandGenerator diff --git a/docs/docs/llms/contextual-response-rephraser.mdx b/docs/docs/llms/contextual-response-rephraser.mdx index 9ca105ddab10..6633d4ad08ae 100644 --- a/docs/docs/llms/contextual-response-rephraser.mdx +++ b/docs/docs/llms/contextual-response-rephraser.mdx @@ -8,12 +8,19 @@ abstract: | of the conversation into account. --- -import RasaLabsLabel from "@theme/RasaLabsLabel"; -import RasaLabsBanner from "@theme/RasaLabsBanner"; +import RasaProLabel from "@theme/RasaProLabel"; +import RasaProBanner from "@theme/RasaProBanner"; - + - + + +:::info New in 3.7 + +The *Contextual Respones Rephrasing* is part of Rasa's new +Conversational AI with Language Models (CALM) approach and available starting +with version `3.7.0`. +::: ## Key Features diff --git a/docs/docs/llms/flow-policy.mdx b/docs/docs/llms/flow-policy.mdx index 2f7fc45886d2..eae24ec6f57f 100644 --- a/docs/docs/llms/flow-policy.mdx +++ b/docs/docs/llms/flow-policy.mdx @@ -6,11 +6,15 @@ abstract: | This is a guide to implementing and managing conversational flows using the FlowPolicy. --- -import RasaDiscoveryBanner from "@theme/RasaDiscoveryBanner"; import dialogueStackEvolution from "./dialogue_stack_evolution.png"; import dialogueStackOverview from "./dialogue_stack.png"; - +:::info New in 3.7 + +The *Flow Policy* is part of Rasa's new +Conversational AI with Language Models (CALM) approach and available starting +with version `3.7.0`. +::: Rasa's Flow Policy is a state machine that allows you to manage and control your chatbot's conversational flows. It facilitates the integration of your business @@ -125,7 +129,7 @@ completing the action and incorporating its result, it moves to the next state. A flow can be started in several ways: - A flow is started when a Rasa component puts the flow on the stack. For - example, the [LLM Command Generator](./llm-command-generator.mdx) puts a flow + example, the [LLM Command Generator](../concepts/llm-command-generator.mdx) puts a flow on the stack when it determines that a flow would be a good fit for the current conversation. - One flow can ["link" to another flow](../concepts/flows.mdx#link), which will initiate @@ -144,7 +148,7 @@ which digressions and interruptions the flow policy can handle, refer to For example, the user message _"oh sorry I meant John"_ is a correction to a prior input. The `FlowPolicy` depends on another component, like the -[LLM Command Generator](./llm-command-generator.mdx), to identify it as a +[LLM Command Generator](../concepts/llm-command-generator.mdx), to identify it as a correction and set the corresponding slots. Based on this, the `FlowPolicy` initiates the correction flow. diff --git a/docs/docs/llms/llm-command-generator.mdx b/docs/docs/llms/llm-command-generator.mdx deleted file mode 100644 index 4dc0ef50331f..000000000000 --- a/docs/docs/llms/llm-command-generator.mdx +++ /dev/null @@ -1,208 +0,0 @@ ---- -id: llm-command-generator -sidebar_label: Command Generation with LLMs -title: Command Generation with LLMs -abstract: | - LLM command generation component for believe state updates and flow - control. ---- - -import RasaLabsLabel from "@theme/RasaLabsLabel"; -import RasaLabsBanner from "@theme/RasaLabsBanner"; - - - - - -## LLMCommandGenerator - -The `LLMCommandGenerator` is a standalone NLU component that handles all the -interactions that users might have with flows. For that purpose, it recognizes -both intents and entities to start and advance flows. It does so without needing -any NLU training data. Instead, it leverages a zero-shot prompt in the background, which -contains the relevant flows, their slots and a number of data points on the current -conversation context. - -## Key Features -1. **Zero shot learning**: This classifier can be trained without any NLU examples for - intents or entities. Instead, it uses the description of flows. -2. **Flexible slot mapping**: The classifier can oftentimes determine which slot - should be filled from the given context, as opposed to only extracting a generic - entity. -3. **Linguistic Ability**: The classifier can handle more complex linguistic scenarios - such as negations or pronoun references, and it does not need all entities to be - explicitly spelled out in a user message. -4. **No Training**: The classifier does not involve any up-front training. -5. **Multilingual**: The classifier works with different languages, depending on the - underlying LLM. - -## Demo - -TODO - -## Using the LLMCommandGenerator in Your Bot - -To use this LLM-based classifier in your bot, you need to add the -`LLMCommandGenerator` to your NLU pipeline in the `config.yml` file. - -```yaml-rasa title="config.yml" -pipeline: -# - ... - - name: LLMCommandGenerator -# - ... -``` - -The `LLMCommandGenerator` requires access to an LLM API. You can use any -OpenAI model that supports the `/chat` endpoint such as "gpt-3.5-turbo" or "gpt-4". -We are working on expanding the list of supported models and model providers. - -## How does the classification work - -The zero-shot prompt is assembled from the definitions of all available flows, the -conversation context and current slots, as well as a number of rules for the LLM. Based -on this prompt, the LLM produces a list of actions in a domain specific language, -such as `StartFlow(transfer_money)` or `SetSlot(recipient, John)`. -We then parse and validate this list and turn it into a classification of intents -and extracted entities. - -Here is a prompt filled with current conversation context: -``` -Your task is to analyze the current conversation context and start new business processes that we call flows and to extract slots to advance active flows. - -These are the flows that can be started, with their description and slots: - -- transfer_money: This flow let's users send money to friends and family. (slots: ['transfer_money_recipient', 'transfer_money_amount_of_money', 'transfer_money_final_confirmation']) -- transaction_search: lists the last transactions of the user account (slots: []) -- check_balance: This flow lets users check their account balance. (slots: []) -- add_contact: add a contact to your contact list (slots: ['add_contact_handle', 'add_contact_name']) -- remove_contact: remove a contact from your contact list (slots: ['remove_contact_handle', 'remove_contact_name']) -- list_contacts: show your contact list (slots: []) -- restaurant_book: This flow books a restaurant (slots: ['restaurant_name', 'restaurant_book_time', 'restaurant_book_size', 'restaurant_confirm_booking']) -- hotel_search: search for hotels (slots: []) - -Here is what happened previously in the conversation: -USER: I want to send some money to Joe -AI: How much money do you want to transfer? -USER: 40$ - - -You are currently in the flow "transfer_money". -You have just asked the user for the slot "transfer_money_amount_of_money". - - -Here are the slots of the currently active flow with their names and values: - -- transfer_money_recipient: Joe - -- transfer_money_amount_of_money: undefined - -- transfer_money_final_confirmation: undefined - - - -If you start a flow, you can already fill that flow's slots with information the user provided for starting the flow. - -The user just said """40$""". - -Based on this information generate a list of actions you want to take. Your job is to start flows and to fill slots where appropriate. Any logic of what happens afterwards is handled by the flow engine. These are your available actions: -* Slot setting, described by "SetSlot(slot_name, slot_value)". An example would be "SetSlot(recipient, Freddy)" -* Starting another flow, described by "StartFlow(flow_name)". An example would be "StartFlow(transfer_money)" -* Cancelling the current flow, describe by "CancelFlow()" - -Write out the actions you want to take for the last user message, one per line. -Do not prematurely fill slots with abstract values. -Only use information provided by the user. -Strictly adhere to the provided action types above for starting flows and setting slots. -Focus on the last message and take it one step at a time. -Use the previous conversation steps only to aid understanding. -The action list: -``` - -The LLM might reply to this prompt with: -``` -SetSlot(transfer_money_amount_of_money, 40$) -``` -Which we would then turn into an `inform` intent, since no other flow needs to be -started and the information belongs to the question that was just asked. The -`transfer_money_amount_of_money` entity would also be detected. - -If the user had said "Sorry, I meant to John" instead, the LLM might have replied with -``` -SetSlot(transfer_money_recipient, John) -``` -Which would then be turned into a `correction` intent, since it tries to set a slot that -was asked earlier in the flow. The `transfer_money_recipient` entity would also be -detected. - -If the user had said "How much do I still have in my account" instead, the LLM might -have replied with -``` -StartFlow(check_balance) -``` -Which we then would turn into a `check_balance` intent. - -It is also possible to return multiple actions at the same time for the LLM, if the -user for example says "I want to send 40$ to John", the LLM should reply: -``` -StartFlow(transfer_money) -SetSlot(transfer_money_recipient, John) -SetSlot(transfer_money_amount_of_money, 40$) -``` - -which would then be turned into the `transfer_money` intent as well as two entities. - -### Too complex requests - -Some requests from the user and responses by the LLM are currently deemed as too complex -and classified as such based on the composition of the action list. - -## Customization - -### LLM configuration - -You can specify the openai model to used for the `LLMCommandGenerator` by setting the -`llm.model_name` property in the `config.yml` file: - -```yaml-rasa title="config.yml" -pipeline: -# - ... - - name: LLMCommandGenerator - llm: - model_name: "gpt-4" - request_timeout: 7 - temperature: 0.0 -# - ... -``` - -The `model_name` defaults to `gpt-4`. The model name should be set -to a chat model of [OpenAI](https://platform.openai.com/docs/guides/gpt/chat-completions-api). - -Similarly, you can specify the `request_timeout` and -`temperature` parameters for the LLM. The `request_timeout` -defaults to `7` seconds and the `temperature` defaults to `0.0`. - -If you want to use Azure OpenAI Service, you can configure the necessary -parameters as described in the -[Azure OpenAI Service](./llm-configuration.mdx#additional-configuration-for-azure-openai-service) -section. - -:::info Using Other LLMs - -By default, OpenAI is used as the underlying LLM provider. - -The used LLM provider provider can be configured in the -`config.yml` file to use another provider, e.g. `cohere`: - -```yaml-rasa title="config.yml" -pipeline: -# - ... - - name: LLMCommandGenerator - llm: - type: "cohere" -# - ... -``` - -For more information, see the -[LLM setup page on llms and embeddings](./llm-configuration.mdx#other-llmsembeddings) - -::: \ No newline at end of file diff --git a/docs/docs/llms/llm-configuration.mdx b/docs/docs/llms/llm-configuration.mdx index e3e4d00a7159..d101d46a92f5 100644 --- a/docs/docs/llms/llm-configuration.mdx +++ b/docs/docs/llms/llm-configuration.mdx @@ -49,7 +49,7 @@ nlg: Additional configuration parameters are explained in detail in the documentation pages for each of these components: -- [LLMCommandGenerator](./llm-command-generator.mdx) +- [LLMCommandGenerator](../concepts/llm-command-generator.mdx) - [FlowPolicy](../llms/flow-policy.mdx) - [Docseach](../llms/llm-docsearch.mdx) - [ContextualResponseRephraser](../llms/contextual-response-rephraser.mdx) diff --git a/docs/docs/llms/llm-intentless.mdx b/docs/docs/llms/llm-intentless.mdx index c0b0821cd721..b55db4c74edf 100644 --- a/docs/docs/llms/llm-intentless.mdx +++ b/docs/docs/llms/llm-intentless.mdx @@ -7,14 +7,20 @@ abstract: | forward without relying on intent predictions. --- -import RasaLabsLabel from "@theme/RasaLabsLabel"; -import RasaLabsBanner from "@theme/RasaLabsBanner"; +import RasaProLabel from "@theme/RasaProLabel"; +import RasaProBanner from "@theme/RasaProBanner"; import intentlessPolicyInteraction from "./intentless-policy-interaction.png"; import intentlessMeaningCompounds from "./intentless-meaning-compounds.png"; - + - + + +:::info New in 3.7 + +The *Intentless Policy* is part of Rasa's new Conversational AI with +Language Models (CALM) approach and available starting with version `3.7.0`. +::: The new intentless policy leverages large language models (LLMs) to complement existing rasa components and make it easier: diff --git a/docs/sidebars.js b/docs/sidebars.js index 94445e2c8e6c..8c2ec1de43e5 100644 --- a/docs/sidebars.js +++ b/docs/sidebars.js @@ -306,7 +306,7 @@ module.exports = { collapsed: false, items: [ "llms/llm-intent", - "llms/llm-command-generator", + "concepts/llm-command-generator", "llms/contextual-response-rephraser", "llms/llm-docsearch", "llms/llm-intentless",