aboutsummaryrefslogtreecommitdiffstats
path: root/Alc/effects
Commit message (Collapse)AuthorAgeFilesLines
* Don't assume the "real" output buffer follows the dry bufferChris Robinson2016-05-171-15/+44
|
* Improve reverb panning gains for "3D" output.Chris Robinson2016-05-171-8/+8
|
* Get rid of an unnecessary copy of ALeffectPropsChris Robinson2016-05-1311-55/+54
|
* Hold the effect and filter maps while handling effects and filtersChris Robinson2016-05-121-8/+0
|
* Provide (mostly) lockless updates for effect slotsChris Robinson2016-05-1211-67/+83
| | | | | | | | | | | | | | | | | Similar to the listener, separate containers are provided atomically for the mixer thread to apply updates without needing to block, and a free-list is used to reuse container objects. A couple things to note. First, the lock is still used when the effect state's deviceUpdate method is called to prevent asynchronous calls to reset the device from interfering. This can be fixed by using the list lock in ALc.c instead. Secondly, old effect states aren't immediately deleted when the effect type changes (the actual type, not just its properties). This is because the mixer thread is intended to be real-time safe, and so can't be freeing anything. They are cleared away when updates reuse the container they were kept in, and they don't incur any extra processing cost, but there may be cases where the memory is kept around until the effect slot is deleted.
* Improve radius behavior with scaling of ambisonic coefficientsChris Robinson2016-04-245-15/+21
|
* Don't look up the dry buffer's FrontCenter in the Dedicated effectChris Robinson2016-04-161-8/+4
| | | | | | The real FrontCenter output is used if it exists, and if it doesn't, it's unlikely the dry buffer will have it (and even if it does, it won't be any better than panning).
* More directly map coefficients for ambisonic mixing buffersChris Robinson2016-04-1510-44/+26
| | | | | | Instead of looping over all the coefficients for each channel with multiplies, when we know only one will have a non-0 factor for ambisonic mixing buffers, just index the one with a non-0 factor.
* Avoid mixing all coefficients together when only some are usedChris Robinson2016-04-155-21/+31
|
* Use the 3D panned output for reverb with HQ decodingChris Robinson2016-03-311-3/+3
| | | | | | This is less than ideal, but matching each reverb line to a speaker with surround sound output is way too loud without the ambient volume scaling offered by the "direct" panning.
* Include any first-order scaling in the FOAOut coefficientsChris Robinson2016-03-253-16/+12
|
* Mix Dedicated effects to the real output if possibleChris Robinson2016-03-251-6/+21
|
* Add a specific output for first-order sourcesChris Robinson2016-03-223-3/+12
|
* Add a workaround for a buggy modffChris Robinson2016-03-181-0/+15
|
* Make sure enough reverb panning gains are definedChris Robinson2016-03-161-4/+4
|
* Add a dual-band ambisonic decoderChris Robinson2016-03-151-8/+12
| | | | | | | | | | This uses a virtual B-Format buffer for mixing, and then uses a dual-band decoder for improved positional quality. This currently only works with first- order output since first-order input (from the AL_EXT_BFROMAT extension) would not sound correct when fed through a second- or third-order decoder. This also does not currently implement near-field compensation since near-field rendering effects are not implemented.
* Generalize GetChannelIdxByNameChris Robinson2016-03-101-2/+2
|
* Allocate enough reverb panning gainsChris Robinson2016-03-101-2/+6
|
* Organize the dry buffer properties into a structChris Robinson2016-03-0910-32/+40
|
* Track the virtual and real output buffers ecplicitlyChris Robinson2016-03-091-15/+21
|
* Fix reverb with UHJ encodingChris Robinson2016-03-031-1/+1
|
* Use 2-channel UHJ for stereo outputChris Robinson2016-02-261-6/+6
|
* Remove a dead assignmentChris Robinson2016-02-161-1/+0
|
* Add special HRTF handling for reverbChris Robinson2016-02-061-1/+77
| | | | | | | This is pretty hacky. Since HRTF normally renders to B-Format with two "extra" channels for the real stereo output, the panning interpolates between a panned reverb channel on B-Format, and two non-panned reverb channels on stereo output, given the panning vector length.
* Only apply the +3dB reverb gain boost to the ambient response.Chris Robinson2016-02-061-2/+1
|
* Avoid an extra sample of delay in the reverb modulatorChris Robinson2016-02-051-4/+6
|
* Remove an unnecessary variable and move duplicate code to a common spotChris Robinson2016-02-051-37/+23
|
* Don't explicitly check for LFEChris Robinson2016-02-051-16/+0
| | | | It's going to be set to 0 gain anyway
* Boost the direct-pan reverb to better match the expected volumeChris Robinson2016-02-051-0/+2
| | | | | Hopefully. Would be nice to have a reference implementation for this style of reverb to compare with.
* Update a couple outdated commentsChris Robinson2016-02-051-3/+1
|
* Apply the early and late reverb gains with the panning gainsChris Robinson2016-02-051-26/+28
|
* Better organize the reverb code into separate labeled sectionsChris Robinson2016-02-051-425/+442
|
* Separate early and late reverb output for standard reverb tooChris Robinson2016-02-051-33/+27
|
* Modify how the four output reverb points are calculatedChris Robinson2016-02-051-40/+62
| | | | | For HRTF and B-Format output, the points no longer move but instead scale based on the desired panning direction.
* Try to map reverb outputs directly to output channelsChris Robinson2016-02-011-2/+77
| | | | | | | | | HRTF and B-Format output still need to use virtual panning directions, but the reverb works better when it outputs directly to an output channel. Ambient and directional panning is used to properly mask and attenuate each output channel. Note that currently the "direct panning" output is quieter than it should be. Work is underway to attenuate the early reflections and late reverb better.
* Apply the main reverb gain with the panningChris Robinson2016-02-011-13/+12
|
* Fix an out of date commentChris Robinson2016-01-311-4/+2
|
* Rename ComputeBFormatGains to ComputeFirstOrderGainsChris Robinson2016-01-313-6/+6
|
* Make the modulator effect multichannelChris Robinson2016-01-291-22/+41
|
* Use separate modulator functions only for the waveformChris Robinson2016-01-291-56/+42
|
* Convert the equalizer effect to multichannelChris Robinson2016-01-291-33/+90
|
* Make the compressor effect multichannelChris Robinson2016-01-281-25/+58
|
* Pass a pointer to the input samples array for effect processingChris Robinson2016-01-2711-27/+27
|
* Separate calculating ambisonic coefficients from the panning gainsChris Robinson2016-01-2511-35/+47
|
* Reorder filterstate propertiesChris Robinson2016-01-232-19/+18
|
* Don't overwrite the output with the dedicated effectChris Robinson2015-12-121-1/+1
|
* Simplify reverb panning rotationsChris Robinson2015-11-071-4/+4
|
* Pan each early/late delay line separatelyChris Robinson2015-11-051-56/+70
|
* Remove an unneeded memset that was overwriting memoryChris Robinson2015-11-051-2/+0
|
* Pass in the Q parameter for setting the filter parametersChris Robinson2015-11-014-21/+36
| | | | Also better handle the peaking filter gain.