Hacker News new | past | comments | ask | show | jobs | submit login

This approach of the broadcasting "peer" sending multiple streams (with varying bitrates) to a relaying server is a neat solution. This is done to avoid transcoding on the relay servers, so it makes the servers cheap. It is superior to:

> Lower[ring] the bitrate of everyone’s streams so it doesn’t overwhelm the slow user (i.e. the lowest common denominator)

However, it's still a lowest common denominator solution with respect to what codec is being used. The broadcasting "peer" has to send using a codec that every other peer supports. Essentially that means you're stuck with the lowest common denominator codec.

If the relay server was to instead transcode, then the broadcasting peer could submit a single stream (lower bandwidth) in the best codec it supports. Then the relay server would generate additional streams in various bitrates and codecs (something this solution is trying to avoid).

So unfortunately there's still a trade-off.

The article does mention "Scalable video codecs" as a future improvement. However, using the approach described in this article, we're a long way off taking advantage of them, because whilst there's no transcoding every participant would need to support VP9/AV1.




How often is that really a problem though?


Codec support is a very annoying issue on mobile. Hardware support for VP9 (let alone AV1) codecs is relatively recent on Android devices, and Apple doesn't provide HW acceleration for Google's codecs at all (or at least not when I was trying to do it).


Android devices in some cases don’t have H264 HW. Libwebrtc also doesn’t support SW H264.

That has added lots of complexity/confusion for people building stuff also. Quite a few footguns in this area :)


If we want to get really pedantic...WebRTC will support SW H264 if you enable it explicitly in the compilation, since you're technically on the hook for royalties if you compile it yourself. Footguns galore :)


> However, it's still a lowest common denominator solution with respect to what codec is being used. The broadcasting "peer" has to send using a codec that every other peer supports. Essentially that means you're stuck with the lowest common denominator codec.

This is correct, though I wouldn't call them "inferior codecs": all WebRTC capable browsers support both H.264 and VP8 as required by the specs.


I would really like to see some projects that leverage SVC, as I haven't seen a single example (and ffmpeg doesn't support them).


I believe Galene does[0] Juliusz was working on pion/RTP for it. You can see all the details here [1]

[0] https://github.com/jech/galene

[1] https://github.com/pion/rtp/blob/master/codecs/vp9_packet.go


Yes, Galene 0.4 and later uses SVC by default when the following conditions are satisfied:

  * the sender is using a Chromium-like browser (the receiver may be Chromium, Firefox or Safari);
  * the codec is either VP8 or VP9;
  * there are at least three users in the group.
You can see a demo at https://galene.org:8443/group/public and https://galene.org:8443/group/public-vp9 (any username, empty password).


Thanks a lot for these pointers!




Consider applying for YC's Spring batch! Applications are open till Feb 11.

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: