This repo is for jugalbandi chatbot API that works on Indian government central schemes data. The chatbot can provide information about which scheme is most relevant for the user, benefits of the scheme, eligibility criteria, documents required. This video shows how to use this bot on whatsapp. You can chat with this bot using this link.
Illiteracy and lack of Information about government welfare schemes is the main in barrier in bottom of pyramid for getting those scheme benefits. However many of them have access to social media like Whatsapp on their mobile and can easily converse in local languages. Taking the welfare scheme information data like benefits, eligibility criteria and allowing citizens to converse with that data using voice.
Our bot API is build over FastAPI and uses Postgresql as the database. Before you can start running the API you need to set up some basic requirements given below:
- You have to create a postgresql database and then update its credentials in
.env
file.
When using voice/audio conversation you need a place to store all the recordings and have a public url for them so that popular messaging application or your own app can work.
- Fo this we have done the implementation for GCP, you can create a service account credential json file, and update ist path in
.env
file.
Note: To use other cloud platform you can do an implementation for them in cloud_filestorage.py
pip install requirements.txt
uvicorn main:app --host 0.0.0.0 --port 8080 --workers 1
This will start the API on 8080 port on which you can open the docs of API as http://localhost:8080/docs
Once you setup and try to use the API you will face an authentication error. This initial error will trigger creation of tables in database. Now, You need to go to table 'jugalbandi_tokens' and mannualy create an API key. And then authorise the api with thje key you have created.
Alternatively, we have provided docker file which you can use to make a docker image after making appropriate changes and deploy over a service.
Jugalbandi chatbot is a Finite State Machine which uses OpenAI models for doing transitions between the states and generating user responses. Multiple AI components are put together to achieve this bot.
We scraped the Indian government welfare schemes data from https://www.myscheme.gov.in/.
The bot can be deployed on popular messaging platforms of your choice like whatsapp or telegram. Ability to send voice notes and receiving the responses as voice notes is the key feature of this bot.
Bhashini models are used to perform speech to text, Indic translations and text to speech. We leveraged the model APIs hosted by AI4Bharat.
Embeddings models of OpenAI were used for doing the scheme searches. Davinci3 models of OpenAI were used to perform most of the reasoning and generate user responses.
Jugalbandi Reasoning Engine is a finite state machine which uses openAI model responses to perform state transitions. In User Need Extraction state, the goal of the chatbot is to capture the user need so as to find most relevant government schemes for the user. Filtered scheme name disambiguation state is where bot needs clarification from user about which scheme user is interested in. In Specific scheme conversation state, user discusses about a specific welfare scheme. After each of the user inputs, openAI LLM is called to decide what should be the user response and next state.
This work is part of OpenNyAI mission which is funded by EkStep and Agami.