Cool video man. It may be a good idea to also add some type of frequency up-rate or down-rate function option in case players in the future want to have a mod specific to speeding up charts without losing audio quality.
*Writing an Audio Engine from Scratch in C++ with OpenAL* * *0:40** OpenAL Introduction:* Explains the reasons for switching from SDL_mixer to OpenAL, emphasizing its lightweight nature, similarity to OpenGL, and targeted functionality. * *1:51** OpenAL Core Concepts:* Introduces the three main OpenAL objects: Listener (single audio perspective), Sources (emit audio), and Buffers (store audio data), and how they interact in 3D space. * *2:41** Singleton Class Implementation:* Describes the use of a Singleton class to manage OpenAL initialization and shutdown, ensuring a single audio engine instance. * *2:56** WAV Loading:* Outlines the process of loading WAV files, either individually or using a directory iterator to load all files within a folder. * *3:30** Sound Effect Playback:* Explains the steps to play a sound effect using OpenAL: creating a source, configuring it, attaching a buffer, and initiating playback. * *3:40** Sound Effect Cleanup:* Discusses the need to clean up sources and buffers after sound effects finish playing, using state polling within a loop to determine when to release resources. * *4:01** Multithreading for Sound Management:* Introduces the concept of multithreading to handle sound effect cleanup in the background, preventing blocking of the main game loop. * *5:03** Thread-Safe Implementation:* Highlights the importance of thread safety in multithreaded audio engines to avoid data corruption. Discusses the use of atomic operations and mutexes to ensure safe concurrent access to shared data. * *6:38** Music Streaming:* Explains the need for streaming music from disk instead of loading entire files into memory, emphasizing the efficiency gains for large music files. * *7:29** Music Playback Control:* Describes the implementation of playback controls (pause, play, stop) and seeking to specific points within a music track. * *8:05** Data Alignment Considerations:* Emphasizes the importance of maintaining proper data alignment when seeking within music files to avoid audio distortion. * *8:28** Multithreading for Music Management:* Mentions the use of multithreading for managing active music players, similar to the approach used for sound effects. * *8:44** Level Editor Plans:* Outlines the next steps in the game's development, focusing on a level editor with tap/hold functionality and custom decoration systems. I used gemini-1.5-pro-exp-0827 on rocketrecap dot com to summarize the transcript. Cost (if I didn't use the free tier): $0.02 Input tokens: 14575 Output tokens: 502
Thanks for the insights. Not sure how efficient the multithreaded structure is if your poll rate is around 200 times per second and it locks the entirety of the audio manager data for the poll update via mutex. Like if you have a game engine type of update loop at some 120 tps that needs to access audio you will have to synchronize with the audio loop every single time. Just the amount of potential interlocking is insane and I don't know how to fix any of it. Because with an update rate of 60Hz you get around 16 ms of potential latency if you poll in the same thread, while with a separate thread you get ridiculous amounts of resource fighting which will impact not just the audio but the main thread as well, which is even worse.
A partial solution would be to have more fine-grained locks and double buffer queues for commands towards the Audio engine that the main thread will write to and the audio thread will process only when needed, but this still doesn't solve the issue of accessing the audio resources concurrently, since pretty much ALL of them need to be locked during the audio update call.
Here before this is big lol, keep the grindset my friend u have heaps of potential
Cool video man. It may be a good idea to also add some type of frequency up-rate or down-rate function option in case players in the future want to have a mod specific to speeding up charts without losing audio quality.
Great stuff, very educational. Keep it up! 🔥
Long time no see 👀
*Writing an Audio Engine from Scratch in C++ with OpenAL*
* *0:40** OpenAL Introduction:* Explains the reasons for switching from SDL_mixer to OpenAL, emphasizing its lightweight nature, similarity to OpenGL, and targeted functionality.
* *1:51** OpenAL Core Concepts:* Introduces the three main OpenAL objects: Listener (single audio perspective), Sources (emit audio), and Buffers (store audio data), and how they interact in 3D space.
* *2:41** Singleton Class Implementation:* Describes the use of a Singleton class to manage OpenAL initialization and shutdown, ensuring a single audio engine instance.
* *2:56** WAV Loading:* Outlines the process of loading WAV files, either individually or using a directory iterator to load all files within a folder.
* *3:30** Sound Effect Playback:* Explains the steps to play a sound effect using OpenAL: creating a source, configuring it, attaching a buffer, and initiating playback.
* *3:40** Sound Effect Cleanup:* Discusses the need to clean up sources and buffers after sound effects finish playing, using state polling within a loop to determine when to release resources.
* *4:01** Multithreading for Sound Management:* Introduces the concept of multithreading to handle sound effect cleanup in the background, preventing blocking of the main game loop.
* *5:03** Thread-Safe Implementation:* Highlights the importance of thread safety in multithreaded audio engines to avoid data corruption. Discusses the use of atomic operations and mutexes to ensure safe concurrent access to shared data.
* *6:38** Music Streaming:* Explains the need for streaming music from disk instead of loading entire files into memory, emphasizing the efficiency gains for large music files.
* *7:29** Music Playback Control:* Describes the implementation of playback controls (pause, play, stop) and seeking to specific points within a music track.
* *8:05** Data Alignment Considerations:* Emphasizes the importance of maintaining proper data alignment when seeking within music files to avoid audio distortion.
* *8:28** Multithreading for Music Management:* Mentions the use of multithreading for managing active music players, similar to the approach used for sound effects.
* *8:44** Level Editor Plans:* Outlines the next steps in the game's development, focusing on a level editor with tap/hold functionality and custom decoration systems.
I used gemini-1.5-pro-exp-0827 on rocketrecap dot com to summarize the transcript.
Cost (if I didn't use the free tier): $0.02
Input tokens: 14575
Output tokens: 502
Doing this right now but with WASAPI. Also awesome video, instant sub
will there be more devlogs??? this is really cool
Thanks for the insights. Not sure how efficient the multithreaded structure is if your poll rate is around 200 times per second and it locks the entirety of the audio manager data for the poll update via mutex. Like if you have a game engine type of update loop at some 120 tps that needs to access audio you will have to synchronize with the audio loop every single time. Just the amount of potential interlocking is insane and I don't know how to fix any of it. Because with an update rate of 60Hz you get around 16 ms of potential latency if you poll in the same thread, while with a separate thread you get ridiculous amounts of resource fighting which will impact not just the audio but the main thread as well, which is even worse.
A partial solution would be to have more fine-grained locks and double buffer queues for commands towards the Audio engine that the main thread will write to and the audio thread will process only when needed, but this still doesn't solve the issue of accessing the audio resources concurrently, since pretty much ALL of them need to be locked during the audio update call.
OMG what's going on, I was looking for this type of content *-* how did you learn all of this? Btw you're great man.
imma be honest using openAL is not making your own audio engine from scratch but ok
how else would you do it then
@mazazaza11 you can also just call it abstration layer lmao
solid video, shame you havent uploaded since