Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/maxent-ai/converse
Conversational text Analysis using various NLP techniques
https://github.com/maxent-ai/converse
callcenter-analysis conversational-ai emotion-recognition huggingface machine-learning nlp nlu pytorch scikit-learn sentiment-analysis spacy speech-to-text text text-mining topic-modeling transformers
Last synced: 19 days ago
JSON representation
Conversational text Analysis using various NLP techniques
- Host: GitHub
- URL: https://github.com/maxent-ai/converse
- Owner: maxent-ai
- License: apache-2.0
- Created: 2021-11-18T11:40:44.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2023-06-12T21:32:49.000Z (over 1 year ago)
- Last Synced: 2024-12-27T07:08:07.216Z (26 days ago)
- Topics: callcenter-analysis, conversational-ai, emotion-recognition, huggingface, machine-learning, nlp, nlu, pytorch, scikit-learn, sentiment-analysis, spacy, speech-to-text, text, text-mining, topic-modeling, transformers
- Language: Jupyter Notebook
- Homepage:
- Size: 154 KB
- Stars: 178
- Watchers: 9
- Forks: 19
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
README
# PyConverse
-----------
[![Downloads](https://static.pepy.tech/personalized-badge/pyconverse?period=total&units=international_system&left_color=black&right_color=orange&left_text=Downloads)](https://pepy.tech/project/pyconverse)
[![Maintenance](https://img.shields.io/badge/Maintained%3F-yes-green.svg)](https://GitHub.com/Naereen/StrapDown.js/graphs/commit-activity)
[![made-with-python](https://img.shields.io/badge/Made%20with-Python-1f425f.svg)](https://www.python.org/)
[![PyPi version](https://badgen.net/pypi/v/pip/)](https://pypi.com/project/pip)
[![PyPI license](https://img.shields.io/pypi/l/ansicolortags.svg)](https://pypi.python.org/pypi/ansicolortags/)
[![Latest release](https://badgen.net/github/release/Naereen/Strapdown.js)](https://github.com/Naereen/Strapdown.js/releases)
## Let me try first
### Installation
```
pip install pyconverse
```### Usage
Please try this notebook that demos the core functionalities: [basic usage notebook](https://github.com/AnjanaRita/converse/blob/master/notebook/usage.ipynb)
## Introduction
Conversation analytics plays an increasingly important role in shaping great customer experiences across various industries like finance/contact centres etc...
primarily to gain a deeper understanding of the customers and to better serve their needs. This library, *PyConverse* is an attempt to provide tools & methods which can be used to gain an understanding of the conversations from multiple perspectives using various NLP techniques.## Why *PyConverse*?
I have been doing what can be called conversational text NLP with primarily contact centre data from various domains like Financial services, Banking, Insurance etc for the past year or so, and I have not come across any interesting open-source tools that can help in understanding conversational texts as such I decided to create this library that can provide various tools and methods to analyse calls and help answer important questions/compute important metrics that usually people want to find from conversations, in contact centre data analysis settings.
## Where can I use *PyConverse*?
The primary use case is geared towards contact centre call analytics, but most of the tools that Converse provides can be used elsewhere as well.
There’s a lot of insights hidden in every single call that happens, Converse enables you to extract those insights and compute various kinds of KPIs from the point of Operational Efficiency, Agent Effectiveness & monitoring Customer Experience etc.
If you are looking to answer questions like these:-
1. What was the overall sentiment of the conversation that was exhibited by the speakers?
2. Was there periods of dead air(silence periods) between the agents and customer? if so how much?
3. Was the agent empathetic towards the customer?
4. What was the average agent response time/average hold time?
5. What was being said on calls?and more... pyconverse might be of small help.
## What can *PyConverse* do?
At the moment pyconverse can do a few things that broadly fall into these categories:-
1. Emotion identification
2. Empathetic statement identification
3. Call Segmentation
4. Topic identification from call segments
5. Compute various types of Speaker attributes:
1. linguistic attributes like: word counts/number of words per utterance/negations etc.
2. Identify periods of silence & interruptions.
3. Question identification
4. Backchannel identification
6. Assess the overall nature of the speaker via linguistic attributes and tell if the Speaker is:
1. Talkative, verbally fluent
2. Informal/Personal/social
3. Goal-oriented or Forward/future-looking/focused on past
4. Identify inhibitions
7. Transcript summarization (Abstractive summarization)### What Next?
1. Improve documentation.
2. Add more use case notebooks/examples.
3. Improve some of the functionalities and make it more streamlined.### Built with:
|Transformers|Spacy|Pytorch|
|---|---|---|
|![](https://huggingface.co/front/assets/huggingface_logo-noborder.svg)|![](https://raw.githubusercontent.com/github/explore/8cf1837393d83900e767cc895dcc814d053e2ffe/topics/spacy/spacy.png)|![](https://upload.wikimedia.org/wikipedia/commons/9/96/Pytorch_logo.png)|### Credits:
_Note: The backchannel Utterance classification method is inspired by facebook's [Unsupervised Topic Segmentation of Meetings with BERT Embeddings](https://arxiv.org/abs/2106.12978) paper (arXiv:2106.12978 [cs.LG])_