Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Store the HRTF's filename separate from the entry storage | Chris Robinson | 2017-04-05 | 2 | -48/+72 |
| | |||||
* | Rename al_string_* functions to alstr_* | Chris Robinson | 2017-04-04 | 23 | -350/+348 |
| | |||||
* | Recognize %-encoded characters for config section names | Chris Robinson | 2017-04-01 | 1 | -1/+55 |
| | |||||
* | Remove a couple unused macros | Chris Robinson | 2017-04-01 | 1 | -18/+0 |
| | |||||
* | Don't rely on sizeof being the offset to a struct's unsized array | Chris Robinson | 2017-04-01 | 1 | -2/+3 |
| | |||||
* | Constify a variable | Chris Robinson | 2017-04-01 | 1 | -3/+3 |
| | |||||
* | Make a pointer restrict and assume aligned | Chris Robinson | 2017-04-01 | 1 | -1/+1 |
| | |||||
* | Avoid some unnecessary string reallocation | Chris Robinson | 2017-03-31 | 1 | -51/+50 |
| | |||||
* | Convert float samples to integer using a power-of-2 multiple | Chris Robinson | 2017-03-31 | 1 | -13/+9 |
| | |||||
* | Convert integer samples to float using a power-of-2 divisor | Chris Robinson | 2017-03-31 | 1 | -2/+2 |
| | | | | | | | This should cut down on unnecessary quantization noise (however minor) for 8- and 16-bit samples. Unfortunately a power-of-2 multiple can't be used as easily for converting float samples to integer, due to integer types having a non- power-of-2 maximum amplitude (it'd require more per-sample clamping). | ||||
* | Load HRTF coefficients as pre-normalized floats | Chris Robinson | 2017-03-31 | 2 | -39/+48 |
| | |||||
* | Combine some HRTF loading code | Chris Robinson | 2017-03-31 | 1 | -78/+72 |
| | |||||
* | Use the correct types' sizes for HRTF storage | Chris Robinson | 2017-03-31 | 1 | -8/+8 |
| | |||||
* | Make ReleaseContext return if any contexts still remain | Chris Robinson | 2017-03-28 | 1 | -10/+25 |
| | |||||
* | Use an array of pointers for effects instead of a linked list | Chris Robinson | 2017-03-27 | 2 | -20/+26 |
| | |||||
* | Fix HRTF interpolated gain calculation | Chris Robinson | 2017-03-26 | 1 | -2/+2 |
| | |||||
* | Use a loop to apply NFC filters | Chris Robinson | 2017-03-25 | 1 | -30/+15 |
| | |||||
* | Use ALsizei for more index lookups | Chris Robinson | 2017-03-24 | 1 | -15/+15 |
| | |||||
* | Properly calculate the echo damping | Chris Robinson | 2017-03-24 | 1 | -1/+1 |
| | |||||
* | Fix setting Ambi formats for loopback devices | Chris Robinson | 2017-03-21 | 1 | -1/+1 |
| | |||||
* | Use an atomic flag to test if a source needs to update | Chris Robinson | 2017-03-20 | 1 | -1/+1 |
| | |||||
* | Make DataPosInt an ALsizei | Chris Robinson | 2017-03-20 | 1 | -15/+16 |
| | |||||
* | Use proper bools for boolean states | Chris Robinson | 2017-03-20 | 1 | -12/+11 |
| | |||||
* | Don't defer source state or offset changes | Chris Robinson | 2017-03-19 | 1 | -32/+3 |
| | |||||
* | Fix alcGetInteger64vSOFT to handle ambisonic attributes | Chris Robinson | 2017-03-18 | 1 | -14/+28 |
| | |||||
* | Replace a couple ALuint with ALsizei | Chris Robinson | 2017-03-17 | 1 | -2/+2 |
| | |||||
* | Fix NFC filter to set the correct center frequency | Chris Robinson | 2017-03-16 | 1 | -13/+9 |
| | |||||
* | Increase the filter slope to -12dB/octave | Chris Robinson | 2017-03-16 | 2 | -9/+9 |
| | |||||
* | Check usability of MixHrtf_Neon before MixHrtf_SSE | Chris Robinson | 2017-03-14 | 1 | -4/+4 |
| | |||||
* | Remove a couple unneeded typedefs | Chris Robinson | 2017-03-14 | 1 | -23/+25 |
| | |||||
* | Store the HRIR coeff pointer and delays directly in MixHrtfParams | Chris Robinson | 2017-03-12 | 3 | -7/+12 |
| | |||||
* | Rework HRTF coefficient fading | Chris Robinson | 2017-03-11 | 9 | -263/+96 |
| | | | | | | | | | | | | | | | This improves fading between HRIRs as sources pan around. In particular, it improves the issue with individual coefficients having various rounding errors in the stepping values, as well as issues with interpolating delay values. It does this by doing two mixing passes for each source. First using the last coefficients that fade to silence, and then again using the new coefficients that fade from silence. When added together, it creates a linear fade from one to the other. Additionally, the gain is applied separately so the individual coefficients don't step with rounding errors. Although this does increase CPU cost since it's doing two mixes per source, each mix is a bit cheaper now since the stepping is simplified to a single gain value, and the overall quality is improved. | ||||
* | Make the voice's 'moving' state a bitflag | Chris Robinson | 2017-03-11 | 1 | -2/+2 |
| | |||||
* | Allocate as many channels for DirectHrtfState as needed | Chris Robinson | 2017-03-11 | 4 | -9/+10 |
| | |||||
* | Dynamically allocate the device's HRTF state | Chris Robinson | 2017-03-10 | 4 | -73/+80 |
| | |||||
* | Fix building on MSVC | Chris Robinson | 2017-03-10 | 1 | -1/+1 |
| | |||||
* | Fix building without C11 | Chris Robinson | 2017-03-10 | 1 | -1/+2 |
| | |||||
* | Implement NFC filters for Ambisonic rendering | Chris Robinson | 2017-03-10 | 4 | -76/+235 |
| | | | | | | | | | | | | | | NFC filters currently only work when rendering to ambisonic buffers, which includes HQ rendering and ambisonic output. There are two new config options: 'decoder/nfc' (default on) enables or disables use of NFC filters globally, and 'decoder/nfc-ref-delay' (default 0) specifies the reference delay parameter for NFC-HOA rendering with ambisonic output (a value of 0 disables NFC). Currently, NFC filters rely on having an appropriate value set for AL_METERS_PER_UNIT to get the correct scaling. HQ rendering uses the averaged speaker distances as a control/reference, and currently doesn't correct for individual speaker distances (if the speakers are all equidistant, this is fine, otherwise per-speaker correction should be done as well). | ||||
* | Add an NFC filter implementation | Chris Robinson | 2017-03-09 | 2 | -0/+459 |
| | |||||
* | Remove an unnecessary variable | Chris Robinson | 2017-03-09 | 1 | -2/+1 |
| | |||||
* | Remove unnecessary atomic members | Chris Robinson | 2017-03-08 | 1 | -109/+86 |
| | |||||
* | Store the channel count and sample size in the voice | Chris Robinson | 2017-03-07 | 1 | -2/+2 |
| | |||||
* | Don't modify the source state in the mixer | Chris Robinson | 2017-03-07 | 1 | -1/+0 |
| | |||||
* | Make the voice's source pointer atomic | Chris Robinson | 2017-03-05 | 2 | -7/+7 |
| | |||||
* | Add a boolean to specify if a voice should be playing | Chris Robinson | 2017-03-02 | 1 | -10/+9 |
| | |||||
* | Increment MixCount in UpdateClockBase | Chris Robinson | 2017-02-28 | 1 | -1/+4 |
| | | | | This is to protect clocktime reads since the backend lock won't protect it. | ||||
* | Dynamically allocate the channel delay buffers | Chris Robinson | 2017-02-28 | 3 | -6/+64 |
| | |||||
* | Remove an unneeded function | Chris Robinson | 2017-02-28 | 3 | -24/+7 |
| | |||||
* | Start a ALC_SOFT_loopback2 extension | Chris Robinson | 2017-02-28 | 1 | -50/+190 |
| | | | | | | | | | | | | | | | | | | | | | | This extends the base ALC_SOFT_loopback extension with support for B-Format. When ALC_FORMAT_CHANNELS_SOFT is set to ALC_BFORMAT3D_SOFT, then additional attributes must be specified. ALC_AMBISONIC_LAYOUT_SOFT must be set to ALC_ACN_SOFT or ALC_FUMA_SOFT for the desired channel layout, ALC_AMBISONIC_SCALING_SOFT must be set to ALC_N3D_SOFT, ALC_SN3D_SOFT, or ALC_FUMA_SOFT for the desired channel scaling/normalization scheme, and ALC_AMBISONIC_ORDER_SOFT must be set to an integer value greater than 0 for the ambisonic order (maximum allowed is implementation-dependent). Note that the number of channels required for ALC_BFORMAT3D_SOFT is dependent on the ambisonic order. The number of channels can be calculated by: num_channels = (order+1) * (order+1); /* or pow(order+1, 2); */ In addition, a new alcIsAmbisonicFormatSupportedSOFT function allows apps to determine which layout/scaling/order combinations are supported by the loopback device. For example, alcIsAmbisonicFormatSupported(device, ALC_ACN_SOFT, ALC_SN3D_SOFT, 2) will check if 2nd order AmbiX (ACN layout and SN3D scaling) rendering is supported for ALC_BFORMAT3D_SOFT output. | ||||
* | Use a variable counter for an array size limit | Chris Robinson | 2017-02-28 | 1 | -21/+13 |
| |