-
Notifications
You must be signed in to change notification settings - Fork 151
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Oto v2.0 has been release :) #128
Comments
Some notes:
I may be wrong on some things here. There are a lot of small details to oversee. I would like to hear other people's thoughts/wishes on this as well. I may try to implement Oto 2 with Beep. If it takes too long, feel free to work on this yourself. I can't spend loads of time on the computer right now. |
Wow, really thorough review of the Oto release. Thanks @MarkKremer! I'm surprised to see there are additional delays with the new API, seeing as @hajimehoshi is also the author of Ebiten and use Oto for game development themselves. @hajimehoshi would you be able to help us clarify the performance improvements you've seen with the new release with regards to games? Also, have you seen any issues with delays as mentioned above? Thanks for working on this! Both Oto and Beep are really great for game development in Go :) Cheers, |
I want to clarify a bit. The problem is with how Beep and Oto work(ed) together. Oto basically has its own mixer that adds samples of each player together. Each player has a big buffer (which is good because you don't want to run out of samples). It's just that if we add our own mixer in front of it that that we have to wait for all samples currently in the buffer to be played before any new samples are played if we add a new streamer. I think this could actually work out quite nicely, but we have to make some changes on our end. :) Great work @hajimehoshi and contributors! I haven't tested it yet but having each player buffer individually and then combining the buffers once the platform-specific code requests it seems promising. |
Hi,
I don't think so. It depends on environments, but the audio library's buffer size should be very much smaller. The delay is determined by the audio library's buffer size, not by Oto players' buffer sizes. For example, on macOS, OS's buffer size is 2048 [bytes] (= 0.005 [s] in 48000 [Hz] stereo) https://github.com/hajimehoshi/oto/blob/main/driver_macos.go
EDIT: From this, you can no longer update your data at io.Reader in real time, as the data change is reflected 0.5[s] after its change. I think this might require to change the current Beep's implementation.
I've not realized any additional delays. Rather, v2 should improve latencies especially on Android. Please inform me if you find actual delays. I appreciate all the contributions. Thanks, |
Ah right, if you do mixing on your side, the buffer sizes of Oto's players would matter. |
I've made a first draft. Some notes:
Besides that, I'm still working on updating the examples to use the new speaker and make use of the player where useful. |
Incredible work @MarkKremer! Excited to take it for a spin, will be great to see if this gives performance improvements in a game I'm playing with. Had some issues with delays a while back. |
Hey, sorry for arriving to this issue so late, thanks @MarkKremer for working on this, it would be great to update to the new Oto. However, I have to stress that the philosophy of Beep has to be kept in tact. To spell it out concretely, I think this is one of the fundamental pillars of Beep's philosophy:
Why is this important? Several reasons:
Now, as @hajimehoshi said, if we do our own mixing (and we do!), then Oto's buffer size starts to matter because of latency. If this is still true, then I'm not sure we can upgrade because low latency is important in games and is actually one of the great features of Beep. This needs to be resolved before updating. Anyway, thanks for the great work, I just wanted to clarify this. |
You could argue that we can of course still do our own mixing in software, but if we want latency-free playback, then we have to fall back on Oto's capabilities. This is also not good. If we have two methods of mixing and one of them is latency-free but not composable, and the other one introduces latency but composes well, then we simply have two methods which are both bad. |
For example, what about letting an Oto's player have a callback function that is called just before pushing bytes/floats to the drivers? It's just like Audio Worklet or ScriptProcessorNode and you would be able to modify bytes/floats in real time. |
@hajimehoshi Yes, that would be great! Btw, I think with this functionality, it would be possible to upgrade to Oto 2 without breaking any backwards compatibility, which would be ideal. |
Actually, without changing any of Beep's API. |
OK let me think. The implementation should not be difficult. Of course, I welcome your designs and/or PRs! |
Although now that I think about it, I'm not sure this would be sufficient. We would be able to modify the samples right before pushing, but you would still push 1/2s or 1/4s of samples at once, meaning the next batch of samples could only be added/modifies after this time has passed. This would still keep the latency there. |
This might be extreme, but would using 'zero' |
That would be the idea, but it would only work if the callback was called many times per second. In fact, the latency would be precisely proportional to that number (called N times per second implies latency of 1/N seconds). Would that be possible? |
Yeah for example calling the callback for each 100 samples = 480 times per second for 48000 Hz would be feasible. |
Yeah, 480 is way more than enough :D Even 16 is probably enough for games. But just to clarify, this would actually make it possible to change the contents of the buffer in such a way that if the speaker is currently playing some sample and I modify a sample that's 1/480 of a second before in the buffer, the speaker would actually end up playing the modified samples when it gets to that point? |
There is still a small delay due to the low level drivers, OSes, and so on. I set these buffer sizes as small as possible on Oto v2, but still there are. |
I'll be afk soon. See you later :-) |
See ya! Hope we can resolve this eventually! |
@hajimehoshi so without the buffer between Beep and the driver code, any guesses on how fast the callback has to respond before it glitches? I had the idea of creating a buffer streamer. Not like the one currently in Beep but more like how Oto buffers the audio: keep 0.5-1sec of audio buffered so it can provide samples quickly and when the buffer gets drained, fill it up with more samples. Having the buffer as a streamer makes it composable again:
I have some thoughts about this but I would like to hear what @faiface thinks about this first. If people have more/different ideas, I'd love to hear them. |
I think you meant how much internal buffers Oto's drivers have. This depends on environments. In the current implementations: Android: ? (this depends on the returning value of Note: Samples are represented in float32 in most cases. |
Quick heads up: ebitengine/oto#160 has finally derived into hajimehoshi re-adding configurable buffer sizes in Oto, in case you want to start experimenting with it. The performance and latency is extremely similar to what could already be achieved with |
Any updates? |
If Oto v2 would not be used in Beep, it would be worthless to keep backward compatibility of Oto's public APIs. I'd plan to freeze the project of Oto (v2), and move Oto as an internal package in Ebitengine. |
Oto is tremendously useful as it's the main Go package to give cross-platform audio playback. @hajimehoshi, please keep Oto as an external package. It is used also outside of Beep and it's a really useful package. With kindness, |
re: #128 (comment)
@MarkKremer I know you've been working on this. Do you still have your draft work for using Oto v2.0 in Beep? Cheerful regards, |
I just pushed whatever I had locally: master...MarkKremer:beep:master Something something long time ago disclaimer 😄 |
Beep is much more widely used than Oto v2. https://pkg.go.dev/github.com/faiface/beep?tab=importedby https://github.com/search?l=Go&q=%22git.luolix.top%2Fhajimehoshi%2Foto%2Fv2%22&type=Code (66 files Oto v2) vs https://github.com/search?l=Go&q=%22git.luolix.top%2Ffaiface%2Fbeep%22&type=Code (1116 files for Beep) So I thought the impact by stopping maintaining Oto v2 would be limited. That's one of the reasons why I'd stop maitaining Oto v2 as long as Beep didn't use Oto v2. What do you think? |
Yeah, that makes sense. Maintain the version of Oto that is supported by Beep. So when Beep does get support for Oto v2, then switch to supporting v2 instead. |
Note that Oto v1 and older is no longer maintained. |
Ah, ok. Good to know. I would love to see Oto v2 support added to Beep, as it's the main audio playback for Go. I don't know how far away #130 is from being ready for merge. Anyone care to take a look who knows more about Beep and Oto internals? : ) Cheers, |
Last year I had trouble getting the example in my PR to run stably. I think I just found a bug in Oto which may have caused some (but not all?) of the problems. As you can see I've made an issue there. My PR contains some other stuff which isn't in line with Beep's philosophy of having composable elements (see faiface's comment). Some of which should be removed/changed. Then figure out if the example can be made working again & update docs and other examples. |
Really happy to see you've found an underlying issue! Great job : )
Thanks for providing more background on the current state of the PR. This also enables others to help out, e.g. to test the example code and such. Excited to see cross platform audio playback in Go receive love from many different people! Cheers, |
I updated my PR with a more minimum viable product version of the speaker so we can get to Oto v2 sooner. I kept the mixer on our end and removed my other additions which aren't strictly necessary. It is backwards compatible I think. If anyone is curious, I moved my original version to here. The speedy player example seems to work great except that it doesn't like to share audio playback with other programs on my laptop. But that could be because it uses the hardware driver or something which is documented somewhere. Next steps in no particular order:
|
Thanks for doing the work @MarkKremer and updating your PR! I'll be excited to test this out on our little game project as soon as I'm through the exam period at Uni : ) Should be in about one week. Cheerful regards, Edit: I couldn't wait, so I tested your PR (#130) and it works like a charm! |
PR is ready for review. I did add some comments. |
That's great! I don't know the ins and outs of the beep nor oto implementations, so I I can't address some of the comments (e.g. ignore errors, close of context, etc). The parts I do know in beep are related to FLAC decoding : ) However, as mentioned in #128 (comment), using #130 worked great on my end (using Linux). So at least, that's a Cheers, Oh, and thanks a lot for working on this! Both @MarkKremer, @hajimehoshi and everyone else involed ❤️ |
I think I'll release Oto v3 this year in order to clean up the API. |
Hi, @hajimehoshi , I loved beep project and started using it. Thanks!!! |
Hi, I'm not the author of beep. Please ask the author :-) |
Right, I misunderstood based on your previous comment :) |
Mirroring @hajimehoshi comment in this issue, so it's not missed (ref: #130 (comment))
I know @faiface stepped down as maintainer of the pixel and beep projects. Who took his place I do not know. Anyone with more information, please let us know : ) And of course, it would be great to see oto v3 in beep. But as a prerequisite, there should be some kind of maintenance plan for beep. Hope we can keep this amazing project alive as it has together with oto simplified cross-platform audio playback a lot. Cheerful regards, |
I've kindly spammed @faiface through the number of channels I could find (please forgive me Michal). If you happen to read this, please contact me. I would like to help you out with coming up with a maintenance plan for Beep. 🙏 |
I haven't been able to contact him but the Pixel people are working on forks for all his projects including Beep. I assume they will add a notice to this repo when it's time. For now the Pixel2 Discord is probably a good channel if you want the newest information. |
Oto v2.0 was just released :) https://github.com/hajimehoshi/oto/releases/tag/v2.0.0
This issue tracks the work to update beep to use the latest version of Oto, bring with it performance increases.
The text was updated successfully, but these errors were encountered: