This project is an AI-based system designed to protect visual privacy by anonymizing faces and obfuscating sensitive textual information (PII) in both images and videos. The system is designed to be robust and efficient for real-time applications.
-
Face Detection and Anonymization
- Detects faces in images and video frames using a deep learning-based model.
- Provides options to anonymize detected faces through blurring or pixelation.
-
Sensitive Text Detection and Obfuscation
- Utilizes Optical Character Recognition (OCR) to detect text within images.
- Leverages Natural Language Processing (NLP) techniques to identify sensitive information such as Personally Identifiable Information (PII).
- Obfuscates sensitive text using methods like drawing black rectangles or applying blurring.
-
Real-Time Processing
- Capable of processing live video feeds to anonymize faces and obfuscate sensitive text in real-time.
-
Confidence Threshold Adjustment
- Allows users to adjust the confidence threshold for face detection, which controls the sensitivity and effectiveness of the anonymization process.
-
User-Friendly Interface
- Provides a simple Graphical User Interface (GUI) that enables users to:
- Select images for processing
- Start and stop live video feeds
- Choose between different anonymization methods (e.g., blurring, pixelation)
- View the anonymized output for verification
- Provides a simple Graphical User Interface (GUI) that enables users to:
-
Clone the repository:
git clone https://github.com/yourusername/visual-privacy-protection.git cd visual-privacy-protection
-
Install dependencies:
This project uses Python and a set of specific libraries. Install the dependencies with the following command:
pip install -r requirements.txt
- Run the application:
You can start the application with:
python imageredactionwithblurringandpixelation.py
- Load images or video streams for processing.
-
OCR Detection:
- Uses
EasyOCR
to extract text from images.
- Uses
-
Text Analysis:
- Uses
spaCy
to analyze the extracted text and identify PII (Personally Identifiable Information).
- Uses
-
Face Detection:
- Utilizes OpenCV’s deep learning-based face detector to find faces in images and videos.
-
Anonymization:
- Applies chosen anonymization techniques (blurring or pixelation) to faces and PII in the media.
- Save or display the anonymized images or video streams.
- Programming Language: Python
- Framework: Tkinter for GUI
- EasyOCR: For text detection and extraction from images.
- spaCy: For text analysis and PII identification.
- OpenCV: For face detection and image processing (blurring and pixelation).
- PIL (Pillow): For image handling and manipulation.
- NumPy: For numerical operations and handling image data.
-
prototxt
File:
This is a configuration file used by the Caffe deep learning framework to define the model architecture. The file specifies the structure of the neural network without the learned weights. It outlines details such as:- Number and type of layers (e.g., convolutional, pooling layers)
- Connections between layers
- Other architectural parameters crucial to the design of the model.
-
.caffemodel
File:
This file contains the pre-trained weights for the face detection model. These weights were learned during training on a large dataset and are essential for the model to perform tasks like face detection effectively. By loading these weights, the model can generalize well to new images and videos, allowing for efficient real-time face detection.
- VSCode, PyCharm: As the integrated development environment (IDE) for coding and testing.
Here’s an example of how the system works on blurring a sample image:
Original Image:
Anonymized Image:
For video: [option= blurring]
[option= pixelation]
-
L. Rakhmawati, Wirawan and Suwadi, "Image Privacy Protection Techniques: A Survey,"
TENCON 2018 - 2018 IEEE Region 10 Conference, Jeju, Korea (South), 2018, pp. 0076-0080, doi: 10.1109/TENCON.2018.8650339 -
Senior, A.W., Pankanti, S. (2011). Privacy Protection and Face Recognition.
In: Li, S., Jain, A. (eds) Handbook of Face Recognition. Springer, London.
https://doi.org/10.1007/978-0-85729-932-1_27 -
Ren, Zhongzheng & Lee, Yong & Ryoo, Michael. (2018). Learning to Anonymize Faces for Privacy Preserving Action Detection.
-
Hukkelås, H., Mester, R., Lindseth, F. (2019). DeepPrivacy: A Generative Adversarial Network for Face Anonymization.
In: Bebis, G., et al. Advances in Visual Computing. ISVC 2019. Lecture Notes in Computer Science(), vol 11844. Springer, Cham.
https://doi.org/10.1007/978-3-030-33720-9_44 -
Padilla-Lopez, J. R., Chaaraoui, A. A., & Florez-Revuelta, F. Visual Privacy Protection Methods: A Survey.
Department of Computer Technology, University of Alicante, P.O. Box 99, E-03080 Alicante, Spain, and Faculty of Science, Engineering and Computing, Kingston University. -
Li, Yiming & Liu, Peidong & Jiang, Yong & Xia, Shu-Tao. (2021). Visual Privacy Protection via Mapping Distortion.
10.1109/ICASSP39728.2021.9414149. -
GitHub Repo: Blur and anonymize faces with OpenCV and Python
We welcome contributions! Feel free to submit a pull request or open an issue if you encounter any bugs or have feature suggestions.
This project is licensed under the MIT License.