mirror of
https://github.com/g-truc/glm.git
synced 2025-04-05 05:25:02 +00:00
Merge pull request #1086 from imgly/imgly/fix/vdivq_f32_undefinded_armv7
Fixed use of undeclared identifier 'vdivq_f32' while compile for ARMv7 #1086
This commit is contained in:
commit
0a6d3334ea
1 changed files with 13 additions and 0 deletions
|
@ -577,7 +577,20 @@ namespace detail {
|
|||
static vec<4, float, Q> call(vec<4, float, Q> const& a, vec<4, float, Q> const& b)
|
||||
{
|
||||
vec<4, float, Q> Result;
|
||||
#if GLM_ARCH & GLM_ARCH_ARMV8_BIT
|
||||
Result.data = vdivq_f32(a.data, b.data);
|
||||
#else
|
||||
/* Arm assembler reference:
|
||||
*
|
||||
* The Newton-Raphson iteration: x[n+1] = x[n] * (2 - d * x[n])
|
||||
* converges to (1/d) if x0 is the result of VRECPE applied to d.
|
||||
*
|
||||
* Note: The precision usually improves with two interactions, but more than two iterations are not helpful. */
|
||||
float32x4_t x = vrecpeq_f32(b.data);
|
||||
x = vmulq_f32(vrecpsq_f32(b.data, x), x);
|
||||
x = vmulq_f32(vrecpsq_f32(b.data, x), x);
|
||||
Result.data = vmulq_f32(a.data, x);
|
||||
#endif
|
||||
return Result;
|
||||
}
|
||||
};
|
||||
|
|
Loading…
Add table
Reference in a new issue