EdierA commited on
Commit
f2eff9d
·
verified ·
1 Parent(s): 2292ca5

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +44 -47
app.py CHANGED
@@ -1,47 +1,44 @@
1
- from transformers import DetrImageProcessor, DetrForObjectDetection
2
- import torch
3
- from PIL import Image
4
- import gradio as gr
5
-
6
- # Cargar el procesador y el modelo
7
- processor = DetrImageProcessor.from_pretrained("facebook/detr-resnet-50")
8
- model = DetrForObjectDetection.from_pretrained("facebook/detr-resnet-50")
9
-
10
- # Función para procesar la imagen y detectar objetos
11
- def detect_objects(image):
12
- inputs = processor(images=image, return_tensors="pt")
13
- with torch.no_grad():
14
- outputs = model(**inputs)
15
-
16
- # Ajustar tamaño de salida al de la imagen
17
- target_sizes = torch.tensor([image.size[::-1]])
18
- results = processor.post_process_object_detection(
19
- outputs, target_sizes=target_sizes, threshold=0.9
20
- )[0]
21
-
22
- detected_objects = []
23
- for score, label, box in zip(results["scores"], results["labels"], results["boxes"]):
24
- label_name = model.config.id2label[label.item()]
25
- detected_objects.append(
26
- f"Objeto: {label_name}, Score: {score:.2f}, Box: {box.tolist()}"
27
- )
28
-
29
- return "\n".join(detected_objects)
30
-
31
- # Crear interfaz con Gradio
32
- def create_interface():
33
- interface = gr.Interface(
34
- fn=detect_objects,
35
- inputs=gr.Image(type="pil"),
36
- outputs=gr.Textbox(),
37
- live=True,
38
- title="Detección de Objetos con Transformers",
39
- description="Sube una imagen y descubre qué objetos puede detectar."
40
- )
41
- interface.launch()
42
-
43
- if __name__ == "__main__":
44
- create_interface()
45
-
46
-
47
-
 
1
+ from transformers import DetrImageProcessor, DetrForObjectDetection
2
+ import torch
3
+ from PIL import Image
4
+ import gradio as gr
5
+
6
+ # Cargar el procesador y el modelo
7
+ processor = DetrImageProcessor.from_pretrained("facebook/detr-resnet-50")
8
+ model = DetrForObjectDetection.from_pretrained("facebook/detr-resnet-50")
9
+
10
+ # Función para procesar la imagen y detectar objetos
11
+ def detect_objects(image, threshold=0.9):
12
+ inputs = processor(images=image, return_tensors="pt")
13
+ with torch.no_grad():
14
+ outputs = model(**inputs)
15
+
16
+ # Ajustar tamaño de salida al de la imagen
17
+ target_sizes = torch.tensor([image.size[::-1]])
18
+ results = processor.post_process_object_detection(
19
+ outputs, target_sizes=target_sizes, threshold=threshold
20
+ )[0]
21
+
22
+ detected_objects = []
23
+ for score, label, box in zip(results["scores"], results["labels"], results["boxes"]):
24
+ label_name = model.config.id2label[label.item()]
25
+ detected_objects.append(
26
+ f"Objeto: {label_name}, Score: {score:.2f}, Box: { [round(v,2) for v in box.tolist()] }"
27
+ )
28
+
29
+ return "\n".join(detected_objects)
30
+
31
+ # Interfaz con la API nueva de Gradio
32
+ demo = gr.Interface(
33
+ fn=detect_objects,
34
+ inputs=[gr.Image(type="pil", label="Imagen"), gr.Slider(0, 1, value=0.9, step=0.05, label="Umbral")],
35
+ outputs=gr.Textbox(label="Detecciones"),
36
+ title="Detección de Objetos con Transformers (DETR)",
37
+ description="Sube una imagen y descubre qué objetos puede detectar."
38
+ )
39
+
40
+ if __name__ == "__main__":
41
+ demo.launch()
42
+
43
+
44
+