16 const ALfloat (*RESTRICT CoeffStep)[2],
20 for(c = 0;c < IrSize;c++)
23 Values[off][0] += Coeffs[
c][0] *
left;
24 Values[off][1] += Coeffs[
c][1] *
right;
25 Coeffs[
c][0] += CoeffStep[
c][0];
26 Coeffs[
c][1] += CoeffStep[
c][1];
36 float32x4_t leftright4;
38 float32x2_t leftright2 = vdup_n_f32(0.0);
39 leftright2 = vset_lane_f32(left, leftright2, 0);
40 leftright2 = vset_lane_f32(right, leftright2, 1);
41 leftright4 = vcombine_f32(leftright2, leftright2);
43 for(c = 0;c < IrSize;c += 2)
47 float32x4_t vals = vcombine_f32(vld1_f32((float32_t*)&Values[o0][0]),
48 vld1_f32((float32_t*)&Values[o1][0]));
49 float32x4_t coefs = vld1q_f32((float32_t*)&Coeffs[c][0]);
51 vals = vmlaq_f32(vals, coefs, leftright4);
53 vst1_f32((float32_t*)&Values[o0][0], vget_low_f32(vals));
54 vst1_f32((float32_t*)&Values[o1][0], vget_high_f32(vals));
static __inline void ApplyCoeffs(ALuint Offset, ALfloat(*RESTRICT Values)[2], const ALuint IrSize, ALfloat(*RESTRICT Coeffs)[2], ALfloat left, ALfloat right)
static __inline void ApplyCoeffsStep(ALuint Offset, ALfloat(*RESTRICT Values)[2], const ALuint IrSize, ALfloat(*RESTRICT Coeffs)[2], const ALfloat(*RESTRICT CoeffStep)[2], ALfloat left, ALfloat right)