Farmer chat is a multi-modal, multi-language QnA bot intended to assist farmers, extension workers, and agronomists. Powered by cutting-edge technologies like Large Language Models (LLMs), Generative AI and RAG (Retrieval Augmented Generation), Farmer.Chat is your go-to source for agricultural advice, tips, and news. As part of the Digital Green tech stack, Farmer.Chat relies on Farmstack to retrieve the content required for answering user queries.
-
Multi-Lingual Support: Leveraging the power of Google Translate, Farmer.Chat can converse and provide information in multiple languages in both text and audio, allowing it to cater to users from diverse linguistic backgrounds.
-
Vectorized Document Retrieval: Retrieves the content required for answering the queries from Farmstack, a multi-tenant content and dataset exchange platform developed by Digital Green. Farmstack vectorises text from extensive agricultural PDF & Rich text documents, videos, websites etc. and retrieve relevant information based on vector similarity.
-
AI-Powered Chat: Backed by RAG (Retrieval Augmented Generation) with a state-of-the-art AI pipeline comprising of below phases to answer user queries.
- User intent classification
- Query rephrasing
- Content Retrieval using Similarity search
- LLM Re-ranking of the content chunks retrieved
- Generation of the answer through custom-made prompts
-
Support for Multi-channel interface: The chat service is exposed over REST APIs using Django-Rest-Framework (DRF) which can be plugged to multiple chat interfaces like: Telegram, WhatsApp, Mobile app, Website, IVR etc.
Farmstack is a a multi-tenant content and dataset exchange platform developed by Digital Green. The Tenants/Organizations can upload data in various formats like PDFs, videos, RTF documents, websites etc. Farmstack vectorises text from these documents and retrieve relevant information based on vector similarity.
The below diagram shows Farmer.Chat/FarmStack’s process, flow of information and control.
The setup primarily will have two kinds of Users. They are,
-
Content curator/ Administrator
- They login to FarmStack Web Application.
- Information flow happens through the steps (a), (b), (c) etc,.
-
Farmer/ Front Line Extension Worker
- Information flow happens through the steps (1), (2), (3) etc,.
- The farmers/ frontline extension workers can access the services through a messenger or an app.
Administrator/Content Curator side:
- Uploading of the content(or content source) into FarmStack to create a knowledge base.
- FarmStack converts the knowledge base to a vector store.
- View analytics and conversation logs
Farmers/Frontline Extension Workers side:
- Routed from front end to application backend (for eg, messenger application like telegram and whatsapp)
- The queries can be listened using API integration and passed to the backend Bot logic
- The bot logic invokes retrieval from the vector store create on the knowledge base
- It uses the LLM calls to generate the answer which is sent back to the user
- The query and responses are logged in the DB
- AI Services :
- Google ASR (Automated Speech Recognition), Translation and TTS (Text-To-Speech)
- Open AI GPT-3.5 turbo for embedding creation, query rephrasing and generation. GPT-4 for Intent classification and LLM reranking
- Language: Python
- Frameworks: Peewee ORM for Database interaction and Django-Rest-Framework for exposing REST APIs
REST APIs are implemented in Farmer.Chat to retrieve the answers for text and voice based user queries in both text and voice. Please refer API specification for full specification of APIs documented in OpenAPI V 3.0.0 format.
-
The Farmer.chat solution is hosted on Digital Green server which is accessible through
- A Web-based User interface at https://farmerchat.farmstack.co/opensource-ui/
- APIs at https://farmerchat.farmstack.co/opensource-be/api
-
This solution uses the content from the Farmstack instance hosted at https://datahubtest.farmstack.co/
-
Register and upload the content in Farmstack. Please refer Farmstack User guide
-
Click on the link to open the User Interface in a web browser
-
Enter the email-id registered in Farmstack and click on Save Email
-
Ask queries in text (Language will be auto-detected for text based queries and response will be received in the detected language, hence language selection is not required.)
-
Tap on to start recording the voice query and once recording is done, tap again to stop recording and send the voice query. Language selection is a must before asking the voice queries for the ASR models to work best. Choose the required langauge from the options in left pane. If no langauge is selected, it will default to English in US accent. Ensure to click on Set Language to set the language.
-
After the query response is received, to listen to the audio of the response, click on just below the response.
- Note:
- The user interface is a reference implementation ONLY, built using naive HTML, CSS and Javascript for interacting with Farmer.chat and is part of the repo index.html
- For the voice query to work, Please ensure that the browser permission is enabled to access the Microphone when it is prompted. This is tested on Chrome and Safari.
- The chat history will be lost once the page is refreshed.
Farmer.Chat can be setup to run in your own environment. The following can be customised:
- Prompts at various stages in pipeline (Intent classification, Rephrasing, Reranking and Generation)
- Choice of whether to log the transactions in Database
- Open AI model parameters like GPT-3 and GPT-4 model versions, temperature, MAX_TOKENS
- Languages that bot support and the default language for ASR
- Farmstack instance from where the content should be retrieved
- Chat history window to be considered during question rephrasing
Please refer the section on configuration: Setting up the .env file and .config.env file
- Linux or Mac OS
- Python 3.9 or 3.10
- VScode or other supporting IDE
- PostgreSQL database (V 15.x)
- Google application credentials JSON file for translation services
- Open AI api key
-
Clone the repo:
Clone the repo into an empty directory in IDE
git clone https://github.com/digitalgreenorg/monorepo
(If you are using VSCode, follow the steps Open VSCode -> File -> Open Folder -> Create a New Folder in desired directory -> Open -> Terminal -> New Terminal and then execute above git command)
Please install git command line for your OS from here
-
Open a new terminal in your IDE and switch to the farmer-chat directory
cd monorepo/farmer-chat
-
Farmer.chat uses 2 environment files, one for setting up secrets (.env) and the other one for setting up other optional configurations (.config.env). Ensure both the files are directly under the farmer-chat directory. .config.env is part of the repo and can readily be used. For .env, an example file example.env file is added to the repo. User should create a file with name .env directly under the farmer-chat directory.
-
Following Variables to be configured in .env file as per your environment:
- Google application credentials:
GOOGLE_APPLICATION_CREDENTIALS=<Path to Google application credentials file>
- Open AI API key:
OPENAI_API_KEY=<Open-AI API key>
- Database (required only if WITH_DB_CONFIG=True in .config.env file):
DB_USER=<Database Username>
DB_PASSWORD=<Database password>
DB_HOST=<Database Host IP or domain>
DB_PORT=<Database port>
DB_NAME=<Name of the database>
DB_MAX_CONNECTIONS=<Maximum number of connections that can be present in the pool>
DB_STALE_TIMEOUT=<Stale timeout for the Database connections>
Please contact [email protected] for a pre-configured environment file.
- Google application credentials:
-
Following Variables can be configured in .config.env file as per your environment:
CONTENT_DOMAIN_URL:<Farmstack Base URL for authentication and content retrieval>. ex: https://datahubtest.farmstack.co/be/
LANGUAGE_SHORT_CODE_NATIVE:<Default language code for Farmer-chat> ex: en
LANGUAGE_CODE_NATIVE:<Default language bcp code for Farmer-chat voice queries and ASR> ex: en-US
Additional configuration: The following variables can be configured if required:
WITH_DB_CONFIG=<True/False> based on whether conversations should be logged in Database
DJANGO_DEBUG_MODE=<True/False> based on whether Django should be started in debug mode
INTENT_CLASSIFICATION_PROMPT_TEMPLATE=<Multi-line prompt to be used for classification of the user intent>
CONVERSATION_PROMPT=<Multi-line prompt to be used to drive the conversation with the user>
UNCLEAR_QN_PROMPT=<Multi-line prompt to be used to seek clarity from the user>
EXIT_PROMPT=<Multi-line prompt to be used to exit the conversation>
OUT_OF_CONTEXT_PROMPT=<Multi-line prompt to be used to convey that the question is out of context>
REPHRASE_QUESTION_PROMPT=<Multi-line prompt to be used during question rephrasing>
RERANKING_PROMPT_SINGLE_TEMPLATE=<Multi-line prompt to be used during reranking>
RESPONSE_GEN_PROMPT=<Multi-line prompt to be used generate response>
GPT_3_MODEL=<GPT-3 model version to be used.>
GPT_4_MODEL=<GPT-4 model version to be used.>
TEMPERATURE=<temperature setting of the LLM.>
MAX_TOKENS=<Maximum number of tokens in output of LLM>
-
-
Run the below commands in sequence (to create and activate the virtual environment and install required dependencies)
python3 -m venv .myenv source .myenv/bin/activate pip install -r requirements.txt
-
Start the Django development server
python3 manage.py runserver
-
Once the development server is started, the APIs are accessible at http://localhost:8000/api
-
Edit the index.html to point the baseUrl to http://localhost:8000 instead of https://farmerchat.farmstack.co/opensource-be and the index.html can be used as explained in section above.
- Set current directory to project root directory after configuring env files
- Run command
cd database
- Run command
pem migrate
- Import the Languages and labels into the database
psql -h hostname -p port -U username -d database_name -f multilingual_text_data.sql
Please refer to the code documentation here
- The retrieved answers may be incomplete if the asnwer to queries does not exist in a running text (paragraph mode) in the content documents. For example, the answer lies in tables, images, table of contents, embedded links etc.
- Sometimes, the Google-translate may detect a language which is absurd and bot answers back in the same language. This happens especially in cases where the query is incomplete
- Some browsers may have problem with accessing microphone which leads to issues while sending voice queries.
Please contact [email protected] for any queries.