OpenScout utilizes Gabriel, a platform originally designed for wearable cognitive assistance applications, to stream image data to the backend server which runs several cognitive engines to evaluate each image. Currently we support object detection via Tensorflow and face recognition via OpenFace. We also support Microsoft Face Cognitive Service if you have an Azure account and have setup the cognitive service endpoint.
Copyright © 2020 Carnegie Mellon University
This is a developing project.
Unless otherwise stated in the table below, all source code and documentation are under the Apache License, Version 2.0. A copy of this license is reproduced in the LICENSE file.
Portions from the following third party sources have been modified and are included in this repository. These portions are noted in the source files and are copyright their respective authors with the licenses listed.
Project | Modified | License |
---|---|---|
cmusatyalab/openface | Yes | Apache 2.0 |
OpenScout uses Tensorflow for object detection and OpenFace for face detection/recognition. It has been tested on Ubuntu 16.04 LTS (Xenial) and Ubuntu 18.04 LTS (Bionic). The object detection cognitive engine requires an nVidia GPU.
If you wish to use Microsoft's Face Cognitive Service for face recognition, you will need to have an Azure account and setup the endpoint and API keys as described in the the above link. You will also need to reconfigure the docker-compose.yaml file. See the Launching Server section for more details.
OpenScout has an Android client that is available on the Google PlayStore. It requires an Android device running Android 7.0+ (API level 24).
The quickest way to set up an OpenScout server is to download and run our pre-built Docker container. This build supports execution on NVIDIA GPUs, Intel integrated GPUs, and execution on the CPU. All of the following steps must be executed as root. We tested these steps using Docker 19.03.
If you do not already have Docker installed, install it using the steps in this Docker install guide or use the following convenience script:
curl -fsSL get.docker.com -o get-docker.sh
sh get-docker.sh
Install docker-compose.
These notes explain how to install the driver.
If you think you may already have an NVIDIA driver installed, run nvidia-smi
. The Driver version will be listed at the top of the table that gets printed.
3. Install the NVIDIA Container Toolkit
Follow these instructions.
After installing the toolkit, ensure that the Docker daemon is prepared to use it by adding the following to /etc/docker/daemon.json
:
{
"runtimes": {
"nvidia": {
"path": "/usr/bin/nvidia-container-runtime",
"runtimeArgs": []
}
}
}
docker pull cmusatyalab/openscout:stable
docker pull cmusatyalab/openface:latest
In the ~/openscout/server/
directory, there is a template.env file that can be used as an example docker-compose environment. Copy it to .env and then modify it to control things such as the confidence thresholds for the face and object engines. If you are using the MS Face Cognitive Service, the API key and endpoint would also be specified here.
cd ~/openscout/server/
cp template.env .env
#edit .env file as necessary
To launch all the containers and interleave the output from each container in the terminal:
cd ~/openscout/server
docker-compose up
If you wish to launch the containers in the background, you can pass the -d flag to docker compose. You can then use docker logs to inspect what is happening to individual containers.
cd ~/openscout/server
docker-compose up -d
If you wish to use the Microsoft Face Cognitive Service instead of OpenFace, the docker-compose.yaml file will need to be modified to comment out the openface-service and instead use ms-face-service.
By default, Elasticsearch will dynamically create an index called openscout
and make a best effor to infer mappings for the fields that are pushed into it. However, we can control the mappings using index templates so that some fields have explicit types (such as geo_point for the location field). To do this, first navigate to the Kibana UI at https://localhost:5601. Under 'Manage and Administer the Elastic Stack', click 'Console'. At the console, paste the following template into the editor on the left and click the send request icon.
PUT _index_template/template_1
{
"index_patterns": ["openscout*"],
"template": {
"settings": {
"number_of_shards": 1
},
"mappings": {
"_source": {
"enabled": true
},
"properties": {
"location": {
"type": "geo_point"
},
"image": {
"type": "keyword"
}
}
},
"aliases": {
"mydata": { }
}
},
"priority": 10,
"version": 1,
"_meta": {
"description": "OpenScout template"
}
}
NOTE: This should be done prior to connecting any clients. Once the first client connects and sends data to the server, the index will be created. If the template doesn't exist beforehand, then the mappings in the template will not be used.
Hitting CTRL-C while docker-compose up
is running will stop the containers. However to explicitly destroy them, you can use docker-compsoe down
. This will also destroy the networks, however the training volume (and any images that were added to the training set) will persist until explicitly deleted with docker volume rm
.
You can download the client from the Google Play Store.
Alternatively, you can build the client yourself using Android Studio. The source code for the client is located in the android-client
directory. You should use the standardDebug build variant.
Servers can be added by entering a server name and address and pressing the + sign button. Once a server has been added, pressing the 'Connect' button will connect to the OpenScout server at that address. Pressing the trash can button will remove the server from the server list.
- Show Screenshot/Recording Buttons - This will enable icons to allow you to capture video or screenshots while running OpenScout.
- Display Metrics - Enabling this option will show the number of detections during your sessions.
- Resolution - Configure the resoultion to capture at. This will have a moderate impact in the computation time on the server.
- Gabriel Token Limit - Allows configuration of the token-based flow control mechanism in the Gabriel platform. This indicates how many frames can be in flight before a response frame is received back from the server. The minimum of the token limit specified in the app and the number of tokens specified on the server will be used.
- GPS Update Frequency - The number of milliseconds in between location updates from the location provider (either GPS or network). This can be increased to conserve battery or decreased for more frequent location changes. Default is 10 seconds.
- GPS Update Distance - In conjunction with the update frequency, updates will not be returned to OpenScout from the location manager if the change is distance is less than the value specified. Default is 10 meters, which means that the device has to have moved more than 10 meters in the last 10 seconds for an updated location to be returned by the location manager.
Once connected to a server, an icon is displayed in the upper right hand corner which allows one to toggle between front- and rear-facing cameras.
The add person button can be clicked to train a person for facial recognition on the fly. Enter the name you wish the person to be identified as and then click the 'Train' button. The images captured over the next 5 seconds will be used as the training set. Ensure that the persons face is prominently displayed in the catpured images.
For object detection, we have prepackaged the ssd_resnet_50_fpn_coco DNN from the Tensorflow Detection Model Zoo. The COCO dataset has ~100 objects that it will detect. The dataset and the objects in it can be explored here.
OpenScout's object detection cognitive engine also supports Tensorflow DNNs exported out of OpenTPOD.
Out of the box, we have trained on three celebrities' faces: Dwayne Johnson, Saoirse Ronan, and Hugh Jackman. Ten images for each person can be found in the /openscout/server/training
directory. You can create subdirectories at this location for additional people and then rebuild the Docker image so that they will be included at startup. You may also train ad hoc as described above in the Android client section. Test images for the three celebrities can be found below.
Dwayne Johnson | Saoirse Ronan | Hugh Jackman |
---|---|---|
OpenScout uses ELK (Elasticsearch, Logstash, Kibana) to index the data discovered by OpenScout clients, allowing it to be explored and visualized. Three ELK containers are run alongside the core OpenScout containers. The Logstash container receives input from the object detection and face recognition cognitive engines, parses the data, and forwards it on to the Elasticsearch container. Kibana then queries the Elasticsearch container using REST APIs to discover and visualize the data that is indexed. As OpenScout clients detect objects and faces and send the results to the server, the data is then propagated to ELK and made queryable. To start exploring the data:
- Navigate to the Kibana dashboard (https://localhost:5601).
- Create an index pattern for Kibana. Because the index in Elasticsearch is called
openscout
, we can useopenscout*
as the index pattern for Kibana. The default@timestamp
field can be used as the timestamp. - Now that an index pattern has been created, you can explore the data by selecting 'Discover' from the home page.
- Visualizations can also be created once clients have forwarded data to the server by selecting 'Visualize'.
Please see the CREDITS file for a list of acknowledgments.