Skip to main content

Deep Knowledge introduces a powerful multi-agent system for creating deep, comprehensive summaries of complex content.

Project description

Deep Knowledge

The Problem

Current summarization tools in the market typically generate shallow, surface-level summaries that fail to capture the rich complexity of content. These summaries often:

  • Miss the deeper connections between concepts
  • Ignore the hierarchical structure of information
  • Extract only the most obvious points
  • Lack contextual understanding
  • Fail to identify underlying frameworks or mental models

As a result, these tools provide little value for comprehensive learning, critical analysis, or deep content exploration.

Our Approach: Multi-Agent Summarization

Deep Knowledge introduces a powerful multi-agent system for creating deep, comprehensive summaries of complex content. Instead of treating summarization as a single task, we break it down into a coordinated pipeline of specialized agents:

  1. Mind Map Agent: Analyzes the structure and concepts of the content, creating both a structural and conceptual map
  2. Summary Architect: Designs a modular summary structure with specific instructions for each component
  3. Content Synthesizer: Generates each module following the architect's specifications

This approach ensures that summaries retain the original content's structure while revealing deeper patterns, frameworks, and connections.

Key Features

  • Deep structured summarization: Creates summaries that capture both structure and conceptual depth
  • Smart content handling: Automatically processes various document types with OCR detection
  • Token-aware processing: Intelligently manages content to work within model context limitations
  • Langchain integration: Seamlessly works with Langchain chat models
  • Visual mind mapping: Generates comprehensive mind maps to visualize content structure

Installation

pip install deep-knowledge

Usage Example

from deep_knowledge.summary import Summary

# From a file path
summary = Summary(input_path="my_book.pdf")
summary.run()
print(summary.output)

# From text content
text_content = "..."
summary = Summary(input_content=text_content)
summary.run()
print(summary.output)

Streamlit Demo

We created a Streamlit demo to showcase the Deep Knowledge summarization pipeline. To run the demo, follow these steps:

export PYTHONPATH=$PYTHONPATH:"$(pwd)"
streamlit run demo/streamlit_app.py

Langchain Integration

Deep Knowledge integrates smoothly with Langchain chat models. You can provide your own Langchain chat model, or use the "auto" option which intelligently selects the best available model:

from langchain_openai import ChatOpenAI
from deep_knowledge.summary import Summary

# Using a specific Langchain model
llm = ChatOpenAI(model_name="gpt-4o", temperature=0)
summary = Summary(llm=llm, input_path="article.pdf")

# Using auto mode (automatically selects from available API keys)
summary = Summary(llm="auto", input_path="article.pdf")

In "auto" mode, the system prioritizes:

  1. Google Gemini models (if GOOGLE_API_KEY is available)
  2. OpenAI models (if OPENAI_API_KEY is available)

This allows for easy experimentation with different LLM providers.

Flexible Input Options

Deep Knowledge accepts multiple input formats:

# From a file path
summary = Summary(input_path="document.pdf")

# From raw text content
summary = Summary(input_content="Your content here...")

# From Langchain Document objects
from langchain_core.documents import Document
documents = [Document(page_content="Content 1"), Document(page_content="Content 2")]
summary = Summary(input_documents=documents)

The library supports various file formats including PDF, DOCX, TXT, Markdown, and EPUB, with automatic OCR detection for scanned documents.

Roadmap

Token Management Optimization

Current implementation can be expensive as it sends the full content to each module creation step. Future improvements will include:

  • Having the Summary Architect return metadata about specific content sections for each module

However, using Google Gemini Flash models allows for free/low-cost experimentation

Interactive Refinement and Follow-ups

The current pipeline operates as a single-pass process, but users often need to refine outputs based on initial results.

  • Enabling conversational interactions to shape the summarization process
  • Allowing targeted refinement of specific modules without regenerating the entire summary

Adding possibility to configure LLM based on step

Now, there's only one LLM that works for all steps. But it would be a good feature to allow experimentation with different LLMs for different steps. E.g.:

  • gpt-4o for the Mind Map Agent
  • o1 for the Summary Architect
  • gemini-2.0-flash for the Content Synthesizer

Improved Reproducibility

We're working on enhancing the system's reliability when LLMs don't precisely follow the expected output format, including:

  • More robust output parsing
  • Fallback strategies for format deviations
  • Better error handling and recovery

Enhanced OCR Capabilities

Plans to expand OCR options include:

  • Supporting additional OCR providers
  • Implementing local OCR processing options

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the Apache 2.0 License - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

deep_knowledge-0.1.7.tar.gz (24.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

deep_knowledge-0.1.7-py3-none-any.whl (23.9 kB view details)

Uploaded Python 3

File details

Details for the file deep_knowledge-0.1.7.tar.gz.

File metadata

  • Download URL: deep_knowledge-0.1.7.tar.gz
  • Upload date:
  • Size: 24.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.9

File hashes

Hashes for deep_knowledge-0.1.7.tar.gz
Algorithm Hash digest
SHA256 9d2ed7831947e60beab5f995bf2ce5483f440d202141ceec8e3d59cd4c4680c4
MD5 cfaa393f21e4f1223349d269b70e80b7
BLAKE2b-256 a9cf0d3b8b66af3ac6480f6e0fb0e5730e6425b12aa80d69ba7f60f0f0fdd263

See more details on using hashes here.

File details

Details for the file deep_knowledge-0.1.7-py3-none-any.whl.

File metadata

File hashes

Hashes for deep_knowledge-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 9674260f4f4fdf6eceab1d1032e19e06108587acb19ad695f74890ca42ef63a2
MD5 5916bff36c8156bebc79cfd996bb6ea2
BLAKE2b-256 dc17dda6c9eeb9fb9093e1a246dada5cfab3a2eb448332f965cbb9a4420fbdfe

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page