File size: 3,707 Bytes
497d51e
 
 
 
 
 
 
 
5e15e0b
497d51e
ca470fe
 
 
 
 
 
 
 
 
 
 
 
 
 
 
e95d9e4
ca470fe
b1c79c4
ca470fe
e95d9e4
ca470fe
 
e95d9e4
b70b1c9
 
ca470fe
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
e95d9e4
b1c79c4
ca470fe
b1c79c4
e95d9e4
ca470fe
e95d9e4
ca470fe
e95d9e4
ca470fe
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
e95d9e4
ca470fe
 
 
 
 
 
e95d9e4
ca470fe
e95d9e4
ca470fe
e95d9e4
ca470fe
e95d9e4
ca470fe
e95d9e4
ca470fe
e95d9e4
b70b1c9
b1c79c4
ca470fe
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
---
license: mit
title: Construction_Snag_Tool_Llama_3.2_Vision
sdk: gradio
emoji: 
colorFrom: indigo
colorTo: blue
short_description: powerful tool built using Python, Gradio, and Groq
sdk_version: 5.1.0
---
# Construction Site Snag Detector

## Overview

The Construction Site Snag Detector is a powerful tool built using Python, Gradio, and the Groq platform. It leverages AI to automatically detect defects, unfinished work, and quality issues in construction site images and videos. This solution aims to enhance quality control and project management by providing real-time insights and expert analysis.

## Features

- **Multi-file Support**: Upload multiple images and videos for batch processing.
- **Real-time Analysis**: Get immediate results for uploaded files without waiting for long processing times.
- **Expert Insights**: Detailed reports generated by an AI assistant specializing in construction site snag detection.
- **Interactive Chat**: Engage in real-time discussions with the AI assistant to clarify findings and ask follow-up questions.
- **Customizable Reports**: Download comprehensive reports for record-keeping and future reference.

## Getting Started

### Prerequisites

Before you begin, ensure you have the following installed:

- Python 3.8 or higher
- Required Python packages (`requirements.txt` provided below)

### Installation

1. Clone the repository:
   ```bash
   git clone https://github.com/your-repo/construction-site-snag-detector.git
   cd construction-site-snag-detector
   ```

2. Install dependencies:
   ```bash
   pip install -r requirements.txt
   ```

3. Set the `GROQ_API_KEY` environment variable:
   ```bash
   export GROQ_API_KEY=your_groq_api_key_here
   ```

### Running the Application

To start the application, simply run the main script:

```bash
python app.py
```

This will launch a Gradio web interface where you can interact with the Construction Site Snag Detector.

## Usage

1. **Upload Files**:
   - Go to the "Upload Files" section and select one or more images or videos of your construction site.

2. **Detect Snags**:
   - Click the "Detect Snags" button to initiate the analysis.

3. **View Results**:
   - The analysis results will be displayed in the chat area. Each file's results will be shown separately.

4. **Engage with the AI Assistant**:
   - Ask questions about the detected snags or request additional information directly within the chat interface.

5. **Download Report**:
   - Once you're satisfied with the analysis, click the "Download Report" button to save a comprehensive report for your records.

## Technical Details

### Architecture

- **Frontend**: Built using Gradio for a user-friendly interface.
- **Backend**: Utilizes Python for file handling, image processing, and AI analysis.
- **AI Integration**: Leverages the Groq platform for AI inference, enabling real-time analysis.

### Dependencies

The project relies on several libraries, including:

- `gradio`: For creating the interactive web interface.
- `PIL`, `opencv-python`, `numpy`: For image processing.
- `base64`: For encoding images.
- `logging`: For logging errors and debugging information.
- `tempfile`: For generating temporary files.
- `groq`: For interacting with the Groq platform.

These dependencies are managed via `requirements.txt`.

## Contributing

Contributions are welcome! Feel free to submit pull requests, bug reports, or feature suggestions.

## License

This project is licensed under the MIT License. See the `LICENSE` file for details.

---

**Note:** Ensure you have the necessary permissions and comply with all relevant laws and regulations when using this tool, especially concerning data privacy and security.