Skip to content

tedbrunell/HowsMySalute

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

HowsMySalute

This is a simple computer vision program to try to determine if someone's "salute" pose meets USMC standards. Marine Corps Order (MCO) 5060.20 covers the requirements for a proper salute.

When "SALUTE" is given, raise your right hand smartly in the most direct manner until the tip of your forefinger touches the lower part of the headdress above and slightly right of your right eye. Your fingers should be extended straight and joined with the thumb along the forefinger. You should be able to see your entire palm when looking straight ahead. Your upper arm should be parallel with the deck with the elbow in line with the body and your forearm at a 45-degree angle. Your wrist and hand should be straight, a continuation of the line made by your forearm. At the same time, if not in ranks, turn your head and eyes toward the person or colors you are saluting.

This script will track to following parts of the requirement:

  • Upper Arm is parallel to the deck
  • Forearm is at a 45 degree angle
  • Wrist and hand is a in-line with the forearm
  • Palm is visible

To prepare your system for the script, make sure python 3 is installed along with mediapipe, OpenCV, numpy flask and matplotlib. The pip program can be used for the installation.

pip install mediapipe
pip install flask
pip install matplotlib

Information about Mediapipe can be found here

For the landmarks that are used by Mediapipe, please refer to the below graphics.

Pose:

pose_landmarks

Hands:

hand_landmarks

To run the code, use the command

python app.py

If you want to build this as a Podman container, a Dockerfile is included. Run the following commands to build and run the container:

$ podman build --layers=false -t howsmysalute .
$ podman run -d --name howsmysalute --security-opt label=disable --device /dev/video0 -p 8080:8080 localhost/howsmysalute

Note that the --security-opt label=disable option is only needed to keep SELinux from blocking access to the webcam from the container.

The SELinux Boolean container_use_devices may have to be set to a value of '1' to allow the container to access the camera.

Open a browser to http://localhost:8080 to see the mirrored image of yourself. See if you can hold the salute for 3-5 seconds.

If you are going to access this over the network, make sure that port 8080 is open on the firewall.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •