- Overview
- Before you begin
- Run the starter kit
- Use post-call analysis with your own data
- How the starter kit works
- Customizing the starter kit
- Third-party tools and data sources
This AI starter kit illustrates a systematic approach to post-call analysis including Automatic Speech Recognition (ASR), diarization, large language model analysis, and retrieval augmented generation (RAG) workflows. All workflows are built using the SambaNova platform.
NOTE: You must use SambaStudio for the Automatic Speech Recognition (ASR) workflow. You can use Sambaverse or SambaStudio to perform text analysis.
This starter kit provides:
- A customizable SambaStudio connector that facilitates LLM inference from deployed models.
- A configurable SambaStudio connector that enables ASR inference workflow from deployed models.
- Implementation of a RAG workflow that includes prompt construction strategies which are tailored for call analysis, including:
- Call summarization
- Classification
- Named entity recognition
- Sentiment analysis
- Factual accuracy analysis
- Call quality assessment
This example is ready to use. We provide:
- Instructions for setup.
- Instructions for running the model as is.
- Instructions for customization.
This starter kit automatically uses the SambaNova snapi
CLI to create an ASR project and run batch inference jobs for doing speech recognition steps. You only have to set up your environment first.
Clone the start kit repo.
git clone https://github.com/sambanova/ai-starter-kit.git
You must perform SambaStudio setup and can optionally perform Sambaverse setup.
- The ASR pipeline requires that you perform the SambaStudio setup steps.
- For the text analysis, you can use either SambaStudio or Sambaverse.
To perform this setup, you must be a SambaNova customer with a SambaStudio account.
NOTE: You must have at least 3 RDUs available in your SambaStudio environment for the ASR pipeline batch inference jobs.
- Log in to SambaStudio and get your API authorization key. The steps for getting this key are described here.
- Select the LLM you want to use (e.g. Llama 2 70B chat) and deploy an endpoint for inference. See the SambaStudio endpoint documentation.
- Update the
sn-ai-starter-kit/.env
config file in the root repo directory. Here's an example:
BASE_URL="https://api-stage.sambanova.net"
PROJECT_ID="12345678-9abc-def0-1234-56789abcdef0"
ENDPOINT_ID="456789ab-cdef-0123-4567-89abcdef0123"
API_KEY="89abcdef-0123-4567-89ab-cdef01234567"
SAMBASTUDIO_KEY="1234567890abcdef987654321fedcba0123456789abcdef"
- Update the config file:
- Set the variable
api
to"sambastudio"
. - Run
snapi app list
, search for theASR With Diarization
section in the output, and setasr_with_diarization_app_id
in theapps
section of the config file to the app ID.
- Follow the instructions in this guide for installing SambaStudio SNSDK and SNAPI, (you can omit the Create a virtual environment step if you plan to create a
post_call_analysis_env
environment in the next step.)
- Create a Sambaverse account at Sambaverse and select your model.
- Get your Sambaverse API key (from the user button).
- In the repo root directory find the config file
sn-ai-starter-kit/.env
and specify the Sambaverse API key, as in the following example:
SAMBAVERSE_API_KEY="456789ab-cdef-0123-4567-89abcdef0123"
- In the config file, set the
api
variable to"sambaverse"
.
We recommend that you run the the starter kit in a virtual environment or use a container.
If you want to use virtualenv or conda environment
- Install and update pip.
cd ai-starter-kit/post_call_analysis
python3 -m venv post_call_analysis_env
source post_call_analysis_env/bin/activate
pip install -r requirements.txt
- Run the following command:
streamlit run streamlit/app.py --browser.gatherUsageStats false
You will see the following Streamlit user interface
If you want to use Docker:
-
Update the
SAMBASTUDIO_KEY
,SNAPI
,SNSDK
args in docker-compose.yaml file -
Run the command:
docker-compose up --build
You will be prompted to go to the link (http://localhost:8501/) in your browser where you will be greeted with the streamlit page as above.
NOTE: For this task, you must have at least 3 RDUs available in your SambaStudio environment.
-
Pick your source audio (.wav file) or transcript (CSV file containing the call transcription with diarization).
-
In the GUI, select either Audio input or Text transcript input and upload the file. If the input is an audio file, the processing step could take a couple of minutes to initialize the bash inference job in SambaStudio. Then the GUI is updated to show information like the following:
-
In the GUI, select Analysis Settings and set the analysis parameters. You can define a list of classes for classification or specify entities for extraction.
Provide the input path containing your facts and procedures knowledge bases, or you include a list of urls that you want to scrape to include it as facts and procedures knowledge bases.
By default, this starter kit performs factual and procedures check only on .txt and PDF files or urls.
-
Click the Analyse transcription button to run the analysis steps over the transcription. After a short time (a few minutes) you will see the following output structure.
This section discusses how the start kit works and which tasks it performs with each step.
-
Audio processing: Audio processing is performed by the batch inference pipeline for ASR and Diarization and is composed of these steps:
-
Transcription: The Transcription step involves converting the audio data into text format. This step utilizes Automatic Speech Recognition (ASR) technology to transcribe spoken words into written text.
-
Diarization: The Diarization process distinguishes between different speakers in the conversation. It segments the audio data based on speaker characteristics, identifies each speaker's audio segments, and enables further analysis on a per-speaker basis.
This pipeline returns a CSV file that contains the timestamped audio segments with speaker labels and transcription assigned to each segment.
-
-
Text Analysis: For the analysis process, you set a list of categories for classifying the text, and the LLM assigns the text to one category using zero shot classification. Analysis consists of several steps.
-
Transcript Reduction: Transcript reduction involves condensing the transcribed text to eliminate redundancy and shorten it enough to fit within the context length of the LLM. This results in a more concise representation of the conversation. This process uses the reduce langchain chain and the
reduce prompt template
, which iteratively takes chunks of the conversation and compresses them while preserving key ideas and entities. -
Summarization: Summarization generates a summary of the conversation, capturing its key points and main themes. This process uses the
summarization prompt template
. -
Classification: Classification categorizes the call based on its content or purpose by assigning it to a list of predefined classes or categories. This zero-shot classification uses the
classification prompt template
. The reduced call transcription and a list of possible classes is passed to the langchain list output parser to get a list structure as result. -
Named entity recognition: Named Entity Recognition (NER) identifies and classifies named entities mentioned in the conversation, such as names of people, organizations, locations, and other entities of interest. We pass (1) a list of entities and (2) the reduced conversation to the
NER prompt template
. The output is parsed with the langchain Structured Output parser, which returns a JSON structure containing a list of extracted values for each entity. -
Sentiment Analysis: Sentiment Analysis determines the overall sentiment expressed in the conversation. This can help gauge the emotional tone of the interaction. This process uses the
sentiment analysis prompt template
. -
Factual Accuracy Analysis: Factual Accuracy Analysis evaluates the factual correctness of statements made during the conversation. This process uses a RAG (Retrieval Augmented Generation) methodology:
- A series of documents are loaded, chunked, embedded, and stored in a vectorstore database.
- Relevant documents for factual checks and procedures are retrieved and contrasted with the call transcrip using the
Factual Accuracy Analysis prompt template
and a retrieval langchain chain. - The output is then parsed using the langchain Structured Output parser, which converts it into a JSON structure containing a
correctness
field, anerror
field containing a description of the errors in the transcription, and ascore
field.
-
Procedure Analysis: Procedure Analysis evaluates whether the agent follows predefined procedures during the conversation and ensures that the agent's procedures correspond with procedural guidelines. This process uses the
procedures analysis prompt template
.The output is then parsed using the langchain Structured Output parser, which converts it into a JSON structure containing a
correctness
field, anerror
field containing a description of the errors evidenced in the transcription, and ascore
field. -
Call Quality Assessment: Call Quality Assessment evaluates agent accuracy in the call. It helps identify areas for improvement in call handling processes. In this starter kit, a basic analysis is performed alongside the Factual Accuracy Analysis and Procedure Analysis steps. The analysis assigns a score based on the errors made by the agent in the call, and predicts the NPS score that the user might give. This is achieved using the
get_call_quallity_assessment()
method in the Analysis script.
-
You can customize this starter kit in many ways.
The precise process for customizing the model depends on whether you're using Sambaverse or SambaStudio.
With Sambaverse, you can test and compare the performance of several models.
To change the model that this starter kit is using:
- Log in to Sambaverse.
- Find the model you want to use in the playground, select the three dots, click Show code, and find the values of
modelName
andselect_expert
. - To modify the parameters for calling the model, open
config.yaml
and set the values ofsambaverse_model_name
andsambaverse_expert
. You can also modifytemperature
andmaximum generation token
to experiment with that.
For the ASR steps, only one pipeline is available. You can see the components in the Jupyter notebook.
For text analysis, we recommend that you use one of the most capable models like Llama2 7B. You can fine tune that model to improve response quality.
The SambaStudio documentation helps you learn how to prepare your training data, import your dataset into SambaStudio and run a training job.
NOTE: You set things like list of categories to classify the conversation in or the entities to extract from the conversation in the Settings section in the SambaStudio GUI. In the config.yaml
file, you customize model-specific settings like the temperature.
Prompting has a significant effect on the quality of LLM responses. A series of prompts used for each text analysis ste are in the prompts
folder of this starter kit.
All prompts used in Analysis section can be further customized to improve the overall quality of the responses from the LLMs. For example, the following prompt was used to generate a response from the LLM, where question
is the user query and context
are the documents retrieved.
template: |
<s>[INST] <<SYS>>\nUse the following pieces of context to answer the question at the end.
If the answer is not in context for answering, say that you don't know,
don't try to make up an answer or provide an answer not extracted from provided context.
Cross check if the answer is contained in provided context.
If not then say \"I do not have information regarding this.\"\n
context
{context}
end of context
<</SYS>>/n
Question: {question}
Helpful Answer: [/INST]
)
Learn more about prompt engineering here.
During factual accuracy analysis, we check if the agent in the conversation made any mistake by comparing it with files that have the informaition. This kit loads a TXT file. You can add or customize document loaders in the load_files
method (in the vectordb class). Several examples of document loaders for different formats with specific capabilities are in the data extraction starter kit.
You can customize the basic example in this starter kit by including your own metrics in the evaluation steps. You can also modify the output parsers to obtain extra data or structures in the analysis script methods.
You can customize batch inference by modifying methods in the analysis, asr notebooks, and analysis, asr scripts.
All the packages/tools are listed in the requirements.txt
file in the project directory. Some of the main packages are listed below:
- langchain (version 0.1.2)
- python-dotenv (version 1.0.1)
- requests (2.31.0)
- pydantic (1.10.14)
- unstructured (0.12.4)
- sentence_transformers (2.2.2)
- instructorembedding (1.0.1)
- faiss-cpu (1.7.4)
- streamlit (1.31.1)
- streamlit-extras (0.3.6)
- watchdog (4.0.0)
- sseclient (0.0.27)
- plotly (5.19.0)
- nbformat (5.9.2)
- librosa (0.10.1)
- streamlit_javascript (0.1.5)