# yolov5-smoke-detection-python **Repository Path**: mumuU1156/yolov5-smoke-detection-python ## Basic Information - **Project Name**: yolov5-smoke-detection-python - **Description**: A Python implementation of Yolov5 to detect whether peaple smoking in Jetson Xavier nx and Jetson nano - **Primary Language**: Python - **License**: MIT - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 11 - **Forks**: 4 - **Created**: 2021-11-14 - **Last Updated**: 2025-01-16 ## Categories & Tags **Categories**: cv **Tags**: None ## README # yolov5-smoke-detection-python A Python implementation of Yolov5 to detect whether peaple smoking in Jetson Xavier nx and Jetson nano In Jetson Xavier Nx, it can achieve 33 FPS. You can see video play in [BILIBILI](https://www.bilibili.com/video/BV1eY411x7k9/), or [YOUTUBE](). if you have problem in this project, you can see this [CSDN artical](https://blog.csdn.net/weixin_42264234/article/details/121325030). If you want to try to train your own model, you can see [yolov5-smoke-detection-python](https://github.com/RichardoMrMu/yolov5-smoke-detection-python). Follow the readme to get your own model. # Dataset https://pan.baidu.com/s/1vmjV1HwhcMOdUqFhKwH4Mg,提取码:pqsv ## Data This pro needs dataset like ``` ../datasets/coco128/images/im0.jpg #image ../datasets/coco128/labels/im0.txt #label ``` Download the dataset and unzip it. ```shell unzip annnotations.zip unzip images.zip ``` You can get this. ``` ├── dataset ├── annotations │ ├── mask_000001.xml │ ├── mask_000002.xml │ ├── mask_000003.xml │ | ... ├── images │ ├── mask_000001.jpg │ ├── mask_000003.jpg │ ├── mask_000003.jpg │ | ... ├── label_list.txt ├── train.txt └── valid.txt ``` You should turn xml files to txt files. You also can see [this](https://github.com/ultralytics/yolov5/wiki/Train-Custom-Data ). Open `script/sw2yolo.py`, Change `save_path` to your own save path,`root` as your data path, and `list_file` as `val_list.txt` and `train_list.txt` path. ```Python list_file = "./val_list.txt" xmls_path,imgs_path = get_file_path(list_file) # 将train_list中的xml 转成 txt, img放到img中 save_path = './data/yolodata/smoke/cocolike/val/' root = "./data/yolodata/smoke/" train_img_root = root ``` Then you need `script/yolov5-split-label-img.py` to split img and txt file. ```shell mkdir images mkdir lables mv ./train/images/* ./images/train mv ./train/labels/* ./labels/train mv ./val/iamges/* ./images/val mv ./val/lables/* ./lables/val ``` Finally You can get this. ``` ├── cocolike ├── lables │ ├── val │ ├── smoke_000001.xml | ├── ... │ ├── train │ ├── smoke_000002.xml | ├── ... │ ├── images │ ├── val │ ├── smoke_000001.jpg | ├── ... │ ├── train │ ├── smoke_000003.jpg | ├── ... ├── label_list.txt ├── train.txt └── valid.txt ``` ## Datafile `{porject}/yolov5/data/` add your own yaml files like `smoke.yaml`. ```yaml # YOLOv5 🚀 by Ultralytics, GPL-3.0 license # COCO128 dataset https://www.kaggle.com/ultralytics/coco128 (first 128 images from COCO train2017) # Example usage: python train.py --data coco128.yaml # parent # ├── yolov5 # └── datasets # └── coco128 downloads here # Train/val/test sets as 1) dir: path/to/imgs, 2) file: path/to/imgs.txt, or 3) list: [path/to/imgs1, path/to/imgs2, ..] path: /home/data/tbw_data/face-dataset/yolodata/smoke/cocolike/ # dataset root dir train: images/train # train images (relative to 'path') 128 images val: images/val # val images (relative to 'path') 128 images test: # test images (optional) # Classes nc: 1 # number of classes names: ['smoke'] # class names ``` # Train Change `{project}/train.py`'s data path as your own data yaml path. Change `batch-size ` as a suitable num. Change device if you have 2 or more gpu devices. Then ```shell python train.py ``` # Test Use `detect.py` to test. ```shell python detect.py --source ./data/yolodata/mask/cocolike/images --weights ./runs/train/exp/weights/best.pt ``` You can see `{project}/runs/detect/` has png results.