Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/soheil-mp/plant-health-detector
https://github.com/soheil-mp/plant-health-detector
Last synced: 24 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/soheil-mp/plant-health-detector
- Owner: soheil-mp
- License: mit
- Created: 2024-12-06T12:28:53.000Z (28 days ago)
- Default Branch: master
- Last Pushed: 2024-12-06T16:22:58.000Z (28 days ago)
- Last Synced: 2024-12-06T17:29:49.526Z (27 days ago)
- Language: Python
- Size: 10.7 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Plant Health Detector 🌿
A deep learning-based plant disease detection system that helps identify plant diseases from leaf images.
[![Python](https://img.shields.io/badge/Python-3.8+-3776AB?style=for-the-badge&logo=python&logoColor=white)](https://www.python.org)
[![TensorFlow](https://img.shields.io/badge/TensorFlow-2.0+-FF6F00?style=for-the-badge&logo=tensorflow&logoColor=white)](https://www.tensorflow.org)
[![OpenCV](https://img.shields.io/badge/OpenCV-4.0+-5C3EE8?style=for-the-badge&logo=opencv&logoColor=white)](https://opencv.org)
[![License](https://img.shields.io/badge/License-MIT-green.svg?style=for-the-badge)](LICENSE)## Features
- 🔍 Real-time plant disease detection
- 🌿 Support for multiple plant species
- 📊 Confidence scores for predictions
- 💡 Treatment recommendations
- 🚀 Easy-to-use command-line interface## Project Structure
```
Plant-Health-Detector/
├── data/ # Data directory
│ ├── raw/ # Raw training data
│ └── processed/ # Processed data
├── docs/ # Documentation
├── models/ # Trained models
├─�� src/ # Source code
│ ├── plant_detector/
│ ├── train.py
│ └── predict.py
└── tests/ # Test files
```## Installation
### Prerequisites
- Python 3.8 or higher
- pip (Python package manager)
- 2GB+ free disk space### Quick Start
1. Clone the repository:
```bash
git clone https://github.com/yourusername/Plant-Health-Detector.git
cd Plant-Health-Detector
```2. Create and activate a virtual environment:
```bash
# On Windows
python -m venv venv
venv\Scripts\activate# On Unix/MacOS
python -m venv venv
source venv/bin/activate
```3. Install the package:
```bash
pip install -e .
```## Usage
### Training a Model
To train a new model:
```bash
train-plant-detector --data_dir data/raw/plant_dataset/Plant_leave_diseases_dataset_without_augmentation --epochs 50
```Options:
- `--data_dir`: Directory containing training data (with subdirectories for each class)
- `--epochs`: Number of training epochs (default: 50)
- `--batch_size`: Batch size for training (default: 32)
- `--output_dir`: Directory to save models (default: models/)
- `--workers`: Number of data loading workers (default: 4)### Making Predictions
For a single image:
```bash
predict-plant-disease --model_path models/final_model.keras --image path/to/image.jpg
```For batch processing:
```bash
predict-plant-disease --model_path models/final_model.keras --input_dir path/to/images --output_dir results
```Options:
- `--model_path`: Path to the trained model (.keras file)
- `--image`: Path to single image for prediction
- `--input_dir`: Directory containing images for batch prediction
- `--output_dir`: Directory to save results (default: results/)The prediction output includes:
- Disease name
- Confidence score
- Treatment recommendations## Model Architecture
The system uses a ResNet50-based architecture with the following modifications:
- Pre-trained weights from ImageNet
- Additional dense layers for classification
- Dropout for regularization
- Data augmentation during training## Development
### Running Tests
```bash
python -m unittest discover tests
```### Contributing
1. Fork the repository
2. Create a feature branch
3. Commit your changes
4. Push to the branch
5. Create a Pull Request## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
## Acknowledgments
- ResNet architecture by Microsoft Research
- Plant Village Dataset
- TensorFlow and OpenCV communities