Waaaaaaasm?
Valeriy Kuzmin
Lilt, 2019
Idea
JS Business logic
JS Business logic
OMG, this part is so laggy!
Idea
JS Business logic
JS Business logic
Fast and smart code written in C
WASM Applications
PDF Rendering
Working with images
Cryptography
Video processing
Fast serialization/Desirialization
Usage of Game engines in browser
Other languages but JS in browser
Browser in browser
Various math, sorting, brute-forcing problems
Databases inside the browser
Working with archives
Machine Learning
Downsampling JPEG
Very rough explanation
#0f0
#f00
#770
A
B
C
D
E
E = (A + B + C + D) / 4
JPEG
Canvas
JPEG
Canvas
canvas.width
Canvas
canvas.height
ctx.toDataURL
ctx.drawImage
JPEG
RGB
JPEG
RGB
libjpeg.decode
libjpeg.encode
stb resize
Wasm
Demo
(downsample)
Original
Chrome - canvas + sq=high
FF, IE - canvas
Wasm everywhere- laczos3
What's inside?
(and how to do it yourself)
jpegasm (JS)
libjpeg-9a (C)
stb_resize_image (C++)
libjpegasm.js
emscripten
libjpegasm.wasm
Modules
var encode_jpeg = Module.cwrap('encode_jpeg',
'number', ['number', 'number', 'number',
...]);
int encode_jpeg(
unsigned char* rgb_buffer,
unsigned int rgb_width,
unsigned int rgb_height,
...);
Calling pure C from JS (cwrap)
C function declaration
JS call
EMSCRIPTEN_BINDINGS() {
function("stbir_resize_uint8_generic",
optional_override(...) {
...marshalling magic...
}
}));
}
int stbir_resize_uint8(
const unsigned char *input_pixels ,
int input_w , int input_h , ...)
Calling C++ from JS (embind)
#include <emscripten.h>
...
float coef = stbir__filter_info_table[filter]
.kernel((float)(out_last_pixel + 1)
+ 0.5f - out_center_of_in, scale_ratio);
EM_ASM_({console.log('coef', $0)}, coef)
...
Calling JS from C/C++ (EM_ASM)
How to do it: summary
- build emscripten on your machine
- use cwrap for С, embind for С++
- optional_override for complex mapping
- EM_ASM for calling JS from C/C++
- Forget about GC, do free() manually in JS
Demo 2
(game)
Useful stuff
Thanks!
Questions?
malcoriel@gmail.com
malcoriel
wasm2-at-lilt
By Valeriy Kuzmin
wasm2-at-lilt
- 434