What’s New in Core ML, Part 1
What’s New in Core ML, Part 1
WWDC 2018
Simplified
data:image/s3,"s3://crabby-images/88aa7/88aa721728e267c7f6dcbca19902957b1208a52c" alt=""
data:image/s3,"s3://crabby-images/821fb/821fb2135b55740008b2373d9da574cbb6ea34bf" alt=""
data:image/s3,"s3://crabby-images/f32ad/f32adb5ca2849f9f0ad954e3d75549bfbec0de17" alt=""
Integrated
- Vision —
VNCoreMLRequest
- Natural Language —
NLModel
Models on Device
data:image/s3,"s3://crabby-images/c6f09/c6f09d871a06a20a9497690a38620feec31dab31" alt=""
Problem
data:image/s3,"s3://crabby-images/9a550/9a55047ab0946259d4967ff25c8b4dd06b697b3a" alt=""
Reducing Model Size
- Smaller bundle
- Smaller/faster downloads
- Reduced runtime memory usage
Core ML App Size
data:image/s3,"s3://crabby-images/12e19/12e19dd683ea5ba349922ff896339bf3cee9b434" alt=""
data:image/s3,"s3://crabby-images/1aae6/1aae696aec51adb5f62a1a620430a11c3c87d4cd" alt=""
Resnet50
< 8 bit quantization
data:image/s3,"s3://crabby-images/55215/5521562462205aa6d5dc14f109cb74dd47a41ee5" alt=""
Obtaining Quantized Models
- Post-training quantization
data:image/s3,"s3://crabby-images/8dab3/8dab3b713616166c4fcc3a299be4d80bd77f8613" alt=""
- Train quantized
- From scratch or re-training
- Then convert quantized models to Core ML
Accuracy Tradeoff
Check Your Quantized Model Accuracy
with test data and metric relevant for your app
- Model dependent
- Use case dependent
- Active area of research
Demo
data:image/s3,"s3://crabby-images/98617/98617d277942751173f79cddfdad3be9b92b6881" alt=""
data:image/s3,"s3://crabby-images/dd846/dd8466ead4383c8cc0ecac950a8c5a077b223c22" alt=""
data:image/s3,"s3://crabby-images/b917c/b917c4c04adba5ddb79fde0ff0e66a312dd7156b" alt=""
One Flexible Model
data:image/s3,"s3://crabby-images/1dec7/1dec741a19bcd7a42b7f3ce0492cf1cd056483a6" alt=""
Combine Using Flexible Image Sizes
- One model
- No redundant code
- Faster model switching times
data:image/s3,"s3://crabby-images/28e1c/28e1c51fbb652c72631bd2d2b21f00bc56bd9ca8" alt=""
Flexibility Options
data:image/s3,"s3://crabby-images/c61ca/c61ca00fcdee7b7137430d96a8746da03a103b09" alt=""
Which Models are Flexible?
Core ML Tools can check for you !
- Fully convolutional Neural Networks
- Image processing
- Object detection
Performance and Customization
data:image/s3,"s3://crabby-images/dc293/dc293d8b9508f3b8c421080de8dc2d2e530f0a02" alt=""
For Loop vs Batch
data:image/s3,"s3://crabby-images/1fa06/1fa06cd163f30e9755f5a41aca61ef319dc4d1a4" alt=""
data:image/s3,"s3://crabby-images/3ffff/3ffffed3ddfd3ed3dcbc2054c88527d08b0a5bbb" alt=""
data:image/s3,"s3://crabby-images/51fc0/51fc0907c047efb03df6644445dce899ae70a00c" alt=""
data:image/s3,"s3://crabby-images/9e5f5/9e5f50cd5ba47adf1c14351ef29f219aa8752fb1" alt=""
Any Horses?
data:image/s3,"s3://crabby-images/8ffd3/8ffd30eb7c54e9e406e944033f8244422a7ad575" alt=""
Custom Layers
data:image/s3,"s3://crabby-images/94640/94640fb5a49d1c53a252f8bd0480098836b3cfac" alt=""
data:image/s3,"s3://crabby-images/988fc/988fccdf28074fb56a5dafa8d2cf09694904786e" alt=""
data:image/s3,"s3://crabby-images/d62cf/d62cfacf3bf688999d793b9baec92b1fbee0e354" alt=""
data:image/s3,"s3://crabby-images/730ed/730ed4cda76a2de22bfde42197302f5dc8d9d5d2" alt=""
Custom Models
data:image/s3,"s3://crabby-images/f65bb/f65bb0fa77c0b229978eee39895d0766a5ec7a6e" alt=""
data:image/s3,"s3://crabby-images/e9c19/e9c19e1f2e5e05b62ac538dc8ad37ab1c1af488d" alt=""
Customization in Xcode
data:image/s3,"s3://crabby-images/c1e1c/c1e1cddcdae73ed0c1e5f80451b3e22ab5034a60" alt=""
Customization
data:image/s3,"s3://crabby-images/837c7/837c78ae53c4112ecc652ce397df372445fdfd6a" alt=""
data:image/s3,"s3://crabby-images/7753f/7753fb5b40f0d77feb18b72366e4e28f2f8311a7" alt=""