/llm-text-summarization

A comprehensive guide and codebase for text summarization using Large Language Models (LLMs). Dive into techniques, from chunking to clustering, and harness the power of LLMs like GPT-3.5 and GPT-4.

Primary LanguagePython

LLM-based Text Summarization: Novice to Maestro πŸš€

A comprehensive guide and codebase for text summarization harnessing the capabilities of Large Language Models (LLMs). Delve deep into techniques, from chunking to clustering, and maximize the potential of LLMs like GPT-3.5 and GPT-4.

πŸ“„ Article: I highly recommend reading this article before diving into the code.

Architecture

Full_Architecture

πŸš€ Getting Started

  1. Clone the Repository
  2. Install Dependencies:
    python3 -m pip install -r requirements.txt
  3. Install Spacy's English Dataset:
    python3 -m spacy download en_core_web_sm
  4. Set Up OpenAI API Key:
    export OPENAI_API_KEY='sk-...'
  5. Configure IO: Navigate to src/config.yaml and update the input_file and output_file parameters under io_config.
  6. File Handling: For the input file, only .txt is accepted. For the output, .json is preferred. Place the input file in the input folder. The generated summary will be in the output folder.
  7. Run the Program:
    cd src/
    python3 main.py

πŸ›  Understanding the config.yaml File

  • summary_type_token_limit: Determines how to categorize the input text: short, medium, or long.
  • sentence_splitter: Adjust approx_total_doc_tokens. Keep it around 1000 for medium-sized texts and up to 6000 for longer texts.
  • cod: Configuration for Chain of Density (CoD) prompting.
  • map_reduce: To further condense the final summary with CoD, set final_dense to true.
  • cluster_summarization: Adjust num_closest_points_per_cluster (max value: 3) for the top-k best chunks. Vary num_clusters (hyper-parameter for k-means) to optimize results.
  • Remaining configs are self-explanatory.

πŸ“‹ Output JSON Format

The output JSON comprises:

{
    "summary": "Descriptive final summary...",
    "keywords": ["Keyword1", "Keyword2", "..."],
    "metadata": {
        "total_tokens": 3625,
        "total_cost": 0.082,
        "total_time": 86.23
    }
}
  • summary: The final summary output
  • keywords: important keywords and phrases
  • metadata: Provides total time (in seconds) taken to execute your summary, total cost (in USD) for openai, and total token counts in the whole process

❀️ If this repository helps, please star ⭐, and share βœ”οΈ!
If you also found the article informative and think it could be beneficial to others, I'd be grateful if you could like πŸ‘, follow πŸ‘‰, and shareβœ”οΈ the piece with others.
Happy coding!