Empirical Analysis of ABR streaming over QUIC.
Aniketh Girish
data:image/s3,"s3://crabby-images/a73f7/a73f7a81debaf64671aae9279bd0364897ab0601" alt=""
Dr. Subhasri Duttagupta
Collaboration with:
Max Planck Institute's Internet Architecture group, Germany
Hasselt University, Belgium
gnuTLS community
videoLAN community
A quick news!
ACM students research competition in SOSP'19, Toronto, Canada
What is QUIC?
data:image/s3,"s3://crabby-images/fc3c1/fc3c16993536e350f655ad430e558585a523865c" alt=""
Research interest:
0-RTT connection setup
Low Latency
data:image/s3,"s3://crabby-images/ca37e/ca37e6b0504c51f41926c36cb530bf41a99b8bfd" alt=""
Head of line blocking
data:image/s3,"s3://crabby-images/9aa30/9aa3007323b6b454478c160996cea62bc5f679dd" alt=""
Within the scope of this thesis!
QUIC TLS API for crypto in gnuTLS
Custom QUIC version integration in VLC for better streaming experience.
Work update: Mini Project!
Exposing QUIC TLS APIs in gnuTLS
- A callback to notify the key (epoch) change
- A callback to write a Handshake messsage, when it is being sent
- A callback to write an Alert messasge, when it is being sent
- A callback to flush the message.
- A function to push data received from the peer to the TLS layer
Initial QUIC setup
ngtcp2 + ngHTTP3
Work update: Mini Project!
Updates after Mini Project
1) quicsy: A HTTP3/QUIC tool devised.
It does HTTP/3 request-response pair.
2) Segmentation: segments and manifest created for a mp4 file. Scripts to do encoding/segmentation were written
3) Host the segments in a web server
4) Mininet script to emulate a topology for controlled network experiments
5) Work in progress: HTTP/3 and QUIC implementation in VLC
1) Quicy: A HTTP3 tool
- Based on ngtcp2 + nghttp3
- A stand-alone network module
- Can send and recieve any size of data
data:image/s3,"s3://crabby-images/f7530/f7530359182f249b20f99c87ee94ebf0eb52f53e" alt=""
Demo!
2) Segmentation: Flow
data:image/s3,"s3://crabby-images/29512/295126e0e2beaa92a640c12359c186d305823836" alt=""
2) Segmentation: HLS Streaming
data:image/s3,"s3://crabby-images/dc1a7/dc1a7e398e1c0b55910ca520e4c8243b74901087" alt=""
2) Segmentation: DASH Streaming
data:image/s3,"s3://crabby-images/c4319/c43198e9bc612b3b93937ca99801b4c4fb6d1593" alt=""
2) Segmentation: Process
data:image/s3,"s3://crabby-images/d93b0/d93b02cd3b7aa47184fc5ee0a124dbce127b99ee" alt=""
Demo!
3) Host the segments in a web server
ABR streaming test with VLC
Bug in VLC found, frames being dropped.
Literature reads:
Te-Yuan Huang et al. A Buffer-Based Approach to Rate Adaptation: Evidence from a Large Video Streaming Service
Mengbai Xiao et al. DASH2M: Exploring HTTP/2 for Internet Streaming to Mobile Devices
Sheng Wei et al. Low Latency Live Video Streaming over HTTP 2.0
Anatoliy Zabrovskiy et al. Multi-Codec DASH Dataset
Stefan Lederer et al. Dynamic Adaptive Streaming over HTTP Dataset
By the next review:
Complete Mininet scripts
Evaluation of existing ABR over HTTP/1.1 and HTTP/2 in VLC
Simple live streaming over HTTP application using any ffmpeg or libav library to test our quicsy tool
Wrap up the VLC implmentation of HTTP/3 and QUIC.
Live streaming over HTTP application using any ffmpeg or libav library to test our quicsy tool
data:image/s3,"s3://crabby-images/12986/1298612b5506892dc58db848e0a9734d8041e210" alt=""
Finally, What's proposed...?
In Custom QUIC extension (QUIC-tweaked) ....?
-
Selective Reliable Transport
-
Deadline Awareness
-
Message-Oriented Abstraction
-
Forward Error Correction
-
I-P-B frame handling
-
Head-Of-Line blocking resilience
[WIP]: A complete documentation is available at: https://synackd.gitbook.io/research/
[WIP]: Code and scripts available at: https://github.com/Aniketh01/quicsy
Thank You!
anikethgireesh@gmail.com
Empirical Analysis of ABR over QUIC.
By Aniketh Gireesh
Empirical Analysis of ABR over QUIC.
- 1,037