Alias: YOU FOCUS YOUR WALK
- Group Members: Mai Jiajun DC127853, Huang Yanzhen DC126732
- Supervisor: Prof. Bob Zhang
- A Windows computer with a standalone GPU from NVIDIA.
- Reference GPU: NVIDIA GeForce RTX 4060 Laptop GPU (Ours)
- It's recommended to use a newer GPU.
- Used for both training and application of the two models.
 
This repository uses the following project licensed under different licenses. The full texts are available in the LICENSES directory.
| Component | Type | LICENSE File (Local) | Source (with License) | 
|---|---|---|---|
| Open-MMLab | Apache-2.0 | LICENSES/Apache_Open-MMLab/LICENSE.txt | https://github.com/open-mmlab | 
| ultralytics | AGPL-3.0 | LICENSES/AGPL_ultralytics/LICENSE.txt | https://github.com/ultralytics/ultralytics | 
More credits and copyrights info about ultralytics is in main.py.
- Posture Dataset:
- Raw Videos: https://drive.google.com/drive/folders/1EfuFSjnZtJW_DKmfCdUalr19KOpqjrVN?usp=drive_link
- Annotated .npyFiles: data/train/3dnpy
- Annotation Function: step01_annotate_image_mmpose/annotate_image.py
 
- Cell Phone Dataset:
- Raw Videos: https://drive.google.com/drive/u/0/folders/1_RhlYpDtS8KXBRBiPI-0_vmgFCnJcXQo
- Roboflow Project: https://universe.roboflow.com/victor-workspace-owmoa/pedestrian-cell-phone-detection
- Annotation Function: step03_yolo_phone_detection/yolo11_data_gather.py
 
A quick start: The entry of this project is main.py. Come back and run this file when you are done configuring.
Please make sure that Anaconda is installed.
Please make sure that you are under the conda environment. If you are not, please do the following in the anaconda prompt terminal to create one.
conda create --prefix <PATH_TO_YOUR_VENV_ROOT_FOLDER> python=3.8 -yconda activate <PATH_TO_YOUR_VENV_ROOT_FOLDER>cd <PATH_TO_YOUR_CLONED_PROJECT>We have inspected that mmcv does not work with pytorch with a higher version. Under a higher torch version, cuda:0
is not available, eventhough torch.cuda.is_available() returns True.
According to this issue: open-mmlab/mmdetection#11530 (comment),
mmcv only works with pytorch with version 2.1.0. And it has been confirmed by us. Please run:
conda install pytorch==2.1.0 torchvision==0.16.0 torchaudio==2.1.0 pytorch-cuda=11.8 -c pytorch -c nvidiaYou should have these installed:
| Package | Build | 
|---|---|
| pytorch-2.1.0 | py3.8_cuda11.8_cudnn8_0 | 
| torchaudio-2.1.0 | py38_cu118 | 
| torchvision-0.16.0 | py38_cu118 | 
After activating your conda environment, pleas install openmim package manager.
<PATH_TO_YOUR_VIRTUAL_ENVIRONMENT>/Scripts/pip.exe install -U openmimThe absolute path to your pip executable is preferred to ensure that you have used the correct pip
executable, i.e., the executable stored in the Scripts/ directory in the virtual environment directory.
Using a wrong instance of pip will cause your packages to be downloaded to the wrong environment.
Notice that the
Scripts/pip.exeis windows-only. For mac, it's/bin/pip, just for your reference.
There are four MM packages you need to install. Please install the EXACT version listed in the form below. This is the best solution we could get to prevent package conflicts. For more information, please visit https://mmcv.readthedocs.io/en/latest/get_started/installation.html.
| Package | Version | Source | 
|---|---|---|
| mmcv | 2.1.0 | https://github.com/open-mmlab/mmcv | 
| mmdet | 3.2.0 | https://github.com/open-mmlab/mmdetection | 
| mmengine | 0.10.4 | https://github.com/open-mmlab/mmengine | 
| mmpose | 1.3.2 | https://github.com/open-mmlab/mmpose | 
Run this command to install MM related packages:
mim install "mmcv==2.1.0" "mmdet==3.2.0" "mmengine==0.10.4" "mmpose==1.3.2"If you encounter an error while installing mmcv like this:
error: Microsoft Visual C++ 14.0 or greater is required. Get it with "Microsoft C++ Build Tools": https://visualstudio.microsoft.com/visual-cpp-build-tools/You are missing a C++ requirement. Please download C++ build tools using the given link, and configure a C++ environment. Please inspect this link for more details about C++ environment configuration: https://blog.csdn.net/xiao_yan_/article/details/119538602.
For both boundary detection and pose estimation, there are two kinds of files: Config files and Checkpoint files.
Please download all of them by clicking these links:
.py Files (No longer need manual downloading)
Note
You can skip this step, since the config .py files have been re-included into the GitHub repo,
in model_config/configs.
However, you can still choose to download them from URLs listed below.
- config files (.py):- det config (boundary detection): https://github.com/open-mmlab/mmpose/blob/dev-1.x/projects/rtmpose/rtmdet/person/rtmdet_nano_320-8xb32_coco-person.py
- pose config (pose estimation): https://github.com/open-mmlab/mmpose/blob/dev-1.x/projects/rtmpose/rtmpose/body_2d_keypoint/rtmpose-t_8xb256-420e_coco-256x192.py
 
.pth Files
Note
The below downloading method is too slow in efficiency. We have put all the available configurations in our
Google Drive. Link: https://drive.google.com/drive/folders/1Oe6Z2GqkqDfGxmH2_x6f2wKSK0HIoEm9.
Please download ALL of them (may contain redundant ones) and put them in model_config/checkpoints/, where the
contents in this folder are ignored. If you prefer to download from source, please refer to the links below.
- checkpoint files (.pth):
After downloading from the browser, please move them into model_config/checkpoints/.
Run the following command to install regular required packages.
For windows:
<PATH_TO_YOUR_VIRTUAL_ENVIRONMENT>/Scripts/pip.exe install -r requirements.txtTry to run main.py. If an error regarding opencv-python occurred, uninstall it and re-install it again.
Roboflow will somehow install
opencv-python-headerless, overwriting theopencv-pythonpackage. If you encounter errors regardingopencv-python, just uninstall and re-installopencv-python.
<PATH_TO_YOUR_VIRTUAL_ENVIRONMENT>/Scripts/pip.exe uninstall opencv-python<PATH_TO_YOUR_VIRTUAL_ENVIRONMENT>/Scripts/pip.exe install opencv-python- Get From:
- Trained models & training logs are stored under Google Drive.
- Model referred in the project report: posture_mmpose_vgg3d_0508-132048.pth.
 
- Move To:
Moreover, if you want to explore previously trainned posture recognition models, please go to main.py at around line 282, and replace the file name to the model you want to use.
    ...
    # Posture classifier
    model_state = torch.load('step02_train_model_cnn/archived_models/posture_mmpose_vgg3d_20250508-132048.pth',
                             map_location=global_device)
    ...- 
YOLO models are contained in this GitHub repository. Find it here. It is automatically used when you run the main.py main file. 
- 
Feel free to explore previous trained models stored in step03_yolo_phone_detection/archived_onnx. You can go to around line 292 of main.py and change the name to the one you want to use. 
    # YOLO object detection model
    if user_config["use_trained_yolo"]:
        yolo_path = "step03_yolo_phone_detection/archived_onnx/best.pt"
    else:
        yolo_path = "step03_yolo_phone_detection/non_tuned/yolo11n.pt"
    phone_detector = YOLO(yolo_path)P.S. The models are not actually stored in
.onnxformat. It's an inherited name during project construction.
- Please unzip the file step03_yolo_phone_detection/pvalue.py.zip for system integrity. It is zipped to protect the API key from being recorded into the commit history.
Option 1. Run via command.
Direct to the root of the inference backend project folder (where main.py is stored).
cd <PATH_TO_YOUR_CLONED_PROJECT>Run the correct python executable on the main file main.py.
<PATH_TO_YOUR_VIRTUAL_ENVIRONMENT>/python.exe -m mainDisambiguation:
-mmeans to run as a package, so it's specified asmaininstead ofmain.py
Option 2. Run via IDE
Run by click the run button on supported IDEs (e.g., VSCode, PyCharm, etc.). Please make sure the
IDE reads the virtual environment correspondingly.
When you run the project, you will encounter a pop-up panel that allows you to choose some parameters.
The meaning and default values of these parameters are listed below.
| Parameter | Default | Type | Description | 
|---|---|---|---|
| Video Source | 0 | int | string | The source of video monitoring. Could be digit for camera index or string for video paths. | 
| Push video to remote | true | bool | Whether to push the video feed to the frontend or use local OpenCV window. | 
| Face announce interval | 5 | int | The time length of the cool-down window of face announcing. | 
| Posture Confidence | 0.8 | float | The confidence threshold for reporting an engagement behavior. | 
| Phone Confidence | 0.65 | float | The confidence threshold for cell phone detection. | 
| Spareness | 0.45 | float | The degree to which the secondary hand is spared when no cell phone detected in the primary hand. | 
| Use MMPose visualizer | false | bool | To use the MMPose visualizer or not. | 
| Use Self-trained YOLO model | true | bool | To use a self-trained YOLO model instead of the official one. | 
| Generate report | false | bool | To generate a real-time performance graph of mean frame computation time. | 

