Measuring and Optimizing HLS Performance
Measuring and Optimizing HLS Performance
WWDC 2018
Best User Experience for HLS
- Content authoring → playlist authoring, media formats, codecs
- Application design → using the AVFoundation API
- Delivery → server configuration and performance
- Understand and quantify user experience in conjunction with your changes
- Measure to find the optimal configuration
What Is This Session About?
- Establish a common language for streaming Quality of Service
- Objectively measure the streaming QoS
- Identify and solve problems that impair Qos
- Get master playlists right
Anatomy of an HLS Playback session
data:image/s3,"s3://crabby-images/4fecd/4fecdb1375731674109971077920d48d9365b92d" alt=""
Quantifying the User Experience
Key Performance Indicator (KPIs) for HLS
data:image/s3,"s3://crabby-images/07eec/07eec4754bf914b766aa89ff331dd952c44e0c63" alt=""
Startup Time
How much time did users spend waiting for playback to start?
data:image/s3,"s3://crabby-images/91e13/91e136467e17f81326bb10f1d4e0afbf61d863a0" alt=""
Stall Rate
- How often was playback interrupted?
data:image/s3,"s3://crabby-images/4e083/4e0831c2a5aa9ccc5f47079891a135d4583a7e63" alt=""
- How long was playback interrupted?
data:image/s3,"s3://crabby-images/ac3a5/ac3a535279fb87c6b46b6735bdca825415a1c8cb" alt=""
data:image/s3,"s3://crabby-images/78812/788120c3b5328764add01deaf6ea8290c53d6d5d" alt=""
AVPlayerItemAccessLog
Provides a history of the playback session
data:image/s3,"s3://crabby-images/c0374/c0374a528a40fe591af311ec1686666d30a9a8d8" alt=""
Time-Weighted Indicated Bitrate
What was the overall media quality?
data:image/s3,"s3://crabby-images/fba88/fba88568e81eac8c857eeca22eb3537033312f60" alt=""
data:image/s3,"s3://crabby-images/3d2c3/3d2c364de3d40f39dcd45b2c2dc5e55d250994fa" alt=""
Playback Failure Percentage
How often did the stream end due to an error?
data:image/s3,"s3://crabby-images/980f8/980f83777713c981388cf434c6c3a23226ec525a" alt=""
AVPlayerItemErrorLog
Conveys failures with varying degrees of user impact
data:image/s3,"s3://crabby-images/00928/009283ee0915f37c142096f0eef0613814895dfd" alt=""
The User Experience
Key performance indicators for HLS
- KPIs are not always comparable between device models and usage scenarios
- Gather context information along with your streaming metrics
- Partition your playback sessions in classes that make sense for your application
data:image/s3,"s3://crabby-images/76124/76124551ac4d5f03bccbc475383d8d31c63e52cf" alt=""
Sample
What can Delay Start of playback?
data:image/s3,"s3://crabby-images/5a671/5a6716dc4e798db0b236f0118de8d34aee61dbd2" alt=""
How Do I Reduce Startup Time?
- Multiple time-consuming operations
- Measure time cost
- Time spent between API calls and Player/ PlayerItem status change notifications
-AVPlayerItemAccessLogEvent.startupTime
- Time from starting media download to the firstisPlaybackLikelyToKeepUp == true
Reduce Startup Time — AVAsset
data:image/s3,"s3://crabby-images/70624/70624172378f7d0b1d7b379eeb74caea5bc5d5b6" alt=""
Reduce Startup Time — AVAsset
data:image/s3,"s3://crabby-images/5cb43/5cb4348f963dd9e6ae73e1d6dd6c999e97485b9a" alt=""
- Create and inspect AVAsset before user decides to play
- Prefetch decryption keys
- Adopt AVContentKeySession!
Reduce Startup Time — AVPlayer and AVPlayerItem
- Set up AVPlayerItem before buffering
- Set AVPlayer rate before setting player item
data:image/s3,"s3://crabby-images/8be03/8be030513e3c212445f5a4dd0e5841ec3567e8dd" alt=""
data:image/s3,"s3://crabby-images/a9751/a9751bccd089a146ebd629e94c0c0ebdf86be896" alt=""
Reduce Startup Time — AVPlayerItem Transition
- Use AVQueuePlayer to play multiple items
- Enqueue second AVPlayerItem well in advance
data:image/s3,"s3://crabby-images/c397f/c397fde2822fdc1c12d94775e7227f110b3b8589" alt=""
What Determines Network Buffering Time?
- Choice of variant
- Content bitrate
- Playlist target duration
- Network bandwidth
Network Buffering Time — Typical Case
data:image/s3,"s3://crabby-images/feb63/feb63e6cca736fa607a78057087e5d3bc0e0f408" alt=""
Network Buffering Time — Download Slower Than 1x
data:image/s3,"s3://crabby-images/e6c1c/e6c1c1e95390f7b8569e9f0ff9b5cb3501482622" alt=""
Network Buffering Time — Initial Variant Choice
data:image/s3,"s3://crabby-images/9a778/9a778fd862b7ab894d54502ad8eef04bf7125e8f" alt=""
Reducing Network Buffering Time
- Wise choice of initial variant
- Lower content bitrate means shorter buffering time for startup
- But it’s a trade off of initial video quality 🤔 - Be mindful of all media format
- Consider initial variant for each flavor of media format
- HDR / SDR, HEVC / H.264, Stereo / DD / DD+
Why Does the Playback Stall ?
- Stalls can happen !
- How to investigate stalls
- How to avoid stalls
Stall Investigation
- Listen to stall notifications
data:image/s3,"s3://crabby-images/51f77/51f77c7245f850927050fc64ac0359547a049a69" alt=""
- Check
AVPlayerItem
status
data:image/s3,"s3://crabby-images/46d75/46d75e84ef3797098fde5aa21aee6cafaee06c19" alt=""
AVPlayerItemErrorLog
AVPlayerItemAccessLog
data:image/s3,"s3://crabby-images/c5131/c513100b06244ad1c55ed05c70f74863736874e8" alt=""
Reducing Stalls — Dealing With Variable Networks
Provide a full set of bit rate tiers
- Each codec combination needs its own set of tiers
Reducing Stalls — Dealing With Variable Networks
Your content server and CDN must
- Deliver media playlists, segments, and keys without delay
- Update live playlists at least every target duration
- Synchronize discontinuity sequence numbers between playlists
- Indicate server-side failure clearly
How to Investigate Errors
- Error and access logs
- Error properties
- Media validation
Streaming Errors — AVPlayerItemErrorLog
- Can be triggered by problems with the network or content format
- May be nonfatal
- Details are in the error comments
data:image/s3,"s3://crabby-images/42099/4209950f9d32b5a9394f13bc2db1f0ca367b6e3c" alt=""
Streaming Errors — AVPlayer, AVPlayerItem
- Observe
AVPlayerItem.status
andAVPlayerItem.error
AVPlayerItem
errors end playback, remove item from player queue
data:image/s3,"s3://crabby-images/a1bbf/a1bbf30fb6494e248cf5798562d21795c3b3990d" alt=""
data:image/s3,"s3://crabby-images/06cd9/06cd92fd16d25c3cb1615abe93644f453716d4c4" alt=""
data:image/s3,"s3://crabby-images/5580c/5580caf2bc904ed19ea4521b33cb2fb8a371641d" alt=""
Streaming Errors — HDCP
- Current item requires external protection
- Device does not meet protection level
- User observes video loss
- Have a variant which doesn’t require HDCP protection
- App UI should reflect property value changes
data:image/s3,"s3://crabby-images/dd5c8/dd5c8fe6130d57f4baf1af99a9ac357d95da4e73" alt=""
Streaming Error — Media Validation
- Media stream validator
- Available on developer website
Master PlayLists
How do I make sure the player chooses the right stream?
data:image/s3,"s3://crabby-images/aac10/aac100dddffe489f8eaa5fef085893a54a480928" alt=""
Attributes For Variants
EXT-X-STREAM-INF tag
data:image/s3,"s3://crabby-images/6080d/6080dabf53910f64b72428539c021551747834e3" alt=""
data:image/s3,"s3://crabby-images/de61d/de61d083cf10c6ed3d8e89b73c0d95dd6622d651" alt=""
Why don’t I see images in fast-forward or in the Apple TV scrubber bar ?
data:image/s3,"s3://crabby-images/5d7f1/5d7f1a51a95779048e297e636f36ce7980ceb7ac" alt=""
What’s an I-frame?
data:image/s3,"s3://crabby-images/8e297/8e29702bd242f201d0b650177c4db40f22080497" alt=""
I-frame Video Segments
Consist of a single frame
data:image/s3,"s3://crabby-images/d23e9/d23e912ba7b8660940a3d59d938f2a4ca7eb7954" alt=""
High Density I-frames
Evenly spaced, closer together, better user experience
data:image/s3,"s3://crabby-images/f666d/f666d7567e924b083ca7d859b5cdd7f9cff7bdc0" alt=""
data:image/s3,"s3://crabby-images/a2c5e/a2c5e4b96967c0a5ab9c03504da2592944370304" alt=""
How do I support multiple languages?
data:image/s3,"s3://crabby-images/5b57e/5b57ef0eecb21d4f26f3af0d5dc9718245697dc0" alt=""
data:image/s3,"s3://crabby-images/cfa19/cfa1979f476cdb8d08984d1574613dc585247b23" alt=""
What’s the difference between DEFAULT and AUTOSELECT ? 🤔
- AUTOSELECT
- This rendition can be automatically selected
- Generally you want this set to YES
- Set to NO for things like a commentary track - DEFAULT
- Player chooses this rendition unless the user chooses something else
- Only one member of a group can beDEFAULT = YES
- Must haveAUTOSELECT = YES
- Has nothing to do with the default variant
How do I support multichannel audio?
data:image/s3,"s3://crabby-images/5b7ec/5b7ecd277365e515d196132c354ce9ed4d9e924e" alt=""
data:image/s3,"s3://crabby-images/3b8c7/3b8c7c6a514a98da387ecf557f59aef5e33a5787" alt=""
How do I support several audio bit rates ?
data:image/s3,"s3://crabby-images/15d41/15d414dc27f8bfaeb0b0e7e7307484de8fcca744" alt=""
data:image/s3,"s3://crabby-images/7685a/7685af61a426ebf40c6eb9d904c7c0ff0c840d2a" alt=""
How do I want HEVC or Dolby Vision ?
data:image/s3,"s3://crabby-images/66f9a/66f9a7a52fe82ec57bf412197c042ede810bdffa" alt=""
data:image/s3,"s3://crabby-images/6dc66/6dc66ccaccb5dc375c806e8d2ae4a40e3f4396b9" alt=""
How do I handle subtitles ?
data:image/s3,"s3://crabby-images/2185b/2185bee35c960859a6877338bf2895c7e5c41b43" alt=""