On this page we will introduce some core concepts to consider when building your bot with Teneo. In contrast to previous pages in our Build Your Bot section, we take a step back from implementation details here and focus on the big picture of your final bot instead. Typically, a chatbot implementation consists of the following stages:
Before starting to build, let's take a step back. Within any business there is a wide range of possible uses for conversational applications. Try to consider all possible options and evaluate them regarding:
Once you have identified the area and goals you are looking to achieve, you can start narrowing down the use case.
When you start building a bot, develop a clear understanding about the tasks the bot is suppposed to solve. Start by identifying an appropriate business case. Focus on the business problem, not the technology. Ensure there are sufficient volumes of interactions to deliver the expected returns. There can be various business drivers, here are some frequent ones:
Don't forget to establish key performance indicators that allow you to measure the success of the coversational application and to understand the value that it is providing for your business.
So by now, you know where you're heading, but before you proceed with building the bot, you first have to determine it's scope. Where should you start? Which questions or tasks should your very first bot be able to handle? The analysis of data, talking to subject matter experts and finding natural use cases that benefit your business will help you narrow down the scope:
Based on this analysis you can then decide on the core functions or conversations that you intend to build. It's a good idea to select specific areas of the business to cover, and to make the scope clear to the end user. With a combination of some core flows to satisfy requests in your chosen area and some flows that belong to the extended scope ouf your bot, your bot is well equipped to answer any questions related to this area, albeit some of them in a very general way.
Sometimes, natural language data from previous customer interactions is available. Examples include:
Such data is a great starting point to get a feeling for what kinds of requests your bot will face. If possible, you should do some kind of quantitative analysis of the existing data in order to identify the most common questions. Once identified, you can then let your bot deal with higher frequent subjects first, as they are more likely to pay off quickly. Moreover, you can use some of the pre-existing data as example inputs to train class triggers.
Teneo Discovery can be used to speed up the process of identifying crucial topics and user requests. However, Teneo Discovery is currently not available with Teneo Developer sandbox environments, but only to customers with a commercial license. Contact us to find out more!
During the development of your bot, you should always spend time with subject matter experts. They are:
Try to select processes that allow the customers to get something specifially done and make sure that these processes can be fully automated from beginning to end. This will delight the customer and also achieve most benefit to the company.
When screening previous customer interactions (for example call center interactions) you will rarely find FAQ-like conversations that consist of a single customer question getting a single answer from the agent. Rather, the conversations are likely to involve several points of clarification from the user to get the exact answer or action required. The customers are pleased if we can help them with their exact request. This is true for call centers but also for conversational AI platforms. Instead of creating FAQ-flows, we will thus create some more advanced multi-step flows that understand exactly what the customer requests.
Analysing possible use cases may also mean that you have to discard some use cases because they are too complex or always require human interactions. You save a lot of time and effort by acknowledging this before you start building in vain.
At this point, you have set the goals and the scope for your bot. Now it is time to actually start building it! We recommend you to start with a rapid prototype of some dialogues and conversations that you expect yout bot to be able to handle. Just get going by implementing the rought outlines of the dialogues together with subject matter experts. Once your prototype is up and running you can then go ahead expand it with more special features and requirements.
For many scenarios, you can have a first draft of a flow in Teneo ready in just a few hours. This will allow you to test if the dialogue you have designed is natural and, most importantly, if it provides a good user experience. You can roughly follow these steps, that will help you to rapidly create a prototype.
Before modeling flows, you should first collect some example questions that you expect users to ask your bot:
Drawing out the flow logic graphically to represent the dialogues is a great place to start your design. These can then easily be translated into the same flow design graphically in Teneo.
Once the core ‘Happy Path’ for the dialogue design is established we recommend creating the flow in Teneo.
During this whole process, keep in mind how humans use language to efficiently convey what they want to achieve. If talking to your bot feels like being forced down a predefined menu structure with no shortcuts or deviations allowed, then you should maybe consider a web form instead of a bot for this application. The advantage of a good coversational AI application is that you can imitate human interactions while collecing information from the user. For example, you bot may listen for information the user provides before the bot having prompted for it or allow the user to interrupt the bot and afterwards pick up the conversation again.
Once you have built a few primary flows for your prototype bot, you should expand it a little bit before then going on to thoroughly test it. Let's look at the following 3 concepts for expansion:
In human to human interactions, each sentence is considered in relation to earlier parts of the conversation - we understand that inherently. In order to build a smart bot, we need to do the same. All of this is easily implemented in Teneo and will give a great user experience!
From the very beginning, make sure that you setup your implementation in way that it allows for future growth of your bot. Users will not want to switch from one bot to another to perform different tasks. Be aware that your bot can end up consisting of hundreds or even thousands of flows run from the same solution, and consider ongoing maintenance. This will pay of when your bot grows. We recommend you to:
Once you are happy with the behaviour of the various flows you have built you can add robustness, ensuring that different intents don’t overlap.
Once the first iteration of your chatbot has been produced, you need to preliminary publish the solution, and give it to a group of test users to see how they get on.
In addition to that, don't forget to run the automated system test. These will highlight any issues that are present, prior to every round of testing.
Your bot is now ready to be released to the outside world! However, before you publish, think of a publishing procedure that includes testing and deployment of:
These workflows and procedures shall be applied to environments of all stages: Development, Quality Assurance and Production.
Now that your bot has been fully built and published, the implementation process does not stop! The real customer dialogues that are being run through the bot will create a rich data source which we can use for many purposes. For example, having access to this data may help to improve the performance of your bot, and it may deliver valuable business insights.
Naturally, looking at the log data from user chats with your bot gives you a good insight into what works well and what doesn't and thus the potential to improve your bot based on this data. From within its bot building platform, Teneo will proactively highlight where to:
Moreover, analyzing user chat data can help you to identify out of scope yet related topics that the uses are requesting. This can be useful to prioritize additional coverage in coming releases and thereby further increase the success of your bot.
Chat data can also be used to derive usage statistics. These can be fed into existing Business Intelligence systems and, together with additional data, can be used to gain an understanding of how the bot is performing - both in terms of technical functionality but also in terms of whether key performance indicators are delivered and still in line with the business expectations.
We have already seen how the stored user data can be used to improve and measure the performance of your bot. But there is even more value to it than that. Performing a deeper and more structured analysis of the chat data can give you valuable business insights from the customer's point of view. Unlike web-driven UIs, where users can mainly select from pre-defined options to assess your product, querying freeform user data allows you to discover what the users really wanted, for example products or product combinations that are not yet offered.
Dialogues are basically a structured collection of unstructured data. They are structured into user inputs and bot responses, which are ordered sequentially. And while the bot's responses are pre-defined, the user inputs are freeform and unstructured. The same content may potentially appear in a multitude of different ways and variants. In order to access the key content, a rich query language is required that has been designed from the ground to understand human language. Even more so, to resolve relational user inputs like "That's fantastic" your query needs access to previous turns in the dialogue to find the subject that the user denoted as being fantastic.Teneo's Query Language is available to build such queries on chat data from within the bot building platform. It has been optimized to make this complex task much simpler.
Was this page helpful?