Skip to content

The intelligent ad-insertion reference pipeline shows how to integrate various media building blocks, with analytics powered by the OpenVINO™ Toolkit, to accelerate your converged media pipeline. This is a server-side ad insertion sample (not a finished product) that can be referenced by developers to ease application development challenges.

License

Notifications You must be signed in to change notification settings

dpatel257/Ad-Insertion-Sample

 
 

Repository files navigation

ld Status](https://travis-ci.com/OpenVisualCloud/Ad-Insertion-Sample.svg?branch=master)](https://travis-ci.com/OpenVisualCloud/Ad-Insertion-Sample) Stable release License Contributions

The E2E sample implements a server-side AD insertion system, which features on-demand video transcoding and streaming, and AD insertion based on video content analysis.

The Content Provider service serves original content, with on-demand transcoding, through the DASH or HLS streaming protocol. The AD Insertion service analyzes video content on the fly and inserts AD, with transcoding if needed, into the video stream at each AD break slot.

The client player is based on dash.js and hls.js.

See additional information on each service:

Install docker engine:

(1) Install docker engine.
(2) Install docker compose, if you plan to deploy through docker compose. Version 1.20+ is required.
(3) Setup docker swarm, if you plan to deploy through docker swarm. See docker swarm setup for additional setup details. (4) Setup Kubernetes, if you plan to deploy through Kubernetes. See kubernetes setup for additional setup details.

Setup docker proxy:

(4) sudo mkdir -p /etc/systemd/system/docker.service.d       
(5) printf "[Service]\nEnvironment=\"HTTPS_PROXY=$https_proxy\" \"NO_PROXY=$no_proxy\"\n" | sudo tee /etc/systemd/system/docker.service.d/proxy.conf       
(6) sudo systemctl daemon-reload          
(7) sudo systemctl restart docker     

Build docker images:

(1) mkdir build    
(2) cd build     
(3) cmake ..    
(4) make     

Generate DASH/HLS segments

By default, DASH/HLS segments are generated on the fly during playback, which requires a powerful server platform to keep up with the load. If unsure, it is recommended that you use the following commands to pre-generate DASH/HLS segments:

(5) make dash    # take a coffee break?        
(6) make hls     # take a walk?!      

Start/stop services:

Use the following commands to start/stop services via docker swarm:

(1) make start_docker_swarm      
(2) make stop_docker_swarm      

Use the following commands to start/stop services via docker-compose:

(1) make start_docker_compose      
(2) make stop_docker_compose      

Use the following commands to start/stop services via Kubernetes:

(1) make start_kubernetes      
(2) make stop_kubernetes      

Note: This commands must be run as root.

Launch browser:

Launch your browser and point to https://localhost to play the streams and see ADs got inserted during playback. Note that if you see a browser warning of self-signed certificate, please accept it to proceed to the sample UI.

In-case of Kubernetes, connect to https://<system-ip>:30443

Customize videos:

Customize the video playlist by adding videos under volume/video/archive or in the build script content-provider/archive/build.sh.
Rerun make and restart the service after making any changes.

About

The intelligent ad-insertion reference pipeline shows how to integrate various media building blocks, with analytics powered by the OpenVINO™ Toolkit, to accelerate your converged media pipeline. This is a server-side ad insertion sample (not a finished product) that can be referenced by developers to ease application development challenges.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 70.2%
  • Shell 11.7%
  • CSS 6.0%
  • Dockerfile 5.9%
  • JavaScript 4.6%
  • CMake 1.2%
  • HTML 0.4%