Skip to content

The Arabic Font Recognition System classifies Arabic paragraphs into one of four fonts (0 to 3). Using image processing and ML, it extracts text features and employs a trained model for accurate classification. It aids in document analysis, font identification, and typography.

Notifications You must be signed in to change notification settings

RawanMostafa08/Arabic-Font-Recognition

 
 

Repository files navigation

Arabic Font Recognition System 🖋️📚

📙 Overview

This project is an Arabic font recognition system implemented in Python. It consists of modules for data reading, preprocessing, feature extraction, model training, testing, and accuracy evaluation. The system is designed to recognize fonts from images and provide accuracy metrics based on the trained model, achieving an impressive 99% accuracy. 🌟

Table of Contents 📑


🔧 Modules

1. 📂 readdata

  • Module for reading font images and labels from specified directories.
  • Provides functions for reading data for training and testing.

2. 🧹 preprocessing

  • Module for preprocessing raw image data.
  • Performs tasks such as resizing, normalization, and noise reduction.

3. 🔍features

  • Module for extracting features from preprocessed images.
  • Extracts relevant features for font recognition.

4. 🏋️modeltraining

  • Module for training machine learning models.
  • Utilizes extracted features to train a font recognition model.

5.🎬 main

  • Main script orchestrating the font recognition process.
  • Integrates data reading, preprocessing, feature extraction, model training, testing, and accuracy evaluation.

🚀Usage

To use the font recognition system, follow these steps:

  1. Set the path_folder variable to the directory containing the font dataset.
  2. Configure the NumberOftrainingData and NumoftestData variables according to your dataset size.
  3. Run the TrainingModule() function to train the font recognition model.
  4. Run the ReadTestData() function to load test data.
  5. Run the TestingModule() function to test the trained model and evaluate accuracy.

🗂️ Files

  • readdata.py: Contains functions for reading font image data.
  • preprocessing.py: Performs image preprocessing tasks.
  • features.py: Extracts features from preprocessed images.
  • modeltraining.py: Trains the font recognition model.
  • main.py: Main script orchestrating the font recognition process.
  • results.txt: Contains predicted labels for test data.
  • time.txt: Contains execution times for the testing phase.

🛠️ Requirements

  • Python 3.x
  • Required Python libraries: joblib, opencv-python, scipy, numpy, scikit-learn

🎯Accuracy

Our system has achieved an outstanding 99% accuracy in recognizing Arabic fonts! 🏆

Contributors


Sara Bisheer


Rawan Mostafa


Menna Mohammed


Fatma Ebrahim

About

The Arabic Font Recognition System classifies Arabic paragraphs into one of four fonts (0 to 3). Using image processing and ML, it extracts text features and employs a trained model for accurate classification. It aids in document analysis, font identification, and typography.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 97.7%
  • Python 2.3%