Skip to content

yousefabuz17/IslamAI

Repository files navigation

IslamAI - Quran and Islamic Knowledge AI Chatbot

IslamAI is an AI chatbot project designed to provide accurate and reliable information about the Quran and Islamic teachings. Unlike general-purpose chatbots, IslamAI is focused solely on answering questions related to the Quran and the Islamic religion. It utilizes data from the Quran and other Islamic sources to provide accurate and insightful answers to user queries.

Table of Contents

Features

  • Quranic Information: IslamAI is equipped with an extensive database of Quranic information. It can provide details about individual surahs, ayahs, and keywords within the Quran.

  • Islamic Teachings: The chatbot can answer questions about various aspects of Islamic teachings, rituals, and practices based on reliable sources.

  • Interactive Interface: Users can interact with IslamAI by asking questions and receiving informative responses.

Code Organization

  • Modular Approach: The code is meticulously organized into modular components, following best practices in software design. Each major feature, such as QuranAPI, HadithAPI, and IslamFacts, is encapsulated in a separate class. This modular structure ensures that future changes or additions can be made with ease, as each component is self-contained and independent.

  • Configurability: Configuration settings are thoughtfully separated from the code, allowing for straightforward adjustments and customization without the need to modify the core logic. This separation of concerns simplifies maintenance and ensures that future changes to configuration parameters are hassle-free.

  • Singleton Pattern: The Singleton pattern is applied strategically to guarantee that only one instance of specific classes, like QuranAPI, is created. This design choice optimizes resource utilization and simplifies future updates or extensions.

  • AsyncIO: Asynchronous programming with asyncio is employed to facilitate efficient concurrent operations. This approach enhances performance and responsiveness, making it straightforward to incorporate additional asynchronous tasks or enhancements in the future.

  • Data Serialization: JSON files are chosen as the data storage and retrieval format. This decision enhances data integrity and portability. Should there be a need to change data storage formats or structures, the transition process remains straightforward.

  • Code Efficiency: The use of caching mechanisms, like LRU caching, optimizes performance and resource utilization.

  • Libraries and Frameworks: The choice of libraries and frameworks ensures that the codebase remains compatible with the latest developments in these technologies, making future updates and maintenance seamless. Here are some of the libraries and frameworks used in this project:

Library/Framework Description
TensorFlow TensorFlow is a widely adopted machine learning framework that powers the AI capabilities of this project.
Transformers The Transformers library, known for its natural language processing capabilities, plays a key role in enhancing the chatbot's language understanding.
aiohttp aiohttp is used for asynchronous HTTP requests, optimizing performance and responsiveness.
bs4 (BeautifulSoup) BeautifulSoup aids in web scraping and data extraction, ensuring accurate and up-to-date information.
concurrent.futures (ThreadPoolExtractor) Provides a high-level interface for asynchronously executing functions.

Source Selection

  • Reputation: We prioritized sources with established reputations within the Islamic community. These sources are recognized for their commitment to providing accurate and reliable information about Islam.

  • Scholarly Validation: Sources that have been reviewed and endorsed by reputable Islamic scholars were given preference. Scholarly validation adds a layer of authenticity to the information they provide.

  • Community Trust: We considered the trust and confidence that the Islamic community places in these sources. Feedback and recommendations from the community played a crucial role in our selection process.

  • Historical Significance: Sources with a history of preserving and disseminating Islamic knowledge over time were considered valuable. Their historical significance indicates a commitment to accuracy.

Data Collection

  • Structured Data: The project excels in collecting and structuring data from various sources. This structured data is easily accessible, facilitating accurate responses to user queries. If the data sources or structures evolve over time, adapting the code to accommodate these changes is straightforward, thanks to the meticulous data handling approach.

  • Parallel Processing: Parallel processing techniques are employed skillfully to efficiently extract and process large datasets, such as Quranic content and Hadiths. This design decision ensures that the project can scale to handle even larger datasets in the future, without major code overhauls.

  • Data Integrity: The project is designed to ensure data integrity. For example, the Quranic content is extracted from multiple sources and cross-checked to ensure accuracy and consistency. This approach guarantees that the chatbot provides reliable and trustworthy information.

  • Data Storage: The project uses JSON files to store data. This choice enhances data integrity and portability. Should there be a need to change data storage formats or structures, the transition process remains straightforward.

Data Processing

  • Data Preprocessing: The project employs a variety of data preprocessing techniques to ensure that the data is clean and ready for use. For example, the Quranic content is preprocessed to remove unnecessary characters and whitespace. This approach guarantees that the chatbot provides accurate and reliable information.

Model Training

  • Conversational AI Framework Selection: The model training phase will leverage advanced conversational AI technology. Currently still exploring various options, including Rasa, an open-source conversational AI framework, and other cutting-edge frameworks like those developed by OpenAI. My goal is to select the most suitable framework that aligns with the complexity and unique requirements for this project.

  • NOTE: Data collection still in progress. Model training will be start after majority of data is successfully collected and structured.

Requirements

pip install -r requirements.txt

Project Structure

IslamAI
├── islamic_data
│   ├── docxs
│   │   ├── *.docx
│   ├── htmls
│   │   ├── *.html
│   ├── jsons
│   │   ├── *.json
│   ├── pdfs
│   │   ├── *.pdf
│   └── SOURCES.md
├── blueprints
│   ├── *blueprint.py
│   ├── data_loader.py
├── logo
│   ├── logo.png
├── ai_data.py
├── ai_model.py
├── database.ini
├── README.md
├── LICENSE.md
└── requirements.txt

Progress

  • Data Collection
    • Data Processing
  • RESTful API Data Endpoints
    • Quran
    • Hadiths
    • Other
  • Model Training
  • Model Deployment
  • ChatBot Interface
  • Testing
  • Deployment

Contributing

  • There is another project, much similar to IslamAI, that shares my passion for advancing Islamic knowledge through AI technology. The founder, Ali, maintains an active Discord channel where contributors collaborate, share ideas, and support each other's initiatives. This collaborative spirit allows us to collectively improve AI-driven Islamic knowledge platforms for the benefit of users worldwide.

  • Feel free to join Ali Zahid Raja's Discord channel to participate in this collaborative effort and contribute to the development of cutting-edge solutions for Islamic education and information dissemination. Together, we can make a substantial impact on the way people access and learn about Islam.


Ali Zahid Raja's Links

Platform Link
Website Portfolio
Discord Islam & AI
GitHub QURAN-NLP
Project IslamAndAI

Releases

No releases published

Packages

No packages published