Skip to content

Latest commit

 

History

History
82 lines (56 loc) · 5.58 KB

README.md

File metadata and controls

82 lines (56 loc) · 5.58 KB

Financial-Q-A-Chatbot

Overview

The financial industry operates on the management, analysis, and reporting of vast amounts of data, including financial statements, balance sheets, and actuarial reports. Organizations rely on accurate, up-to-date data to make informed decisions on investments, budgeting, forecasting, and risk management. However, accessing and analyzing this information manually is time-consuming, especially when dealing with large, complex financial documents. A report by McKinsey suggests that automation and AI adoption in finance is growing, with 60% of tasks like data processing and reporting being automated across firms. This trend highlights the need for leveraging advanced natural language processing (NLP) models to simplify this process.

A financial question-answer chatbot provides a solution by using AI to extract relevant information from financial documents and respond to user queries in a concise and understandable manner. By fine-tuning large pre-trained language models (LLMs) such as GPT or BERT with domain-specific financial data, the chatbot can interpret both structured data (tables, charts) and unstructured data (textual explanations). This approach improves efficiency, reduces response times, and offers real-time analysis without the need for manual intervention.

The increasing adoption of machine learning (ML) techniques in financial services, such as credit risk modeling, fraud detection, and customer support automation, highlights the critical role of AI-powered chatbots. This project aims to advance the application of AI in finance by building a chatbot tailored to answering financial queries using advanced NLP and machine learning technologies.

The solution will enhance user experience by delivering accurate responses and provide a robust tool for businesses and financial institutions to interact with complex datasets. By fine-tuning a model for the financial domain, significant benefits can be achieved, including improved decision-making, faster access to critical information, and enhanced client engagement.


Project Architecture

Financial Chatbot


Project Components

Dataset

The dataset is highly structured and consists of financial tables and accompanying textual information.

The tables include key metrics such as:

  • Actuarial assumptions for pension funds (e.g., inflation rates, salary increases, discount rates).
  • Intangible assets including internally developed software costs and amortization.
  • Product sales data and segment-wise financial analysis.
  • Revenue and net income breakdown for various years.

The dataset is annotated with questions and answers, spanning different formats:

  • Extracting values from tables: E.g., "What is the 2019 rate of inflation?"
  • Performing arithmetic operations: E.g., Calculating the average rate of inflation.
  • Comparing figures across multiple years: E.g., "What is the percentage change in total inventories between 2018 and 2019?"

Approach

  1. Data Preprocessing:

    • Clean and structure the dataset to extract relevant financial tables and textual paragraphs.
    • Standardize input formats for fine-tuning the model using JSON files for training and testing.
  2. Fine-Tuning the Model:

    • Fine-tune a pre-trained large language model (LLM) using the financial dataset.
    • Teach domain-specific terminologies and concepts using supervised learning with labeled questions and answers.
  3. Question Answering System:

    • Build a system to recognize and answer various question types:
      • Span-based Questions: Extract specific data points directly.
      • Arithmetic Questions: Handle calculations like percentage changes or average rates.
      • Multi-span Questions: Answer questions requiring multiple comparisons across datasets.
  4. Evaluation and Testing:

    • Evaluate the model using metrics like R² score, MSE, MAE, and RMSE for numeric predictions.
    • Use evaluation metrics for LLMs like Perplexity, BLEU, and ROUGE for generative tasks.
    • Develop a robust testing framework to ensure accurate handling of diverse financial queries.

Evaluation Metrics:

Financial Chatbot Financial Chatbot Financial Chatbot


Technologies

  1. Pretrained Model: Hugging Face, GPT, BERT, or similar models.
  2. Frameworks: PyTorch for model development and fine-tuning.
  3. Natural Language Processing (NLP): Techniques for financial terminology and document analysis.
  4. Backend: Python-based backend using FastAPI, Flask, or Streamlit for chatbot interfacing.
  5. Deployment: Scalable deployment on cloud platforms like AWS, Azure, or Google Cloud.

Financial Chatbot Financial Chatbot Financial Chatbot

Streamlit Web APP deployed at AWS EC2 public instance at http://3.89.24.100:8502/