libpeer VS broadcast-box

Compare libpeer vs broadcast-box and see what are their differences.

libpeer

WebRTC Library for IoT/Embedded Device using C (by sepfy)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
libpeer broadcast-box
11 10
775 524
- 5.3%
8.1 8.9
5 months ago 3 days ago
C Go
MIT License MIT License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

libpeer

Posts with mentions or reviews of libpeer. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-19.
  • VoRS: Vo(IP) Simple Alternative to Mumble
    15 projects | news.ycombinator.com | 19 Apr 2024
  • Pure C WebRTC
    12 projects | news.ycombinator.com | 7 Jan 2024
    I am really excited about https://github.com/sepfy/libpeer. It has examples ready for ESP32 etc....

    When working on KVS I wasn't familiar with the embedded space at all. I saw 'heavyweight' embedded where you were running on Linux. Then you had RTOS/No OS at all. I wasn't prepared for these devices at all. If we can make WebRTC work in the embedded space I think it will really accelerate what developers are able to build!

    Remotely driven cars, security cameras, robots in hospitals that bring iPads to infectious patients etc... Creative people are building amazing things. The WebRTC/video space needs to work harder and support them :)

    -----

    I love how diverse the WebRTC space is now. Outside of this implementation you have plenty of other options!

    * https://github.com/shinyoshiaki/werift-webrtc (Typescript)

    * https://github.com/pion/webrtc (Golang)

    * https://github.com/webrtc-rs/webrtc (Rust)

    * https://github.com/algesten/str0m (Rust)

    * hhttps://github.com/sepfy/libpeer (C/Embedded)

    * https://webrtc.googlesource.com/src/ (C++)

    * https://github.com/sipsorcery-org/sipsorcery (C#)

    * https://github.com/paullouisageneau/libdatachannel (C++)

    * https://github.com/elixir-webrtc (Elixir)

    * https://github.com/aiortc/aiortc (Python)

    * GStreamer’s webrtcbin (C)

    See https://github.com/sipsorcery/webrtc-echoes for examples of some running against each other.

  • WebRTC for the Curious
    18 projects | news.ycombinator.com | 4 Jan 2024
  • Show HN: Bring phone calls into the browser (sip-to-WebRTC)
    9 projects | news.ycombinator.com | 4 Jan 2024
  • Drop packet
    1 project | /r/WebRTC | 25 May 2023
    I am experimenting based on the pear project (https://github.com/sepfy/pear) and using the clumsy tool to simulate the case of dropping packets.
  • Pear - A WebRTC Toolkit for IoT/Embedded Devices (a work-in-progress)
    1 project | /r/C_Programming | 8 Apr 2021
  • Hacker News top posts: Apr 8, 2021
    6 projects | /r/hackerdigest | 8 Apr 2021
    A simple C implementation to stream H.264 to browser using WebRTC\ (61 comments)
  • A simple C implementation to stream H.264 to browser using WebRTC
    1 project | /r/patient_hackernews | 8 Apr 2021
    1 project | /r/hackernews | 8 Apr 2021
    6 projects | news.ycombinator.com | 7 Apr 2021
    I think there's some truth in what as-j is saying. Rust binaries (and C++ ones) tend to be larger than C ones. I think the major reasons are (a) Rust dependencies being statically linked due to a lack of ABI stability, (b) inclusion of portions of the (statically linked, see a) Rust standard library used by the program where C code uses libc, (c) code bloat due to monomorphization, (d) the ease of just using a full-featured library where someone writing in C might cheat a little bit. As an example of what I mean by the last point, see sdp_attribute_get_answer in this codebase. [1] It's writing JSON, but it doesn't use a JSON library that actually escapes the included string. It just assumes the included string doesn't have a quote character in it. Is that assumption valid? Will it always be valid? I'm not sure on quick inspection.

    There are ways around all of these:

    * a. Static vs dynamic linkage: in an embedded system, it'd be reasonable to just produce a single userspace binary that does everything. It can change its behavior based on argv[0]. I think this is not too unusual for constrained systems even with C binaries. Eg busybox does it. If you only have one binary, you don't need dynamic linking. Also, I think it's not strictly true that Rust doesn't support dynamic linking. I think you can dynamically link everything if you ensure the whole system is built with the same compiler version.

    * b. Standard library. You don't have to use it at all, or you can use it sparingly, paying only for what you use.

    * c. Monomorphization. You could write (for example) a Go-like map [2] rather than relying so heavily on monomorphization. I'd love to see someone take this idea as far as possible; it might be a good idea for a lot of non-inner-loop code in general, not just on tight embedded systems.

    * d. Using full-featured libraries. Obviously no one is making you do this; the same cheats available in C are available in Rust.

    but in fairness, the further you go down this path, the further you are from just being able to just take advantage of the whole Rust ecosystem.

    Personally, I'd still rather develop or use a #![no_std] Rust codebase than a C one. Memory safety is important to me. IOT devices are no exception to that. Their security is historically horrible but I'd like to change that.

    [1] https://github.com/sepfy/pear/blob/b984c8dccaafdcdd1b181786a...

    [2] https://dave.cheney.net/2018/05/29/how-the-go-runtime-implem...

broadcast-box

Posts with mentions or reviews of broadcast-box. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-01-04.
  • Show HN: Bring phone calls into the browser (sip-to-WebRTC)
    9 projects | news.ycombinator.com | 4 Jan 2024
    > [1] https://github.com/Glimesh/broadcast-box

    This is really interesting! Any latency benchmarks comparing it to gstreamer UDP, P2P primarily?

  • OBS Studio 30.0
    2 projects | news.ycombinator.com | 11 Nov 2023
    This release includes WebRTC support. I would really appreciate if people could try it! I have so many things I want to improve with broadcasting.

    ——

    * Serverless Streaming - WebRTC is P2P so you can video right into your browser. You don’t have to stand up a server anymore to stream for a small audience.

    * Sub-Second Latency - Create content and interact with viewers instantly. There is something magical about having a real conversation with your viewers.

    * Multitrack Input - Upload your transcodes instead of generating then server side. Give viewers multiple video tracks to see action from all sides.

    * Mobility - WebRTC lets you switch networks at any time. Go from WiFi -> Mobile with zero interruptions.

    * E2E Authentication - WebRTC lets you add authentication on the sender and receiver. Broadcasters could sign their video streams so viewers can be sure it wasn’t modified.

    Try it out with Broadcast Box. A reference server implementation. https://github.com/glimesh/broadcast-box

  • Show HN: AV1 Broadcasting from OBS
    2 projects | news.ycombinator.com | 14 Aug 2023
    This is a PR (with builds) to add AV1 support to the WebRTC output from OBS.

    We also have been working on a reference server implementation with https://github.com/Glimesh/broadcast-box/ to make it easy to self host.

  • Show HN: OBS with Simulcast Support
    3 projects | news.ycombinator.com | 12 Jul 2023
    Simulcast builds of OBS are available. Simulcast is when a client generates multiple encodes of a video. Testers and feedback would be greatly appreciated!

    Design Discussion: https://github.com/obsproject/rfcs/pull/55

    Use it against your favorite WHIP ingest. If you don't have one check out https://github.com/glimesh/broadcast-box. It is a reference implementation of a WHIP/WHEP server.

    I hope/believe the impact of this will be much greater then WebRTC. This could benefit all broadcast workflows.

    * Higher Quality Videos - Decoding and re-encoding causes quality loss. Generating all the renditions from the source video is going to be a big improvement for viewers.

    * Lower Latency - Removing the additional encoding/decoding allows video to be delivered faster.

    * Reduce complexity - With Simulcast setting up a streaming server becomes dramatically easier. It is much easier for an individual to afford and manage a single broadcast server. RTMP -> Transcode -> HLS gets complicated and expensive quickly.

  • OBS merges WebRTC support
    2 projects | /r/linux_gaming | 11 Jun 2023
    One of the devs commented on HN that you can use Broadcast Box handle the initial connection. That's open source so you can self-host that too
  • OBS Merges WebRTC Support
    3 projects | /r/WebRTC | 10 Jun 2023
    Try it out today with Broadcast Box. A reference server implementation. https://github.com/glimesh/broadcast-box. The PR to add WebRTC to OBS https://github.com/obsproject/obs-studio/pull/7926
    7 projects | news.ycombinator.com | 10 Jun 2023
    I don't have an idea on how to do cascading OBS instances. I should write some software to make this easy though. I want to make 'self hosting' as easy as possible. I think https://github.com/glimesh/broadcast-box will fill that gap for now.

    For my own usage I run WebRTC servers and have them 'replicate' the video traffic. LiveKit did a write up on this with some good graphics https://blog.livekit.io/scaling-webrtc-with-distributed-mesh...

  • WebRTC support being added to FFmpeg
    6 projects | news.ycombinator.com | 30 May 2023
    I am really excited for this PR to land. Being able to use WebRTC for Broadcast and Playback is going to be huge.

    Instead of doing fixed interval keyframe we can use receiver feedback (Massive reduction in bandwidth)

    Instead of server side generated transcodes we can use Simulcast. Will be better quality AND massively reduced server load.

    If anyone wants to use with Pion check out https://github.com/Glimesh/broadcast-box

    Then run `ffmpeg -re -f lavfi -i testsrc=s=1280x720:r=30 -f lavfi -i sine=f=440:b=4 -vcodec libx264 -pix_fmt yuv420p -profile:v baseline -r 25 -g 50 -acodec libopus -ar 48000 -ac 2 -f rtc -authorization "STREAM_NAME" "http://localhost:8080/whip"

What are some alternatives?

When comparing libpeer and broadcast-box you can also consider the following projects:

libdatachannel - C/C++ WebRTC network library featuring Data Channels, Media Transport, and WebSockets

go2rtc - Ultimate camera streaming application with support RTSP, RTMP, HTTP-FLV, WebRTC, MSE, HLS, MP4, MJPEG, HomeKit, FFmpeg, etc.

openmiko - Open source firmware for Ingenic T20 based devices such as WyzeCam V2, Xiaomi Xiaofang 1S, iSmartAlarm's Spot+ and others.

str0m - A synchronous sans I/O WebRTC implementation in Rust.

tiny-webrtc-gw - tiny/fast webRTC video conferencing gateway

ffmpeg - FFmpeg Zig package

spchcat - Speech recognition tool to convert audio to text transcripts, for Linux and Raspberry Pi.

webrtc-for-the-curious - WebRTC for the Curious: Go beyond the APIs

cpufetch - Simple yet fancy CPU architecture fetching tool

webrtc-echoes - Simple useful interoperability tests for WebRTC libraries. If you are a WebRTC library developer we'd love to include you!

Ory Keto - Open Source (Go) implementation of "Zanzibar: Google's Consistent, Global Authorization System". Ships gRPC, REST APIs, newSQL, and an easy and granular permission language. Supports ACL, RBAC, and other access models.

rfcs - RFCs for changes to OBS Studio (and supporting toolset)