news 2026/5/23 20:02:11

【AI】一种基于YOLOv8/v11目标检测模型之检测人体的脚本及服务1️⃣【Ubuntu 22.04】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【AI】一种基于YOLOv8/v11目标检测模型之检测人体的脚本及服务1️⃣【Ubuntu 22.04】

本文介绍了两套基于YOLOv8模型的活体检测服务系统。


1️⃣:一种针对图片YOLO活体检测服务【端口:5000】

  • ① 脚本
import os import json import threading from flask import Flask, request, jsonify from ultralytics import YOLO app = Flask(__name__) class YOLOService: def __init__(self): self.model = None self.lock = threading.Lock() self.load_model() def load_model(self): """加载能检测人和车的模型""" model_path = "/opt/yolov11/models/yolov8n.pt" print(f"【重要】加载新模型: {model_path}") print(f"此模型可检测80类目标,包括人和车") try: if os.path.exists(model_path): self.model = YOLO(model_path) # 打印模型能识别的类别 if hasattr(self.model, 'names'): print(f"模型可识别类别: {self.model.names}") # 找到人和车的ID (COCO数据集中: 0=person, 2=car) print(f"-> 人的类别ID: 0 (person)") print(f"-> 车的类别ID: 2 (car)") print("✅ 模型加载成功!") else: print(f"❌ 错误: 模型文件不存在 {model_path}") print("请运行: cd /opt/yolov11/models && wget -O yolov8n.pt https://github.com/ultralytics/assets/releases/download/v8.1.0/yolov8n.pt") self.model = None except Exception as e: print(f"❌ 模型加载失败: {e}") self.model = None def predict_image(self, image_path): """执行推理,只返回人和车""" if self.model is None: return {"error": "Model not loaded", "success": False} try: with self.lock: # 执行推理 results = self.model(image_path, verbose=False) # 提取检测结果 all_detections = [] person_count = 0 car_count = 0 for result in results: for box in result.boxes: cls_id = int(box.cls) conf = float(box.conf) # 只保留人和车 (COCO数据集中: 0=person, 2=car) if cls_id in [0, 2]: class_name = "person" if cls_id == 0 else "car" if cls_id == 0: person_count += 1 else: car_count += 1 all_detections.append({ "class": cls_id, "class_name": class_name, "confidence": conf, "bbox": box.xyxy[0].tolist() # [x1, y1, x2, y2] }) return { "success": True, "detections": all_detections, "statistics": { "total_objects": len(all_detections), "person_count": person_count, "car_count": car_count }, "image_size": result.orig_shape } except Exception as e: return {"error": str(e), "success": False} service = YOLOService() @app.route('/health', methods=['GET']) def health_check(): model_status = "loaded" if service.model is not None else "not loaded" return jsonify({ "status": "healthy", "model_loaded": service.model is not None, "model_name": "yolov8n.pt", "model_path": "/opt/yolov11/models/yolov8n.pt", "detection_classes": "person (人), car (车)" }) @app.route('/predict', methods=['POST']) def predict(): """接收图片路径进行预测""" data = request.json if not data or 'image_path' not in data: return jsonify({"error": "Missing image_path parameter", "success": False}), 400 image_path = data['image_path'] # 验证文件是否存在 if not os.path.exists(image_path): return jsonify({"error": f"File not found: {image_path}", "success": False}), 404 # 执行预测 result = service.predict_image(image_path) return jsonify(result) @app.route('/predict/url', methods=['POST']) def predict_url(): """通过URL推理""" data = request.json if not data or 'image_url' not in data: return jsonify({"error": "Missing image_url parameter", "success": False}), 400 image_url = data['image_url'] result = service.predict_image(image_url) return jsonify(result) if __name__ == '__main__': port = 5000 print(f"✅ YOLO活体检测服务启动!") print(f" 端口: {port}") print(f" 模型: yolov8n.pt (专检测人和车)") print(f" 访问: http://localhost:{port}/health") app.run(host='0.0.0.0', port=port, threaded=True, debug=False)
  • ② 服务
[Unit] Description=YOLOv11 CPU Inference Service After=network.target [Service] Type=simple User=zst Group=zst WorkingDirectory=/opt/yolov11 Environment="PATH=/home/zst/yolov11_venv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" ExecStart=/home/zst/yolov11_venv/bin/python /opt/yolov11/api/inference_service.py Restart=on-failure RestartSec=5 StandardOutput=journal StandardError=journal SyslogIdentifier=yolov11-service [Install] WantedBy=multi-user.target

2️⃣:一种针对视频YOLO活体检测服务【端口:5001】【以下任选一种脚本】

  • ① 脚本
import os import cv2 import threading import time import json import traceback from flask import Flask, request, jsonify from ultralytics import YOLO app = Flask(__name__) class VideoDetectionService: def __init__(self): self.model = None self.lock = threading.Lock() self.load_model() def load_model(self): """加载正确的模型 - yolov8n.pt""" # 【重要】使用正确的模型路径 model_path = "/opt/yolov11/models/yolov8n.pt" print(f"【视频服务】加载模型: {model_path}") # 检查文件是否存在 if not os.path.exists(model_path): print(f"【视频服务】❌ 错误: 模型文件不存在!") print(f"请运行: wget -O {model_path} https://github.com/ultralytics/assets/releases/download/v8.1.0/yolov8n.pt") self.model = None return try: self.model = YOLO(model_path) print(f"【视频服务】✅ 模型加载成功!") print(f"【视频服务】模型信息: {len(self.model.names)}个类别") # 验证模型能检测人和车 if hasattr(self.model, 'names'): print(f"【视频服务】人(person): ID 0") print(f"【视频服务】车(car): ID 2")
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/21 23:34:07

Kotaemon能否用于心理健康自助?资源推荐而非诊疗

Kotaemon能否用于心理健康自助?资源推荐而非诊疗 在焦虑情绪日益普遍、心理服务资源却严重不足的今天,一个现实问题摆在面前:如何让那些暂时无法接触到专业咨询的人,也能获得及时、可靠的心理支持? AI对话系统似乎提…

作者头像 李华
网站建设 2026/5/21 0:55:08

环境配置错误

在配置环境的时候,你会遇到千奇百怪的各种错误。沉静下来,耐心一个一个解决。多跟ai交互,把报错历程做成一个思维导图,防止自己迷路,因为极有可能在解决一个报错的过程中又报错,不断循环嵌套,就…

作者头像 李华
网站建设 2026/5/22 10:12:09

Java反射的作用与应用场景

Java反射&#xff08;Reflection&#xff09;是Java语言提供的一种强大机制&#xff0c;允许程序在运行时动态地检查、访问和修改类、对象、方法和属性&#xff0c;而无需在编译时知道这些信息。重要作用&#xff1a;1. 动态类型操作// 运行时加载类 Class<?> clazz Cl…

作者头像 李华
网站建设 2026/5/23 17:05:28

Kotaemon如何处理递归问题?层次化推理能力解析

Kotaemon如何处理递归问题&#xff1f;层次化推理能力解析 在构建企业级智能对话系统的过程中&#xff0c;一个长期存在的挑战是&#xff1a;如何让AI真正“理解”复杂问题&#xff0c;并像人类专家一样进行有条理的思考&#xff1f;尤其是在金融分析、法律咨询或医疗诊断这类…

作者头像 李华
网站建设 2026/5/23 18:56:33

Kotaemon能否用于快递物流查询?多源数据整合实践

Kotaemon能否用于快递物流查询&#xff1f;多源数据整合实践 在电商包裹每天以亿计流动的今天&#xff0c;用户早已不满足于“已发货”“运输中”这样的状态提示。他们更关心的是&#xff1a;“我的快递是不是被堵在路上了&#xff1f;”“为什么昨天显示到达北京&#xff0c;今…

作者头像 李华
网站建设 2026/5/23 19:52:11

Kotaemon如何降低Token消耗?五大优化技巧公开

Kotaemon如何降低Token消耗&#xff1f;五大优化技巧公开 在大语言模型&#xff08;LLM&#xff09;日益深入企业级应用的今天&#xff0c;一个看似不起眼却直接影响系统成本与响应效率的问题逐渐浮出水面——Token消耗。无论是智能客服、知识问答&#xff0c;还是自动化办公助…

作者头像 李华