🤖 Project S.O.C.R.A.T.E.S.: Sophisticated Orchestration of Collaborative Resources and AI Task Execution System
Project S.O.C.R.A.T.E.S. is a cutting-edge framework designed to harness the power of multi-agent AI systems for seamless collaboration, task automation, and resource management. By orchestrating specialized agents and leveraging advanced AI capabilities, S.O.C.R.A.T.E.S. enables efficient task execution and intelligent resource integration, making it an indispensable tool for researchers, developers, and organizations.
S.O.C.R.A.T.E.S. integrates a sophisticated multi-agent framework with state-of-the-art AI models, providing a powerful platform for collaborative task management and resource optimization. Whether it’s analyzing documents, generating content, or executing complex workflows, the system’s agents work together to deliver streamlined and intelligent solutions.
-
Advanced Chat Interface:
- 💬 Context-aware conversations using RAG
- 🧠 Intelligent response generation
- 📝 Chat history management
- 🔍 Semantic search capabilities
-
Document Management:
- 📄 Support for multiple formats (PDF, TXT, DOCX, MD)
- 🔄 Advanced document processing and vectorization
- 🗑️ Robust document deletion with resource cleanup
- 🔎 Full-text and semantic search
- 🔄 Efficient vector store management
- 🧹 Automatic resource cleanup and optimization
-
Modern Architecture:
- 🚀 LLaMA 3 70B via Groq for state-of-the-art responses
- 🔗 LangChain for RAG and memory management
- 💾 ChromaDB for efficient vector storage
- 🎯 Streamlit for responsive UI
- ⚙️ Unified configuration management
- 🤗 Local inference with SentenceTransformers
-
Enhanced Logging:
- 📝 Emoji-enhanced logging for better traceability
- 🔍 Detailed error tracking and reporting
- 📊 Improved operation status feedback
-
Improved UI:
- 🖥️ Updated chat interface with emoji roles
- 📋 Enhanced document management interface
- 🔔 Smooth notifications and feedback
- 🎨 Better visual consistency
-
Document Upload Enhancements:
- 📤 Improved document processing capabilities
- Python 3.12+
- Groq API key (get one at console.groq.com)
-
Clone the repository:
git clone https://github.com/Hams-Ollo/Dynamic-AI-Assistant-base.git cd Dynamic-AI-Assistant-base
-
Set up virtual environment:
python -m venv venv # Windows .\venv\Scripts\activate # Unix/MacOS source venv/bin/activate
-
Install dependencies:
pip install -r requirements.txt
-
Configure environment:
cp .env.example .env # Add your Groq API key and other settings to .env
-
Run the application:
streamlit run frontend/Home.py
Dynamic-AI-Assistant-base/
├── app/
│ ├── agents/
│ │ └── chat_agent.py # Core chat and RAG functionality
│ ├── utils/
│ │ ├── config.py # Unified configuration management
│ │ ├── document_processor.py # Document handling
│ │ └── memory.py # Memory management
│ └── core/ # Core application components
├── frontend/
│ ├── Home.py # Main entry point
│ └── pages/
│ ├── Chat.py # Chat interface
│ └── Document_Upload.py # Document management
├── data/ # Data storage
│ └── memory/ # Vector store and memory
├── docs/ # Documentation
└── tests/ # Test suite
The application uses a unified configuration system (app/utils/config.py
) that manages:
- Model settings (temperature, tokens, etc.)
- API configurations
- Memory management
- Document processing parameters
- Path management
Configuration can be customized through:
- Environment variables
.env
file- Runtime configuration
- Research Assistant: Process and analyze academic papers
- Documentation Helper: Quick access to technical documentation
- Knowledge Base: Create smart FAQ systems
- Legal Assistant: Analyze legal documents
- Training Support: Process training materials
Key customization points:
-
Document Processing:
- Adjust chunking in
document_processor.py
- Configure embedding models
- Modify vector store settings
- Adjust chunking in
-
Chat Behavior:
- Update prompts in
chat_agent.py
- Customize RAG integration
- Adjust memory management
- Update prompts in
-
User Interface:
- Modify Streamlit components
- Add new pages
- Customize styling
We welcome contributions! Please:
- Fork the repository
- Create a feature branch
- Submit a pull request
[Your License] - See LICENSE file for details
This release is version 1.1.0, featuring new enhancements and improvements.