Research
Security News
Malicious npm Package Targets Solana Developers and Hijacks Funds
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Face detection and recognition library that focuses on speed and ease of use. This is a stripped down version of timesler's facenet repo with some improvements notably on memory overflows. This repository is actively developed and used in production.
MTCNN is used for face detection and FaceNet is used for generating face embeddings.
Both algorithms can be used directly by copying the source file into your code base. They are single file and single model implementations with no interdependence.
Alternatively you can install with pip3 install dface
command. Weights will be downloaded from github automatically in the first run.
This implementation takes a list of frames and returns a list of detected faces. The input and output lists always have the same size. If no face is detected for a frame, the corresponding list element is returned None
, otherwise it's a tuple of three elements; (bounding_boxes, probabilities, landmarks)
.
mtcnn = MTCNN('cuda')
...
result = mtcnn.detect(frames)
for res in result:
if res is None:
continue
boxes, probs, lands = res
Bounding boxes is a list of four coordinates (x1, y1, x2, y2)
for each face detected in the frame. Probabilities is a list of confidence scores between 0 and 1 for each face. Landmarks is a list of facial landmark points. There are five points for each face.
The implementation is at mtcnn.py
This implementation takes a list of cropped faces and returns a list of face embedding vector of 512 dimensions. These embeddings then can be used for detecting facial similarities, clustering identities and so on.
facenet = FaceNet('cuda')
...
embeds = facenet.embedding(faces)
The implementation is at facenet.py
Both algorithms accept model path as the second argument if you want to load models from a custom location.
The repo contains an example script that uses both MTCNN and Facenet to read a video and cluster the faces. It uses OpenCV to read video frames and DBSCAN to cluster faces.
You can run the example by simply typing: python3 example.py video.mp4
. A directory will be created with the same name as video that contains clustered identities. The following is an example image.
The implementation is at example.py
FAQs
Face detection and recognition library that focuses on speed and ease of use.
We found that dface demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Security News
Research
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.