Creating Photo and Video Effects Using Depth
Creating Photo and Video Effects Using Depth
WWDC 2018
data:image/s3,"s3://crabby-images/32414/32414febcc4faaa870d718fa72ccfb9bc356bf79" alt=""
Portrait Matte
- iOS 12
- Front and rear
- Portrait
- People
- Linear
- No guarantee
data:image/s3,"s3://crabby-images/c227c/c227c50cb40ee95f2431a01fac5a05f7daaced1d" alt=""
data:image/s3,"s3://crabby-images/3172c/3172ca07de079da252bb8e70c8d18fae5b0c5315" alt=""
Loading
ImageIO
data:image/s3,"s3://crabby-images/32fd8/32fd856b22b769a3932b47374c39289f5176a7a7" alt=""
AVPortraitEffectsMatte
data:image/s3,"s3://crabby-images/16727/16727dc7d8476675641d44634c7cd1b383291809" alt=""
Capture
AVCapturePhoto
data:image/s3,"s3://crabby-images/c4b1d/c4b1ddfd6ddabe358eb36cbaea3198d5594695ca" alt=""
Loading and Saving
data:image/s3,"s3://crabby-images/0ce29/0ce2936020a93916032a21691f27a2752568ad78" alt=""
data:image/s3,"s3://crabby-images/fec9b/fec9b466c2e757494fbd44f4a19e6f5cf4c5ef4b" alt=""
Sample
- Capturing Photos with Depth
- Enhancing Live Video by Leveraging TrueDepth Camera Data
- Streaming Depth Data from the TrueDepth Camera
Demo 1
Working with Depth
data:image/s3,"s3://crabby-images/ad93a/ad93ac827d398a5c7c84f7f5a9f29287d1409378" alt=""
Demo 2
Working with the Portrait Effects Matte
data:image/s3,"s3://crabby-images/51c4c/51c4ce9667c6c9af1bae15a99ca5ad144b680995" alt=""
Real-Time Video Effects with TrueDepth
- TrueDepth stream
- Point clouds
- Backdrop
data:image/s3,"s3://crabby-images/02ed2/02ed266c1c209097c4059a89f9b4f503b6424dcd" alt=""
Depth Map
data:image/s3,"s3://crabby-images/5ab39/5ab390387d1e0bbea5e66780220275c1cb25b994" alt=""
data:image/s3,"s3://crabby-images/79202/79202953f1c22b470622fc6cea5ee0c804c1d5fc" alt=""
data:image/s3,"s3://crabby-images/73b1c/73b1cc0a367a034ad42d37deaf64ab64b18f0aab" alt=""
How do you add a TrueDepth stream?
data:image/s3,"s3://crabby-images/12b2a/12b2a3d5c55c0776e0720270f6f03d334a612b23" alt=""
Disparity or Depth?
- Disparity usually yields better results
- Depth values are intuitive, but the error goes with Z²
data:image/s3,"s3://crabby-images/f8c93/f8c934b1984a2e11ca23b770c56433b9e5027fba" alt=""
Resolution
data:image/s3,"s3://crabby-images/01db8/01db8131d2a4f4a77b9dc15509a2db2552d6710d" alt=""
Test System Pressure
High resolution + fast frame rate + processing + duration
AVCaptureDevice.SystemPressureState.Level
- Nominal
- Fair
- Serious
- Critical
- Shutdown
Monitor System Pressure and Adapt
Prevent AVCaptureDevice shutdown
- Reduce frame rate when level is increasing:
- Nominal (30fps) → Serious (15 fps)
- Nominal (30fps) → Fair (24 fps) → Serious (20 fps) → Critical (15 fps)
data:image/s3,"s3://crabby-images/4706d/4706da4cfc29cfc8b52c813da9c9d48bc0d03ba8" alt=""
Filtered Depth Map
- Smoothed, spatially and temporally
- Holes filled, using RGB
- For photography/ segmentation applications
- iOS 12: spatial resolution of filtering improved from iOS 11
data:image/s3,"s3://crabby-images/369c6/369c69a293f67db7651f6d5e43d9b85cb11e08f6" alt=""
data:image/s3,"s3://crabby-images/6ead8/6ead8e9d094343470cfb23189da183277be560f6" alt=""
Using Raw Depth Data
- Use for point clouds, or real world measurements
- No depth value == 0 ⚠️
- Watch out for averaging / downsampling
Depth Map Holes ⚠️
- The TrueDepth camera detects most objects up to about 5 meters
- Low reflectivity materials absorb light
- Reflectivity
- Specular materials reflect light only from certain directions
data:image/s3,"s3://crabby-images/d41e8/d41e8884050bbe753b5782227a27fa4711b7ed4c" alt=""
- Outdoor conditions are more challenging
data:image/s3,"s3://crabby-images/5b63b/5b63b088f118d866f4cc2c3d5001f63d363cb2a7" alt=""
- Shadow from parallax between projector and camera
data:image/s3,"s3://crabby-images/b95e3/b95e37acaa60c578d1327be2fd6d7bf0894fab8e" alt=""
Point clouds
data:image/s3,"s3://crabby-images/312a7/312a7687c88f680a2ffe0c34e0d2c4a3d8317a65" alt=""
data:image/s3,"s3://crabby-images/b9660/b966072d815e7f78583bb1a919b43e01ae4d1976" alt=""
RGB-D
data:image/s3,"s3://crabby-images/7dc33/7dc3391ebcf7ec152c131d954a0b6d3a2b560179" alt=""
Vertex Shader
Point location
- Z = func( U, V )
- Tranform to ( X, Y, Z )
- Reproject with view matrix
data:image/s3,"s3://crabby-images/ae42a/ae42a2d214be7c32f59879d49743ec77a3262c74" alt=""
Fragment Shader
Point color
- Get vertex info
- Discard holes ( Z == 0 )
- Apply color from RGB frame at vertex coordinates
data:image/s3,"s3://crabby-images/966fd/966fd22e0afd90d2a5845aa67469ef347514277b" alt=""
Backdrop
data:image/s3,"s3://crabby-images/a6c17/a6c175607a8f193af9afa9d9e8d4cdf80ec5b6bd" alt=""
Per-Frame, Real-Time Processing
- Detect a face
- Create binary foreground mask, smooth, and upscale
- Upscale foreground to background and blend
- Resize background to video resolution once:
- Not upscaling foreground
- Blending at lower resolution
Getting Face Metadata
- Until a face is detected, use default face depth of 0.5 meters
- Transform center of face to depth map coordinates, and get its depth
data:image/s3,"s3://crabby-images/14c48/14c48a70851f3327448427c32ab822d5414686c4" alt=""
Binary Foreground Mask
- Threshold = face depth + 0.25 meters
- Binary mask:
- Foreground = 1
- Background = 0
data:image/s3,"s3://crabby-images/ac94a/ac94a1eea90201163737790616c1062999fe58d5" alt=""
Gaussian Blur
data:image/s3,"s3://crabby-images/aa7e2/aa7e2340f1f45aef30d7e402c06f03bfc034d209" alt=""
data:image/s3,"s3://crabby-images/5961b/5961b647a102687ca6fb8063a609efe10a428b80" alt=""
Gamma Adjust
data:image/s3,"s3://crabby-images/aa1c9/aa1c931f564ecdea11ba43f911f3c0b28ac4428d" alt=""
data:image/s3,"s3://crabby-images/a37e4/a37e455fe3dd78a6d24835741b74c927a3892b83" alt=""
Binary Mask
Alpha matte
data:image/s3,"s3://crabby-images/f2167/f2167f9f2682a0a36f6708d364cc4aa3d5ae2948" alt=""
Clamp Before Filtering
Avoiding edge softening
data:image/s3,"s3://crabby-images/5bf79/5bf7944315900930b8d405e99bfa2d39ccbaf915" alt=""
Blending Foreground with Background
data:image/s3,"s3://crabby-images/ff7ee/ff7ee62b974eafd5880f27533211227a98ad0d71" alt=""
TrueDepth Stream
640 x 480 depth map registered to video at 30 fps
data:image/s3,"s3://crabby-images/5f188/5f1883ef72a9abd07895e400088797730f6e2cba" alt=""