Waaaaaaasm?

Валерий Кузьмин, СКБ Контур

FrontTalks, сентябрь 2017

Kontur.Recognition

Как?

Бизнес-логика на JS

Бизнес-логика на JS

OMG, тут все тормозит!

Как?

Бизнес-логика на JS

Бизнес-логика на JS

Шустрый код на C

WebAssembly - это...

  • Развиваемая W3C спецификация платформы
  • Работающая рядом с JS "виртуальная машина"
  • Текстовый и бинарный формат
  • Цель компиляции для С/С++/Rust

"asm.js на стероидах"

WebAssembly - это не...

  • Не замена Javascript
  • Не язык сам по себе
  • Не цель компиляции для TypeScript
  • Не цель компиляции для Java, C# *

* Вообще неправда, уже есть компиляторы

Применение WASM

Рендеринг PDF

Работа с изображениями

Криптография

Обработка видео

Сериализация и

десериализация xml, json

Использование готовых игровых движков

Запуск других языков

Браузер в браузере

Математика, переборы,

сортировки

Базы данных на клиенте

Работа с архивами

Machine Learning

Downsampling JPEG

На пальцах

#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

Демо

(downsample)

Original

Chrome - canvas + sq=high

FF, IE - canvas

Wasm - laczos3

А что внутри?

(и как это повторить у себя в проекте)

jpegasm (JS)

libjpeg-9a (C)

stb_resize_image (C++)

libjpegasm.js

emscripten

libjpegasm.wasm

Модули

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, 
    ...);

C из JS (cwrap)

EMSCRIPTEN_BINDINGS() {
    function("stbir_resize_uint8_generic", 
        optional_override(...) {
            ...магия с маршалингом...
        }
    }));
}
int stbir_resize_uint8(
    const unsigned char *input_pixels , 
    int input_w , int input_h , ...)

C++ из 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)

...

JS из C (EM_ASM)

Резюме

  • собираем emscripten
  • cwrap для С, embind для С++
  • optional_override для сложных типов
  • EM_ASM в обратную сторону
  • Забудьте про GC, .delete() руками

Вместо заключения

Демо

(игра)

Полезности

Спасибо за внимание!

Вопросы?

malcoriel@gmail.com

malcoriel

http://bit.ly/wasm-ft

wasm2-at-ft

By Valeriy Kuzmin

wasm2-at-ft

  • 1,746