サイマルキャストマルチコーデック機能

注意

この機能を利用する場合は事前にサポートまでご連絡ください

警告

この機能は 実験的機能 のため、正式版では仕様が変更される可能性があります

概要

サイマルキャストマルチコーデックは、複数のコーデックを同時に使用して、サイマルキャストを実現する仕組みです。

注意

この機能は実験的機能として提供しており、かつブラウザ側の実装が未定のため、 将来的に仕様が大きく変更する可能性があります。それを踏まえてご利用ください。

不明点がある場合はサポートまでお問い合わせください。

制限

ブラウザでの配信

重要

2024 年 12 月 現在、ブラウザでサイマルキャストマルチコーデック機能を利用することはできません。

ブラウザでの視聴

一部ブラウザでサイマルキャストマルチコーデックで配信された映像を視聴することはできます。 視聴時のコーデック切り替えにも対応しています。

動作が確認できているブラウザは Chrome と Edge と Safari Technology Preview です。 それ以外のブラウザでは正常に動作しない可能性があります。

録画機能の利用

将来的に対応予定です

サイマルキャストマルチコーデックが有効なクライアントでは録画機能を利用することはできません。

映像コーデック指定の無視

サイマルキャストマルチコーデックを指定した場合、 クライアントや認証時の払い出しでのコーデック指定は無視されます。

利用方法

サイマルキャストマルチコーデックを利用する

sora.conf で simulcast_multicodec を有効にする

サイマルキャストマルチコーデック機能を利用するには sora.confsimulcast_multicodectrue に設定します。

simulcast_multicodec = true

シグナリング接続時に "simulcast": true"simulcast_multicodec": true を指定する

マルチコーデックサイマルキャストを利用するにはシグナリング接続時に "simulcast": true"simulcast_multicodec": true を指定します。

この際、 "video": {"codec_type": "VP8"} などのコーデック指定は無視されます。

{
  "type": "connect",
  "role": "sendrecv",
  "channel_id": "sora",
  "simulcast": true,
  "simulcast_multicodec": true
}

サイマルキャストマルチコーデックのデフォルト値

サイマルキャストマルチコーデック用のコーデックには以下のデフォルト値が設定されています。

[
  {"rid": "r0", "codec_type": "AV1", "codec_params": {"profile": 0}},
  {"rid": "r1", "codec_type": "AV1", "codec_params": {"profile": 0}},
  {"rid": "r2", "codec_type": "H264", "codec_params": {"profile_level_id": "42e01f"}}
]

サイマルキャストマルチコーデックのデフォルト値を変更する

sora.confsimulcast_codecs_file でサイマルキャストマルチコーデックで利用するコーデックのデフォルトを指定することができます。

simulcast_codecs_file = etc/simulcast_codecs.json
[
  {"rid": "r0", "codec_type": "H264", "codec_params": {"profile_level_id": "42e01f"}},
  {"rid": "r1", "codec_type": "H264", "codec_params": {"profile_level_id": "42e01f"}},
  {"rid": "r2", "codec_type": "H265"}
]

認証成功時の払い出しで指定する

サイマルキャストマルチコーデックを利用する場合 simulcastsimulcast_multicodec を認証成功時に払い出すことができます。

{
  "allowed": true,
  "simulcast": true,
  "simulcast_multicodec": true
}

r0 と r1 に H264 、r2 に H265 を利用する場合の例です。

{
  "allowed": true,
  "simulcast": true,
  "simulcast_multicodec": true,
  "simulcast_codecs": [
    {"rid": "r0", "codec_type": "H264", "codec_params": {"profile_level_id": "42e01f"}},
    {"rid": "r1", "codec_type": "H264", "codec_params": {"profile_level_id": "42e01f"}},
    {"rid": "r2", "codec_type": "H265"}
  ]
}

simulcast_encodings の指定

サイマルキャストマルチコーデックのサイマルキャストエンコード部分は simulcast_encodings のデフォルト値を利用します。

そのため、サイマルキャストマルチコーデック向けに simulcast_encodings を指定したい場合は、 認証成功時に払い出す必要があります。

{
  "allowed": true,
  "simulcast": true,
  "simulcast_multicodec": true,
  "simulcast_encodings": [
    {"rid": "r0", "active": true, "scaleResolutionDownBy": 4.0, "maxFramerate": 10.0},
    {"rid": "r1", "active": true, "scaleResolutionDownBy": 1.0, "maxFramerate": 30.0},
    {"rid": "r2", "active": true, "scaleResolutionDownBy": 1.0, "maxFramerate": 30.0}
  ],
  "simulcast_codecs": [
    {"rid": "r0", "codec_type": "H264", "codec_params": {"profile_level_id": "42e01f"}},
    {"rid": "r1", "codec_type": "H264", "codec_params": {"profile_level_id": "42e01f"}},
    {"rid": "r2", "codec_type": "H265"}
  ]
}

type: offer 時に払い出される内容

simulcast_encodingssimulcast_codecs に指定された値から、 W3C WebRTC 準拠の RTCRtpEncodingParameters を生成し、 "type": "offer""encodings" として追加します。

"codec" については W3C WebRTC RTCRtpCodecParametersW3C WebRTC Extension RTCRtpEncodingParameters に準拠しています。

{
  "type": "offer",
  "simulcast": true,
  "simulcast_multicodec": true,
  "encodings": [
    {
      "rid": "r0",
      "active": true,
      "scaleResolutionDownBy": 4.0,
      "maxFramerate": 10.0,
      "codec": {
        "mimeType": "video/H264",
        "clockRate": 90000,
        "sdpFmtpLine": "level-asymmetry-allowed=1;packetization-mode=1;profile-level-id=42e01f"
      }
    },
    {
      "rid": "r1",
      "active": true,
      "scaleResolutionDownBy": 1.0,
      "maxFramerate": 30.0,
      "codec": {
        "mimeType": "video/H264",
        "clockRate": 90000,
        "sdpFmtpLine": "level-asymmetry-allowed=1;packetization-mode=1;profile-level-id=42e01f"
      }
    },
    {
      "rid": "r2",
      "active": true,
      "scaleResolutionDownBy": 1.0,
      "maxFramerate": 30.0,
      "codec": {
        "mimeType": "video/H265",
        "clockRate": 90000,
        "sdpFmtpLine": "profile-id=1;level-id=93"
      }
    }
  ]
}
© Copyright 2024, Shiguredo Inc Created using Sphinx 7.4.7