Skip to content
This repository has been archived by the owner on Nov 12, 2024. It is now read-only.

ibelem/webmlmeet

Repository files navigation

Deprecated

Please visit https://github.com/ibelem/gathering-with-others for up to date version.

Web-based Intelligent Collaboration

A Web-based Intelligent Collaboration (WIC) demo, which integrated emerging Web APIs including Wasm, WebGL, and up to date W3C Web Neural Network API (WebNN), running on the on-device hardware such as CPU, GPU or purpose-built AI accelerators like Intel VPU.

Web Neural Network (WebNN) API is a dedicated low-level API for neural network inference hardware acceleration. It is published by the W3C Machine Learning for the Web Community Group.

Features

Video Conference Features

  • Video and audio
  • Screen sharing
  • Conversation / Text message
  • ...

Web Machine Learning Features

  • Background blur
  • Background replacement
  • Noise suppression
  • More to come

Supported Backends

  • Slowest: WebAssembly (Wasm) + SIMD
  • Fastest: Web Neural Network (WebNN) API

Machine Learning JavaScript Frameworks Integration

Precondition

Setup

HTTPS Configuration

Go to this project main dir, and create private and public key.

Recommend

Visit https://github.com/FiloSottile/mkcert, install mkcert

$ mkcert -install
$ mkcert yourdomain.com xxx.xxx.xxx.xxx localhost 127.0.0.1 ::1

Use the .pem and key.pem files directly or generate .key and .crt files from these .pem files. Fill the certificate path in Line 99 and Line 100 in meetingserver.js

Alternative

$ openssl genrsa 2048 > wic.key
$ chmod 400 wic.key
$ openssl req -new -x509 -nodes -sha256 -days 365 -key wic.key -out wic.crt

Environment Configuration

Update configurations in config.js under main folder, paste sampleServiceId and sampleServiceKey values from WebRTC server via Docker on Linux or Windows, or in 'Launch the OWT Server as Single Node' section of Open WebRTC Toolkit (OWT) Server Setup, update them as the values of id and key in config.js like below:

module.exports = {
  id: '5df9ca6f7415937c7a91d774',
  key: 'rGtTQokQM/OeG/9oDzK9TtFjd+OOeUmFN2dZl52mvaI4cSj1waduIJB8x21Wa9MaGqtZzV1KTWBvr7heBIgSjQjQyeBWI0RFzCTSyhFtd9jmZ994xE50Gkmb2zxkQYALef8oj8do3gT/cWfOfgq1zPooCkRtbMK1xm44Avduyj4=',
  url: 'https://10.239.115.53:3000/',
  httpPort: 8001,
  httpsPort: 8002,
};

Update meetingserver.js:

cert: fs.readFileSync('cert/wic.crt'),
key: fs.readFileSync('cert/wic.key'),

Build

$ npm install
$ node meetingserver.js

If error happens related to port conflict, you could change ports in config.js.

How to Run

If you are running the code locally, the browser will show "Your connection is not private" when accessing Intel OWT server and WIC demo:

On macOS if it says "Your connection is not private", click somewhere on the page and then blindly type thisisunsafe which will instantly bypass the warning.