How to mix audio samples?

前端 未结 4 455
青春惊慌失措
青春惊慌失措 2020-12-29 13:45

My question is not completely programming-related, but nevertheless I think SO is the right place to ask.

In my program I generate some audio data and save the track

相关标签:
4条回答
  • 2020-12-29 14:23

    I assume your problem is that for every audio source you're adding in, you're having to lower the levels.

    If the app gives control to a user, just let them control the levels directly. Hotness is their responsibility, not yours. This is "summing."

    If the mixing is automated, you're about to go on a journey. You'll probably need compression, if not limiting. (Limiting is an extreme version of compression.)

    Note that anything you do to the audio (including compression and limiting) is a form of distortion, so you WILL have coloration of the audio. Your choice of compression and limiting algorithms will affect the sound.

    Since you're not generating the audio in real time, you have the possibility of doing "brick wall" limiting. That's because you have foreknowledge of the levels. Realtime limiting is more limited because you can't know what's coming up--you have to be reactive.

    Is this music, sound effects, voices, what?

    Programmers here deal with this all the time.

    0 讨论(0)
  • 2020-12-29 14:31

    dirty mix of two samples

    mix = (a + b) - a * b * sign(a + b)
    
    0 讨论(0)
  • 2020-12-29 14:31

    You never said what programming language and platform, however for now I'll assume Windows using C#.

    http://www.codeplex.com/naudio

    Great open source library that really covers off lots of the stuff you'd encounter during most audio operations.

    0 讨论(0)
  • 2020-12-29 14:44

    Mixing audio samples means adding them together, that's all. Typically you do add them into a larger data type so that you can detect overflow and clamp the values before casting back into your destination buffer. If you know beforehand that you will have overflow then you can scale their amplitudes prior to addition - simply multiply by a floating point value between 0 and 1, again keeping in mind the issue of precision, perhaps converting to a larger data type first.

    If you have a specific problem that is not addressed by this, feel free to update your original question.

    0 讨论(0)
提交回复
热议问题