Using Accelerate and simd
Using Accelerate and simd
WWDC 2018
Composition of Accelerate Framework
- vDSP — Signal processing
- vImage — Image processing
- vForce — Vector transcendental functions
- BLAS, LAPACK, LinearAlgebra — Dense matrix computations
- Sparse BLAS, Sparse Solvers — Sparse matrix computations
- BNNS-Neural networks
Closely Related
- simd — Small vector and matrix computation for CPU
- Compression — Lossless data compression
Signal Processing Library
- Basic operations on arrays
- Add, subtract, multiply, conversion, etc. - Discrete Fourier/Cosine Transform
- 1D DFT/ DCT/ FFT
- 2D FFT - Convolution and correlation
Demo
Signal Extraction from Noise Link
Essential Computations
- Analyze noisy signal with forward DCT
- Remove frequency components of amplitude less than threshold
- Reconstruct clean signal with inverse DCT
data:image/s3,"s3://crabby-images/a09da/a09da9c445a675f55a58d06bec5213aa2bf493d1" alt=""
data:image/s3,"s3://crabby-images/89693/89693ff3082faddf3c55fae9ffd8af5c0911b250" alt=""
Demo
Halftone Descreening with 2D Fast Fourier Transform
Essential Computations
- Transform halftone image with 2D FFT
- Remove frequency components of the halftone screen
- Reconstruct continuous tone image
data:image/s3,"s3://crabby-images/43afb/43afbcee68035e4c3507773669af2b9d82ea38ab" alt=""
Frequency Removal
- zvmags
- vthrsc
- vclip
- zrvmul
data:image/s3,"s3://crabby-images/08f46/08f4682b031d83e08514c1a4761aebc2f84b7f8e" alt=""
data:image/s3,"s3://crabby-images/84487/844878409db98ea6d2cebcbe3ee9d97806c15ee4" alt=""
The simd Module
- Simplified vector programming
- Small (fixed-size) vector and matrices
- Abstract architecture-specific types and intrinsics
data:image/s3,"s3://crabby-images/a78b0/a78b0a85319fc6ae82e9486aee2db9a6aa0306ba" alt=""
simd
- Matrices of size 2, 3, or 4 and vector of 2, 3, 4, 8, 16, 32, or 64
- Arithmetic operators (+,-, *, /) work with both vectors and scalras
- Supports common vector math and geometry operations (dot, length, clamp)
- Quaternions
data:image/s3,"s3://crabby-images/fde89/fde892de8a43766a60af5d4750a94ebcb1d8f9fa" alt=""
data:image/s3,"s3://crabby-images/fcee1/fcee14396b341b65355c93a5efe5b91cb9fa5486" alt=""
data:image/s3,"s3://crabby-images/f5d6f/f5d6f09a22d4cfa7fb7aa9a9b0372bc3a729f7cf" alt=""
data:image/s3,"s3://crabby-images/9aa63/9aa63ae8aced11278371444a3a40d067cff04271" alt=""
Rotating a Cube by Transforming Its Vertices Link
data:image/s3,"s3://crabby-images/f0ee4/f0ee4b0ac2b96e478c5ecc79b13efe9a5fb5e0bb" alt=""
vImages
Image Processing Library
- Conversion
- Geometry
- Convolution
- Transform
- Morphology
data:image/s3,"s3://crabby-images/f1a52/f1a52e2ba6b46c60af26b0a67276431d5fa1adc4" alt=""
Adjust Color Saturation
- The formula to adjust color saturation is
Cb = ((Cb -128) * saturation) + 128
Cr = ((Cr -128) * saturation) + 128
data:image/s3,"s3://crabby-images/1232a/1232ae8b67cff6e61644994f1fdf979a39223d1a" alt=""
Workflow
data:image/s3,"s3://crabby-images/277dd/277dd83256ca379ebf1011172f905ba5b025a70a" alt=""
More video effects
- Rotation
data:image/s3,"s3://crabby-images/1b44f/1b44f259f004249ea1e007b972f0f590f1e41dc7" alt=""
- Blur
data:image/s3,"s3://crabby-images/ebd69/ebd69b605947222a76c8eb3117dac7be6a3c231c" alt=""
- Dither
data:image/s3,"s3://crabby-images/2bba2/2bba2923e8cae79ce7becf3114dcac3063ad4fb9" alt=""
- Color quantization
data:image/s3,"s3://crabby-images/724e3/724e3fd34040aec0022b7bb5b794ff12d819bac1" alt=""
LINPACK Benchmark
- How fast can you solve a system of equations?
- Actually 3 separate benchmarks
- 100 x 100 system
- 1000 x 1000 system
- No hold barred
data:image/s3,"s3://crabby-images/04336/043362275b1188e6b7b5a74a18ef7fdb3f4d4db8" alt=""