@shiguredo/lyra-wasm
TypeScript icon, indicating that this package has built-in type declarations

2023.1.0 • Public • Published

lyra-wasm

GitHub tag npm version License

Lyra V2 (google/lyra) という低ビットレート音声コーデックを WebAssembly にビルドして ブラウザで使えるようにするためのライブラリです。

デモページ: https://shiguredo.github.io/lyra-wasm/recording.html

使い方

JavaScript / TypeScript から利用する場合

以下のコマンドでパッケージがインストールできます:

$ npm install --save @shiguredo/lyra-wasm

TypeScript での使用方法は次のようになります:

import { LyraModule } from "@shiguredo/lyra-wasm";

// WebAssembly ファイルおよびモデルファイルが配置されているディレクトリの指定
// それぞれのファイルの取得方法は後述
const wasmPath = "./";
const modelPath = "./";

// 各種ファイルをロード
const lyraModule = await LyraModule.load(wasmPath, modelPath);

// エンコーダを生成
const lyraEncoder = await lyraModule.createEncoder({bitrate: 6000});

// デコーダを生成
const lyraDecoder = await lyraModule.createDecoder();

// エンコードおよびデコード
const audioData = new Float32Array(lyraEncoder.frameSize); // 無音の音声データを 1 フレーム分生成
const encoded = await lyraEncoder.encode(audioData);
const decoded = await lyraDecoder.decode(encoded);

ブラウザから利用する場合

examples/recording.html に実際に動作する例があるので、そちらを参照してください。

ビルド済み WebAssembly ファイルの取得方法

リリースページからビルド済みの lyra.wasm および lyra.worker.js ファイルが取得できます。

$ curl -OL https://github.com/shiguredo/lyra-wasm/releases/download/2023.1.0/lyra.wasm
$ curl -OL https://github.com/shiguredo/lyra-wasm/releases/download/2023.1.0/lyra.worker.js

自前でビルドする場合には、以下のコマンドを実行してください。

$ git clone https://github.com/shiguredo/lyra-wasm
$ cd lyra-wasm
$ npm install
$ npm run build
$ ls wasm/bazel-bin/lyra-wasm/lyra.wasm  wasm/bazel-bin/lyra-wasm/lyra.worker.js

モデルファイルの取得方法

Lyra は機械学習ベースの音声コーデックなので、動作させるためには学習済みのモデルファイルが必要になります。 モデルファイルは google/lyra リポジトリで配布されており、以下のようにして取得できます。

$ curl -OL https://github.com/google/lyra/raw/v1.3.0/model_coeffs/lyra_config.binarypb
$ curl -OL https://github.com/google/lyra/raw/v1.3.0/model_coeffs/lyragan.tflite
$ curl -OL https://github.com/google/lyra/raw/v1.3.0/model_coeffs/quantizer.tflite
$ curl -OL https://github.com/google/lyra/raw/v1.3.0/model_coeffs/soundstream_encoder.tflite

注意点

本ライブラリは WebAssembly のマルチスレッド機能を利用しているため、 デフォルトでは無効になっている SharedArrayBuffer クラスが使える必要があります。

このクラスは、本ライブラリを使用する HTML ドキュメントの HTTP 応答で、 以下のヘッダを指定することで有効になります。

Cross-Origin-Embedder-Policy: require-corp
Cross-Origin-Opener-Policy: same-origin

About Shiguredo's open source software

We will not respond to PRs or issues that have not been discussed on Discord. Also, Discord is only available in Japanese.

Please read https://github.com/shiguredo/oss/blob/master/README.en.md before use.

時雨堂のオープンソースソフトウェアについて

利用前に https://github.com/shiguredo/oss をお読みください。

使い方

ライセンス

Apache License 2.0

Copyright 2022-2022, Takeru Ohta (Original Author)
Copyright 2022-2022, Shiguredo Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

生成された wasm ファイルのライセンスについては lyra/LICENSE を参照してください。

Readme

Keywords

Package Sidebar

Install

npm i @shiguredo/lyra-wasm

Weekly Downloads

0

Version

2023.1.0

License

Apache-2.0

Unpacked Size

492 kB

Total Files

7

Last publish

Collaborators

  • tnamao
  • miosakuma
  • melpon
  • takeruohta
  • voluntas