Skip to content

A network of cameras, can be accessed through a simple GRPC interface, where Machine Learning algorithms can do various Computer Vision tasks

License

Notifications You must be signed in to change notification settings

igorrendulic/video-edge-ai-proxy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

88 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

video-edge-ai-proxy

GitHub release (latest by date)

Video Edge-AI Proxy ingests multiple RTSP camera streams and provides a common interface for conducting AI operations on or near the Edge.

Why use Video Edge-AI Proxy?

video-edge-ai-proxy is an easy to use collection mechanism from multiple cameras onto a single more powerful computer.

For example, a network of CCTV RTSP enabled cameras can be accessed through a simple GRPC interface, where Machine Learning algorithms can do various Computer Vision tasks. Furthermore, interesting footage can be annotated, selectively streamed and stored through a simple API for later analysis, computer vision tasks in the cloud or enriching the Machine Learning training samples.

Documentation

You can find more extensive documentation here

Contents

Prerequisites

Read specific configuration options here

Quick Start

By default video-edge-ai-proxy requires these ports:

  • 8905 for web portal
  • 8909 for RESTful API (portal API)
  • 50001 for client grpc connection
  • 6379 for redis

Make sure before your run it that these ports are available.

curl -O https://raw.githubusercontent.com/chryscloud/api_doc/master/install-chrysedge.sh

# Give exec permission
chmod 777 install-chrysedge.sh

# run installation script
./install-chrysedge.sh

Start the docker images:

docker-compose up

# or to run it in daemon mode:

docker-compose up -d

Open browser and visit chrysalisportal at address: http://localhost:8905

For installation outside of WSL 2 on Windows please check manuall installation steps here

Upgrading the version

You can follow the installation process:

curl -O https://raw.githubusercontent.com/chryscloud/api_doc/master/install-chrysedge.sh

chmod 777 install-chrysedge.sh

./install-chrysedge.sh

And restart (navigate to folder where your docker-compose.yml is):

sudo docker-compose restart

Usage

Open your browser and go to: http://localhost:8905

On the first visit Edge Proxy will display a RTSP docker container icon. Click on it. This will initiate the pull for the latest version of the docker container pre-compiled to be used with RTSP enabled cameras.

Connecting RTSP camera

  1. Click: Connect RTSP Camera in the chrysalisportal and name the camera (e.g. test)
  2. Insert full RTSP link (if credentials are required then add them to the link)

Example RTSP url: rtsp://admin:12345@192.168.1.21/Streaming/Channels/101 where admin is username and 12345 is the password.

Example RTSP url: rtsp://192.168.1.21:8554/unicast when no credentials required and non-default port.

Click on the newly created connection and check the output and error log. Expected state is running and output Started python rtsp process...

We're ready to consume frames from RTSP camera. Check the /examples folder.

Examples

Example Prerequisites

Create conda environment:

conda env create -f examples/environment.yml

Activate environment:

conda activate chrysedgeexamples
cd examples

Generate python grpc stubs:

make examples

Running basic_usage.py

List all stream processes:

python basic_usage.py --list

Successful output example:

name: "test"
status: "running"
pid: 18109
running: true

Output single streaming frame information from test camera:

python basic_usage.py --device test

Successful output example:

is keyframe:  False
frame type:  P
frame shape:  dim {
  size: 480
  name: "0"
}
dim {
  size: 640
  name: "1"
}
dim {
  size: 3
  name: "2"
}
  • is_keyframe (True/False)
  • frame type: (I,P,B)
  • frame shape: image dimensions (always in BGR24 format). In this example: 480x640x3 bgr24

Running opencv_display.py

Display video at original frame rate for test camera:

python opencv_display.py --device test

Display only Keyframes for test camera:

python opencv_display.py --device test --keyframe

Running annotation.py

Asynchronous annotation from the edge.

python annotation.py --device test --type thisistest

Running storage_onoff.py

Storage example turn Chrysalis Cloud storage on or off for the current live stream from the cameras.

Run example to turn storage on for camera test:

python storage_onoff.py --device test --on true

Run example to turn storage off for camera test:

python storage_onoff.py --device test --on false

Running opencv_inmemory_display.py

Prerequsite to have an in-memory queue is to setup buffer -> in_memory value in conf.yaml of your custom config.

This setting stores compressed video stream in memory and enables you to query the complete queue or portion of it. It also allows you to query the same queue (timestamp_from and timestamp_to) from parallel subprocess (check examples/opencv_inmemory_display_advanced.py for an example).

Wait for X amount of time for in-memory queue to fill up then run (for added camera named test):

python opencv_inmemory_display.py --device test

Running video_probe.py

This example shows gow to query local system time and retrieve information about the incoming video for specific camera/device.

Run example to probe a video stream (for added camera named test):

python video_probe.py --device tet

Custom configuration

Modify folders accordingly for Mac OS X and Windows

Custom Chrysalis configuration

Create conf.yaml file in /data/chrysalis folder. The configuration file is automatically picked up if it exists otherwise system fallbacks to it's default configuration.

version: 0.0.1
title: Chrysalis Video Edge Proxy
description: Chrysalis Video Edge Proxy Service for Computer Vision
mode: release # "debug": or "release"

redis:
  connection: "redis:6379"
  database: 0
  password: ""

api:
  endpoint: https://api.chryscloud.com

annotation:
  endpoint: "https://event.chryscloud.com/api/v1/annotate"
  unacked_limit: 1000
  poll_duration_ms: 300
  max_batch_size: 299

buffer:
  in_memory: 1 # number of images to store in memory buffer (1 = default)
  in_memory_scale: "iw:ih" # scaling of the images. Examples: 400:-1 (keeps aspect radio with width 400), 400:300, iw/3:ih/3, ...)
  on_disk: false # store key-frame separated mp4 file segments to disk
  on_disk_folder: /data/chrysalis/archive # can be any custom folder you'd like to store video segments to
  on_disk_clean_older_than: "5m" # remove older mp4 segments than 5m
  • mode: release: disables debug mode for http server (default: release)
  • redis -> connection: redis host with port (default: "redis:6379")
  • redis -> database : 0 - 15. 0 is redis default database. (default: 0)
  • redis -> password: optional redis password (default: "")
  • api -> endpoint: chrysalis API location for remote signaling such as enable/disable storage (default: https://api.chryscloud.com)
  • annotation -> endpoint: Crysalis Cloud annotation endpoint (default: https://event.chryscloud.com/api/v1/annotate)
  • annotation -> unacked limit: maximum number of unacknowledged annotatoons (default: 299)
  • annotation -> poll_duration_ms: poll every x miliseconds for batching purposes (default: 300ms)
  • annotation -> max_match_size: maximum number of annotation per batch size (default: 299)
  • buffer -> in_memory: number of decoded frames to store in memory per camera (default: 1)
  • buffer -> in_memory_scale: rescaling decoded images in memory buffer (default: -1:-1). Check FFmpeg Scaling
  • on_disk: true/false, store key-frame chunked mp4 files to disk (default: false)
  • on_disk_folder: path to the folder where segments will be stored
  • on_disk_clean_older_than: remove mp4 segments older than (default: 5m)

on_disk creates mp4 segments in format: "current_timestamp in ms"_"duration_in_ms".mp4. For example: 1600685088000_2000.mp4

If running on Mac OS X modify on_disk_folder to your custom one.

If running on Windows 10 modify on_disk_folder by prefixing /C/. Example:

on_disk_folder:  /C/Users/user/chrys-video-egde-proxy/videos

Building from source

git clone https://github.com/chryscloud/video-edge-ai-proxy.git

video-edge-ai-proxy stores running processes (1 for each connected camera) into a local datastore hosted on your file system. By default the folder path used is:

  • /data/chrysalis

Create the folder if it doesn't exist and make sure it's writtable by docker process.

In case you cloned this repository you can run docker-compose with build command. Start video-edge-ai-proxy with local build:

docker-compose build

RoadMap

  • Finish documentation
  • Configuration (custom configuration)
  • Set enable/disabled flag for storage
  • Add API key to Chrysalis Cloud for enable/disable storage
  • Add configuration for in memory buffer pool of decoded image so they can be queried in the past
  • Configuration and a cron job to store mp4 segments (1 per key-frame) from cameras and a cron job to clean old mp4 segments (rotating file buffer)
  • Add gRPC API to query in-memory buffer of images
  • Remote access Security (grpc TLS Client Authentication)
  • Remote access Security (TLS Client Authentication for web interface)
  • add RTMP container support (mutliple streams, same treatment as RTSP cams)
  • add v4l2 container support (e.g. Jetson Nano, Raspberry Pi?)
  • Initial web screen to pull images (RTSP, RTMP, V4l2)
  • Benchmark NVDEC,NVENC, VAAPI hardware decoders

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process of submitting pull requests to us.

Versioning

Current version is initial release - v0.0.8 prerelease

Authors

License

This project is licensed under Apache 2.0 License - see the LICENSE for details.

Acknowledgments