]> sourceware.org Git - glibc.git/commitdiff
Vector powf for x86_64 and tests.
authorAndrew Senkevich <andrew.senkevich@intel.com>
Thu, 18 Jun 2015 14:04:07 +0000 (17:04 +0300)
committerAndrew Senkevich <andrew.senkevich@intel.com>
Thu, 18 Jun 2015 14:04:07 +0000 (17:04 +0300)
Here is implementation of vectorized powf containing SSE, AVX,
AVX2 and AVX512 versions according to Vector ABI
<https://groups.google.com/forum/#!topic/x86-64-abi/LmppCfN1rZ4>.

    * sysdeps/unix/sysv/linux/x86_64/libmvec.abilist: New symbols added.
    * sysdeps/x86/fpu/bits/math-vector.h: Added SIMD declaration and asm
    redirections for powf.
    * sysdeps/x86_64/fpu/Makefile (libmvec-support): Added new files.
    * sysdeps/x86_64/fpu/Versions: New versions added.
    * sysdeps/x86_64/fpu/libm-test-ulps: Regenerated.
    * sysdeps/x86_64/fpu/multiarch/Makefile (libmvec-sysdep_routines):
    Added build of SSE, AVX2 and AVX512 IFUNC versions.
    * sysdeps/x86_64/fpu/svml_s_wrapper_impl.h: Added 2 argument wrappers.
    * sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core.S: New file.
    * sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core_avx512.S: New file.
    * sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core.S: New file.
    * sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core_sse4.S: New file.
    * sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core.S: New file.
    * sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core_avx2.S: New file.
    * sysdeps/x86_64/fpu/svml_s_powf16_core.S: New file.
    * sysdeps/x86_64/fpu/svml_s_powf4_core.S: New file.
    * sysdeps/x86_64/fpu/svml_s_powf8_core.S: New file.
    * sysdeps/x86_64/fpu/svml_s_powf8_core_avx.S: New file.
    * sysdeps/x86_64/fpu/svml_s_powf_data.S: New file.
    * sysdeps/x86_64/fpu/svml_s_powf_data.h: New file.
    * sysdeps/x86_64/fpu/test-float-vlen16-wrappers.c: Vector powf tests.
    * sysdeps/x86_64/fpu/test-float-vlen16.c: Likewise.
    * sysdeps/x86_64/fpu/test-float-vlen4-wrappers.c: Likewise.
    * sysdeps/x86_64/fpu/test-float-vlen4.c: Likewise.
    * sysdeps/x86_64/fpu/test-float-vlen8-avx2-wrappers.c: Likewise.
    * sysdeps/x86_64/fpu/test-float-vlen8-avx2.c: Likewise.
    * sysdeps/x86_64/fpu/test-float-vlen8-wrappers.c: Likewise.
    * sysdeps/x86_64/fpu/test-float-vlen8.c: Likewise.
    * math/test-float-vlen16.h: Fixed 2 argument macro.
    * math/test-float-vlen4.h: Likewise.
    * math/test-float-vlen8.h: Likewise.
    * NEWS: Mention addition of x86_64 vector powf.

32 files changed:
ChangeLog
NEWS
math/test-float-vlen16.h
math/test-float-vlen4.h
math/test-float-vlen8.h
sysdeps/unix/sysv/linux/x86_64/libmvec.abilist
sysdeps/x86/fpu/bits/math-vector.h
sysdeps/x86_64/fpu/Makefile
sysdeps/x86_64/fpu/Versions
sysdeps/x86_64/fpu/libm-test-ulps
sysdeps/x86_64/fpu/multiarch/Makefile
sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core_avx512.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core_sse4.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core_avx2.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_powf16_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_powf4_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_powf8_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_powf8_core_avx.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_powf_data.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_powf_data.h [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_wrapper_impl.h
sysdeps/x86_64/fpu/test-float-vlen16-wrappers.c
sysdeps/x86_64/fpu/test-float-vlen16.c
sysdeps/x86_64/fpu/test-float-vlen4-wrappers.c
sysdeps/x86_64/fpu/test-float-vlen4.c
sysdeps/x86_64/fpu/test-float-vlen8-avx2-wrappers.c
sysdeps/x86_64/fpu/test-float-vlen8-avx2.c
sysdeps/x86_64/fpu/test-float-vlen8-wrappers.c
sysdeps/x86_64/fpu/test-float-vlen8.c

index fb0e2d30e38ad85d48aa3e7b926a05e2eaf7b3fc..bb70aa2b751e5323e2f49aaca2f0c988a20786c6 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,39 @@
+2015-06-18  Andrew Senkevich  <andrew.senkevich@intel.com>
+
+       * sysdeps/unix/sysv/linux/x86_64/libmvec.abilist: New symbols added.
+       * sysdeps/x86/fpu/bits/math-vector.h: Added SIMD declaration and asm
+       redirections for powf.
+       * sysdeps/x86_64/fpu/Makefile (libmvec-support): Added new files.
+       * sysdeps/x86_64/fpu/Versions: New versions added.
+       * sysdeps/x86_64/fpu/libm-test-ulps: Regenerated.
+       * sysdeps/x86_64/fpu/multiarch/Makefile (libmvec-sysdep_routines):
+       Added build of SSE, AVX2 and AVX512 IFUNC versions.
+       * sysdeps/x86_64/fpu/svml_s_wrapper_impl.h: Added 2 argument wrappers.
+       * sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core.S: New file.
+       * sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core_avx512.S: New file.
+       * sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core.S: New file.
+       * sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core_sse4.S: New file.
+       * sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core.S: New file.
+       * sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core_avx2.S: New file.
+       * sysdeps/x86_64/fpu/svml_s_powf16_core.S: New file.
+       * sysdeps/x86_64/fpu/svml_s_powf4_core.S: New file.
+       * sysdeps/x86_64/fpu/svml_s_powf8_core.S: New file.
+       * sysdeps/x86_64/fpu/svml_s_powf8_core_avx.S: New file.
+       * sysdeps/x86_64/fpu/svml_s_powf_data.S: New file.
+       * sysdeps/x86_64/fpu/svml_s_powf_data.h: New file.
+       * sysdeps/x86_64/fpu/test-float-vlen16-wrappers.c: Vector powf tests.
+       * sysdeps/x86_64/fpu/test-float-vlen16.c: Likewise.
+       * sysdeps/x86_64/fpu/test-float-vlen4-wrappers.c: Likewise.
+       * sysdeps/x86_64/fpu/test-float-vlen4.c: Likewise.
+       * sysdeps/x86_64/fpu/test-float-vlen8-avx2-wrappers.c: Likewise.
+       * sysdeps/x86_64/fpu/test-float-vlen8-avx2.c: Likewise.
+       * sysdeps/x86_64/fpu/test-float-vlen8-wrappers.c: Likewise.
+       * sysdeps/x86_64/fpu/test-float-vlen8.c: Likewise.
+       * math/test-float-vlen16.h: Fixed 2 argument macro.
+       * math/test-float-vlen4.h: Likewise.
+       * math/test-float-vlen8.h: Likewise.
+       * NEWS: Mention addition of x86_64 vector powf.
+
 2015-06-17  Joseph Myers  <joseph@codesourcery.com>
 
        * math/s_ctanhl.c [LDBL_MANT_DIG == 106] (LDBL_EPSILON): Undefine
diff --git a/NEWS b/NEWS
index 1f6b701b301fe8e28e5b32ac87300b71dadd9d0b..149c978ac8d164dada03a8ac3f4c50be67256844 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -55,7 +55,7 @@ Version 2.22
   condition in some applications.
 
 * Added vector math library named libmvec with the following vectorized x86_64
-  implementations: cos, cosf, sin, sinf, log, logf, exp, expf, pow.
+  implementations: cos, cosf, sin, sinf, log, logf, exp, expf, pow, powf.
   The library can be disabled with --disable-mathvec. Use of the functions is
   enabled with -fopenmp -ffast-math starting from -O1 for GCC version >= 4.9.0.
   The library is linked in as needed when using -lm (no need to specify -lmvec
index 5c0a7a484fe2332f97391f1199b69dee6bdd35b7..008e15ea13b7dfcc928a9e6a3c405d8687995a33 100644 (file)
@@ -58,8 +58,8 @@ FLOAT scalar_func (FLOAT x)                   \
 }
 
 // Wrapper from scalar 2 argument function to vector one.
-#define VECTOR_WRAPPER_ff(scalar_func, vector_func) \
-extern VEC_TYPE vector_func (VEC_TYPE);                \
+#define VECTOR_WRAPPER_ff(scalar_func, vector_func)    \
+extern VEC_TYPE vector_func (VEC_TYPE, VEC_TYPE);      \
 FLOAT scalar_func (FLOAT x, FLOAT y)           \
 {                                              \
   int i;                                       \
index 09485bccca55cba59a42b8f0feca943ec2435d25..eaf4b4b13e85524e500c8013f3d294457921305a 100644 (file)
@@ -58,8 +58,8 @@ FLOAT scalar_func (FLOAT x)                   \
 }
 
 // Wrapper from scalar 2 argument function to vector one.
-#define VECTOR_WRAPPER_ff(scalar_func, vector_func) \
-extern VEC_TYPE vector_func (VEC_TYPE);                \
+#define VECTOR_WRAPPER_ff(scalar_func, vector_func)    \
+extern VEC_TYPE vector_func (VEC_TYPE, VEC_TYPE);      \
 FLOAT scalar_func (FLOAT x, FLOAT y)           \
 {                                              \
   int i;                                       \
index d309931c4cf72d974454e4f266074df00cbd9e5d..1a2eb5231898b42ae0764a144546db0e842dbfb9 100644 (file)
@@ -58,8 +58,8 @@ FLOAT scalar_func (FLOAT x)                   \
 }
 
 // Wrapper from scalar 2 argument function to vector one.
-#define VECTOR_WRAPPER_ff(scalar_func, vector_func) \
-extern VEC_TYPE vector_func (VEC_TYPE);                \
+#define VECTOR_WRAPPER_ff(scalar_func, vector_func)    \
+extern VEC_TYPE vector_func (VEC_TYPE, VEC_TYPE);      \
 FLOAT scalar_func (FLOAT x, FLOAT y)           \
 {                                              \
   int i;                                       \
index 9312a6ed2d79980ff5cebde221b10b8d5354c1db..4f9c0404ddb5f76297e2f70e9786cab39cceef30 100644 (file)
@@ -9,6 +9,7 @@ GLIBC_2.22
  _ZGVbN4v_expf F
  _ZGVbN4v_logf F
  _ZGVbN4v_sinf F
+ _ZGVbN4vv_powf F
  _ZGVcN4v_cos F
  _ZGVcN4v_exp F
  _ZGVcN4v_log F
@@ -18,6 +19,7 @@ GLIBC_2.22
  _ZGVcN8v_expf F
  _ZGVcN8v_logf F
  _ZGVcN8v_sinf F
+ _ZGVcN8vv_powf F
  _ZGVdN4v_cos F
  _ZGVdN4v_exp F
  _ZGVdN4v_log F
@@ -27,10 +29,12 @@ GLIBC_2.22
  _ZGVdN8v_expf F
  _ZGVdN8v_logf F
  _ZGVdN8v_sinf F
+ _ZGVdN8vv_powf F
  _ZGVeN16v_cosf F
  _ZGVeN16v_expf F
  _ZGVeN16v_logf F
  _ZGVeN16v_sinf F
+ _ZGVeN16vv_powf F
  _ZGVeN8v_cos F
  _ZGVeN8v_exp F
  _ZGVeN8v_log F
index a5317b9e3211b3cb033f642aa4ca43b0f0916c25..9e53bdf05d405ec04b8a370075f161588cfa0ae2 100644 (file)
@@ -46,6 +46,8 @@
 #  define __DECL_SIMD_expf __DECL_SIMD_x86_64
 #  undef __DECL_SIMD_pow
 #  define __DECL_SIMD_pow __DECL_SIMD_x86_64
+#  undef __DECL_SIMD_powf
+#  define __DECL_SIMD_powf __DECL_SIMD_x86_64
 
 /* Workaround to exclude unnecessary symbol aliases in libmvec
    while GCC creates the vector names based on scalar asm name.
@@ -71,6 +73,10 @@ __asm__ ("_ZGVbN2vv___pow_finite = _ZGVbN2vv_pow");
 __asm__ ("_ZGVcN4vv___pow_finite = _ZGVcN4vv_pow");
 __asm__ ("_ZGVdN4vv___pow_finite = _ZGVdN4vv_pow");
 __asm__ ("_ZGVeN8vv___pow_finite = _ZGVeN8vv_pow");
+__asm__ ("_ZGVbN4vv___powf_finite = _ZGVbN4vv_powf");
+__asm__ ("_ZGVcN8vv___powf_finite = _ZGVcN8vv_powf");
+__asm__ ("_ZGVdN8vv___powf_finite = _ZGVdN8vv_powf");
+__asm__ ("_ZGVeN16vv___powf_finite = _ZGVeN16vv_powf");
 
 # endif
 #endif
index aa9bdea6683285595f6a373150072fbedcc7db7d..20b22f07bdfc23b5368ec2e0719a946f75e3a818 100644 (file)
@@ -15,7 +15,8 @@ libmvec-support += svml_d_cos2_core svml_d_cos4_core_avx \
                   svml_s_expf4_core svml_s_expf8_core_avx svml_s_expf8_core \
                   svml_s_expf16_core svml_s_expf_data svml_d_pow2_core \
                   svml_d_pow4_core_avx svml_d_pow4_core svml_d_pow8_core \
-                  svml_d_pow_data \
+                  svml_d_pow_data svml_s_powf4_core svml_s_powf8_core_avx \
+                  svml_s_powf8_core svml_s_powf16_core svml_s_powf_data \
                   init-arch
 endif
 
index e379c361253b19db03fc5492f846865560714394..1aa7937a30a4c8aa0cae34d9414fb7c87c0b6181 100644 (file)
@@ -9,5 +9,6 @@ libmvec {
     _ZGVbN4v_sinf; _ZGVcN8v_sinf; _ZGVdN8v_sinf; _ZGVeN16v_sinf;
     _ZGVbN4v_logf; _ZGVcN8v_logf; _ZGVdN8v_logf; _ZGVeN16v_logf;
     _ZGVbN4v_expf; _ZGVcN8v_expf; _ZGVdN8v_expf; _ZGVeN16v_expf;
+    _ZGVbN4vv_powf; _ZGVcN8vv_powf; _ZGVdN8vv_powf; _ZGVeN16vv_powf;
   }
 }
index 718e84c3f9ee4a532cb94640666b4ff85dbd3d55..e5ec939225a8a579961fae0d0ed5b91893d02e1a 100644 (file)
@@ -1947,17 +1947,25 @@ ifloat: 4
 ildouble: 2
 ldouble: 2
 
+Function: "pow_vlen16":
+float: 3
+
 Function: "pow_vlen2":
 double: 1
 
 Function: "pow_vlen4":
 double: 1
+float: 3
 
 Function: "pow_vlen4_avx2":
 double: 1
 
 Function: "pow_vlen8":
 double: 1
+float: 3
+
+Function: "pow_vlen8_avx2":
+float: 3
 
 Function: "sin":
 ildouble: 1
index b03b1380c057e2d80763c9bc25301c22713e6898..8f3c457888121518042d08d5a4ec4edd2178bb56 100644 (file)
@@ -66,5 +66,7 @@ libmvec-sysdep_routines += svml_d_cos2_core_sse4 svml_d_cos4_core_avx2 \
                           svml_d_exp4_core_avx2 svml_d_exp8_core_avx512 \
                           svml_s_expf4_core_sse4 svml_s_expf8_core_avx2 \
                           svml_s_expf16_core_avx512 svml_d_pow2_core_sse4 \
-                          svml_d_pow4_core_avx2 svml_d_pow8_core_avx512
+                          svml_d_pow4_core_avx2 svml_d_pow8_core_avx512 \
+                          svml_s_powf4_core_sse4 svml_s_powf8_core_avx2 \
+                          svml_s_powf16_core_avx512
 endif
diff --git a/sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core.S b/sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core.S
new file mode 100644 (file)
index 0000000..a4ba4fb
--- /dev/null
@@ -0,0 +1,39 @@
+/* Multiple versions of vectorized powf.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include <init-arch.h>
+
+       .text
+ENTRY (_ZGVeN16vv_powf)
+        .type   _ZGVeN16vv_powf, @gnu_indirect_function
+        cmpl    $0, KIND_OFFSET+__cpu_features(%rip)
+        jne     1
+        call    __init_cpu_features
+1:      leaq    _ZGVeN16vv_powf_skx(%rip), %rax
+        testl   $bit_AVX512DQ_Usable, __cpu_features+FEATURE_OFFSET+index_AVX512DQ_Usable(%rip)
+        jnz     3
+2:      leaq    _ZGVeN16vv_powf_knl(%rip), %rax
+        testl   $bit_AVX512F_Usable, __cpu_features+FEATURE_OFFSET+index_AVX512F_Usable(%rip)
+        jnz     3
+        leaq    _ZGVeN16vv_powf_avx2_wrapper(%rip), %rax
+3:      ret
+END (_ZGVeN16vv_powf)
+
+#define _ZGVeN16vv_powf _ZGVeN16vv_powf_avx2_wrapper
+#include "../svml_s_powf16_core.S"
diff --git a/sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core_avx512.S b/sysdeps/x86_64/fpu/multiarch/svml_s_powf16_core_avx512.S
new file mode 100644 (file)
index 0000000..4b61974
--- /dev/null
@@ -0,0 +1,653 @@
+/* Function powf vectorized with AVX-512. KNL and SKX versions.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include "svml_s_powf_data.h"
+#include "svml_s_wrapper_impl.h"
+
+/*
+   ALGORITHM DESCRIPTION:
+
+     We are using the next identity : pow(x,y) = 2^(y * log2(x)).
+
+     1) log2(x) calculation
+        Here we use the following formula.
+        Let |x|=2^k1*X1, where k1 is integer, 1<=X1<2.
+        Let C ~= 1/ln(2),
+        Rcp1 ~= 1/X1,   X2=Rcp1*X1,
+        Rcp2 ~= 1/X2,   X3=Rcp2*X2,
+        Rcp3 ~= 1/X3,   Rcp3C ~= C/X3.
+        Then
+          log2|x| = k1 + log2(1/Rcp1) + log2(1/Rcp2) + log2(C/Rcp3C) +
+                    log2(X1*Rcp1*Rcp2*Rcp3C/C),
+        where X1*Rcp1*Rcp2*Rcp3C = C*(1+q), q is very small.
+
+        The values of Rcp1, log2(1/Rcp1), Rcp2, log2(1/Rcp2),
+        Rcp3C, log2(C/Rcp3C) are taken from tables.
+        Values of Rcp1, Rcp2, Rcp3C are such that RcpC=Rcp1*Rcp2*Rcp3C
+        is exactly represented in target precision.
+
+        log2(X1*Rcp1*Rcp2*Rcp3C/C) = log2(1+q) = ln(1+q)/ln2 =
+             = 1/(ln2)*q - 1/(2ln2)*q^2 + 1/(3ln2)*q^3 - ... =
+             = 1/(C*ln2)*cq - 1/(2*C^2*ln2)*cq^2 + 1/(3*C^3*ln2)*cq^3 - ... =
+             = (1 + a1)*cq + a2*cq^2 + a3*cq^3 + ...,
+        where
+             cq=X1*Rcp1*Rcp2*Rcp3C-C,
+             a1=1/(C*ln(2))-1 is small,
+             a2=1/(2*C^2*ln2),
+             a3=1/(3*C^3*ln2),
+                  ...
+        Log2 result is split by three parts: HH+HL+HLL
+
+     2) Calculation of y*log2(x)
+        Split y into YHi+YLo.
+        Get high PH and medium PL parts of y*log2|x|.
+        Get low PLL part of y*log2|x|.
+        Now we have PH+PL+PLL ~= y*log2|x|.
+
+     3) Calculation of 2^(y*log2(x))
+        Let's represent PH+PL+PLL in the form N + j/2^expK + Z,
+        where expK=7 in this implementation, N and j are integers,
+        0<=j<=2^expK-1, |Z|<2^(-expK-1). Hence
+        2^(PH+PL+PLL) ~= 2^N * 2^(j/2^expK) * 2^Z,
+        where 2^(j/2^expK) is stored in a table, and
+        2^Z ~= 1 + B1*Z + B2*Z^2 ... + B5*Z^5.
+        We compute 2^(PH+PL+PLL) as follows:
+        Break PH into PHH + PHL, where PHH = N + j/2^expK.
+        Z = PHL + PL + PLL
+        Exp2Poly = B1*Z + B2*Z^2 ... + B5*Z^5
+        Get 2^(j/2^expK) from table in the form THI+TLO.
+        Now we have 2^(PH+PL+PLL) ~= 2^N * (THI + TLO) * (1 + Exp2Poly).
+        Get significand of 2^(PH+PL+PLL) in the form ResHi+ResLo:
+        ResHi := THI
+        ResLo := THI * Exp2Poly + TLO
+        Get exponent ERes of the result:
+        Res := ResHi + ResLo:
+        Result := ex(Res) + N.  */
+
+       .text
+ENTRY (_ZGVeN16vv_powf_knl)
+#ifndef HAVE_AVX512_ASM_SUPPORT
+WRAPPER_IMPL_AVX512_ff _ZGVdN8vv_powf
+#else
+        pushq     %rbp
+        cfi_adjust_cfa_offset (8)
+        cfi_rel_offset (%rbp, 0)
+        movq      %rsp, %rbp
+        cfi_def_cfa_register (%rbp)
+        andq      $-64, %rsp
+        subq      $1344, %rsp
+        movq      __svml_spow_data@GOTPCREL(%rip), %rdx
+        vmovaps   %zmm1, %zmm9
+        vshuff32x4 $238, %zmm0, %zmm0, %zmm7
+        kxnorw    %k3, %k3, %k3
+        vcvtps2pd %ymm0, %zmm14
+        vcvtps2pd %ymm7, %zmm10
+        movl      $-1, %eax
+        movq      $-1, %rcx
+        vpandd    _ABSMASK(%rdx), %zmm9, %zmm4
+        vmovups   _ExpMask(%rdx), %zmm6
+
+/* exponent bits selection */
+        vpsrlq    $20, %zmm14, %zmm13
+        vshuff32x4 $238, %zmm9, %zmm9, %zmm8
+        vpcmpd    $5, _INF(%rdx), %zmm4, %k2
+        vpsrlq    $32, %zmm13, %zmm15
+        vcvtps2pd %ymm8, %zmm2
+        vmovups   _Two10(%rdx), %zmm4
+        vpmovqd   %zmm15, %ymm12
+        vcvtps2pd %ymm9, %zmm1
+        vpsubd    _NMINNORM(%rdx), %zmm0, %zmm3
+        vpbroadcastd %eax, %zmm8{%k2}{z}
+        vpcmpd    $5, _NMAXVAL(%rdx), %zmm3, %k1
+
+/* preserve mantissa, set input exponent to 2^(-10) */
+        vmovaps   %zmm6, %zmm3
+        vpternlogq $248, %zmm6, %zmm10, %zmm4
+        vpsrlq    $20, %zmm10, %zmm10
+        vpternlogq $234, _Two10(%rdx), %zmm14, %zmm3
+
+/* reciprocal approximation good to at least 11 bits */
+        vrcp28pd  %zmm4, %zmm11
+        vpsrlq    $32, %zmm10, %zmm14
+        vpbroadcastd %eax, %zmm7{%k1}{z}
+        kxnorw    %k1, %k1, %k1
+        vrcp28pd  %zmm3, %zmm5
+        vpmovqd   %zmm14, %ymm6
+        vshufi32x4 $68, %zmm6, %zmm12, %zmm13
+        vmovups   _One(%rdx), %zmm6
+
+/* round reciprocal to nearest integer, will have 1+9 mantissa bits */
+        vrndscalepd $8, %zmm5, %zmm14
+
+/* biased exponent in DP format */
+        vshuff32x4 $238, %zmm13, %zmm13, %zmm5
+        vrndscalepd $8, %zmm11, %zmm11
+        vcmppd    $30, _Threshold(%rdx), %zmm14, %k2
+        vcvtdq2pd %ymm13, %zmm10
+        vcvtdq2pd %ymm5, %zmm15
+
+/* table lookup */
+        vpsrlq    $40, %zmm14, %zmm13
+        vpxord    %zmm5, %zmm5, %zmm5
+        vgatherqpd _Log2Rcp_lookup(%rdx,%zmm13), %zmm5{%k3}
+        vfmsub213pd %zmm6, %zmm14, %zmm3
+        vfmsub213pd %zmm6, %zmm11, %zmm4
+        vcmppd    $30, _Threshold(%rdx), %zmm11, %k3
+        vpbroadcastq %rcx, %zmm14{%k2}{z}
+
+/* dpP= _dbT+lJ*T_ITEM_GRAN */
+        kxnorw    %k2, %k2, %k2
+        vpsrlq    $40, %zmm11, %zmm12
+        vpxord    %zmm6, %zmm6, %zmm6
+        vpbroadcastq %rcx, %zmm11{%k3}{z}
+        kxnorw    %k3, %k3, %k3
+        vgatherqpd _Log2Rcp_lookup(%rdx,%zmm12), %zmm6{%k1}
+        vmovups   _Bias1(%rdx), %zmm12
+        vpternlogq $236, _Bias(%rdx), %zmm12, %zmm14
+        vpternlogq $248, _Bias(%rdx), %zmm11, %zmm12
+        vsubpd    %zmm14, %zmm10, %zmm13
+        vsubpd    %zmm12, %zmm15, %zmm10
+        vmovups   _poly_coeff_3(%rdx), %zmm11
+        vmovups   _poly_coeff_4(%rdx), %zmm15
+        vfmadd213pd %zmm15, %zmm4, %zmm11
+        vmulpd    %zmm4, %zmm4, %zmm12
+        vmovaps   %zmm15, %zmm14
+        vmulpd    %zmm3, %zmm3, %zmm15
+        vfmadd231pd _poly_coeff_3(%rdx), %zmm3, %zmm14
+
+/* reconstruction */
+        vfmadd213pd %zmm4, %zmm12, %zmm11
+        vfmadd213pd %zmm3, %zmm15, %zmm14
+        vaddpd    %zmm6, %zmm11, %zmm11
+        vaddpd    %zmm5, %zmm14, %zmm3
+        vfmadd231pd _L2(%rdx), %zmm10, %zmm11
+        vfmadd132pd _L2(%rdx), %zmm3, %zmm13
+        vmulpd    %zmm2, %zmm11, %zmm12
+        vmulpd    %zmm1, %zmm13, %zmm10
+        vmulpd    __dbInvLn2(%rdx), %zmm12, %zmm6
+
+/* hi bits */
+        vpsrlq    $32, %zmm12, %zmm12
+        vmulpd    __dbInvLn2(%rdx), %zmm10, %zmm1
+
+/* to round down; if dR is an integer we will get R = 1, which is ok */
+        vsubpd    __dbHALF(%rdx), %zmm6, %zmm4
+        vpsrlq    $32, %zmm10, %zmm11
+        vpmovqd   %zmm11, %ymm3
+        vsubpd    __dbHALF(%rdx), %zmm1, %zmm2
+        vaddpd    __dbShifter(%rdx), %zmm4, %zmm14
+        vpmovqd   %zmm12, %ymm4
+        vshufi32x4 $68, %zmm4, %zmm3, %zmm5
+        vpxord    %zmm4, %zmm4, %zmm4
+        vaddpd    __dbShifter(%rdx), %zmm2, %zmm2
+
+/* iAbsX = iAbsX&iAbsMask; */
+        vpandd    __iAbsMask(%rdx), %zmm5, %zmm11
+        vpxord    %zmm5, %zmm5, %zmm5
+        vsubpd    __dbShifter(%rdx), %zmm14, %zmm13
+
+/* iRangeMask = (iAbsX>iDomainRange) */
+        vpcmpgtd     __iDomainRange(%rdx), %zmm11, %k1
+        vsubpd       __dbShifter(%rdx), %zmm2, %zmm15
+        vpbroadcastd %eax, %zmm10{%k1}{z}
+        vpternlogd   $254, %zmm8, %zmm7, %zmm10
+
+/* [0..1) */
+        vsubpd    %zmm15, %zmm1, %zmm1
+
+/* low K bits */
+        vpandq    __lbLOWKBITS(%rdx), %zmm14, %zmm11
+        vgatherqpd 13952(%rdx,%zmm11,8), %zmm5{%k3}
+        vsubpd    %zmm13, %zmm6, %zmm7
+        vptestmd  %zmm10, %zmm10, %k0
+        vpandq    __lbLOWKBITS(%rdx), %zmm2, %zmm10
+        vmulpd    __dbC1(%rdx), %zmm1, %zmm1
+        vmulpd    __dbC1(%rdx), %zmm7, %zmm3
+        vpsrlq    $11, %zmm2, %zmm8
+        vpsrlq    $11, %zmm14, %zmm2
+
+/* NB : including +/- sign for the exponent!! */
+        vpsllq    $52, %zmm8, %zmm8
+        kmovw     %k0, %ecx
+        vpsllq    $52, %zmm2, %zmm6
+        vfmadd213pd %zmm5, %zmm3, %zmm5
+        vgatherqpd 13952(%rdx,%zmm10,8), %zmm4{%k2}
+        vfmadd213pd %zmm4, %zmm1, %zmm4
+        vpaddq    %zmm6, %zmm5, %zmm10
+        vcvtpd2ps %zmm10, %ymm12
+        vpaddq    %zmm8, %zmm4, %zmm7
+        vcvtpd2ps %zmm7, %ymm11
+        vshuff32x4 $68, %zmm12, %zmm11, %zmm1
+        testl     %ecx, %ecx
+        jne       .LBL_1_3
+
+.LBL_1_2:
+        cfi_remember_state
+        vmovaps   %zmm1, %zmm0
+        movq      %rbp, %rsp
+        cfi_def_cfa_register (%rsp)
+        popq      %rbp
+        cfi_adjust_cfa_offset (-8)
+        cfi_restore (%rbp)
+        ret
+
+.LBL_1_3:
+        cfi_restore_state
+        vmovups   %zmm0, 1152(%rsp)
+        vmovups   %zmm9, 1216(%rsp)
+        vmovups   %zmm1, 1280(%rsp)
+        je        .LBL_1_2
+
+        xorb      %dl, %dl
+        kmovw     %k4, 1048(%rsp)
+        xorl      %eax, %eax
+        kmovw     %k5, 1040(%rsp)
+        kmovw     %k6, 1032(%rsp)
+        kmovw     %k7, 1024(%rsp)
+        vmovups   %zmm16, 960(%rsp)
+        vmovups   %zmm17, 896(%rsp)
+        vmovups   %zmm18, 832(%rsp)
+        vmovups   %zmm19, 768(%rsp)
+        vmovups   %zmm20, 704(%rsp)
+        vmovups   %zmm21, 640(%rsp)
+        vmovups   %zmm22, 576(%rsp)
+        vmovups   %zmm23, 512(%rsp)
+        vmovups   %zmm24, 448(%rsp)
+        vmovups   %zmm25, 384(%rsp)
+        vmovups   %zmm26, 320(%rsp)
+        vmovups   %zmm27, 256(%rsp)
+        vmovups   %zmm28, 192(%rsp)
+        vmovups   %zmm29, 128(%rsp)
+        vmovups   %zmm30, 64(%rsp)
+        vmovups   %zmm31, (%rsp)
+        movq      %rsi, 1064(%rsp)
+        movq      %rdi, 1056(%rsp)
+        movq      %r12, 1096(%rsp)
+        cfi_offset_rel_rsp (12, 1096)
+        movb      %dl, %r12b
+        movq      %r13, 1088(%rsp)
+        cfi_offset_rel_rsp (13, 1088)
+        movl      %ecx, %r13d
+        movq      %r14, 1080(%rsp)
+        cfi_offset_rel_rsp (14, 1080)
+        movl      %eax, %r14d
+        movq      %r15, 1072(%rsp)
+        cfi_offset_rel_rsp (15, 1072)
+        cfi_remember_state
+
+.LBL_1_6:
+        btl       %r14d, %r13d
+        jc        .LBL_1_12
+
+.LBL_1_7:
+        lea       1(%r14), %esi
+        btl       %esi, %r13d
+        jc        .LBL_1_10
+
+.LBL_1_8:
+        addb      $1, %r12b
+        addl      $2, %r14d
+        cmpb      $16, %r12b
+        jb        .LBL_1_6
+
+        kmovw     1048(%rsp), %k4
+        movq      1064(%rsp), %rsi
+        kmovw     1040(%rsp), %k5
+        movq      1056(%rsp), %rdi
+        kmovw     1032(%rsp), %k6
+        movq      1096(%rsp), %r12
+        cfi_restore (%r12)
+        movq      1088(%rsp), %r13
+        cfi_restore (%r13)
+        kmovw     1024(%rsp), %k7
+        vmovups   960(%rsp), %zmm16
+        vmovups   896(%rsp), %zmm17
+        vmovups   832(%rsp), %zmm18
+        vmovups   768(%rsp), %zmm19
+        vmovups   704(%rsp), %zmm20
+        vmovups   640(%rsp), %zmm21
+        vmovups   576(%rsp), %zmm22
+        vmovups   512(%rsp), %zmm23
+        vmovups   448(%rsp), %zmm24
+        vmovups   384(%rsp), %zmm25
+        vmovups   320(%rsp), %zmm26
+        vmovups   256(%rsp), %zmm27
+        vmovups   192(%rsp), %zmm28
+        vmovups   128(%rsp), %zmm29
+        vmovups   64(%rsp), %zmm30
+        vmovups   (%rsp), %zmm31
+        movq      1080(%rsp), %r14
+        cfi_restore (%r14)
+        movq      1072(%rsp), %r15
+        cfi_restore (%r15)
+        vmovups   1280(%rsp), %zmm1
+        jmp       .LBL_1_2
+
+.LBL_1_10:
+        cfi_restore_state
+        movzbl    %r12b, %r15d
+        vmovss    1156(%rsp,%r15,8), %xmm0
+        vmovss    1220(%rsp,%r15,8), %xmm1
+        call      powf@PLT
+        vmovss    %xmm0, 1284(%rsp,%r15,8)
+        jmp       .LBL_1_8
+
+.LBL_1_12:
+        movzbl    %r12b, %r15d
+        vmovss    1152(%rsp,%r15,8), %xmm0
+        vmovss    1216(%rsp,%r15,8), %xmm1
+        call      powf@PLT
+        vmovss    %xmm0, 1280(%rsp,%r15,8)
+        jmp       .LBL_1_7
+#endif
+END (_ZGVeN16vv_powf_knl)
+
+ENTRY (_ZGVeN16vv_powf_skx)
+#ifndef HAVE_AVX512_ASM_SUPPORT
+WRAPPER_IMPL_AVX512_ff _ZGVdN8vv_powf
+#else
+        pushq     %rbp
+        cfi_adjust_cfa_offset (8)
+        cfi_rel_offset (%rbp, 0)
+        movq      %rsp, %rbp
+        cfi_def_cfa_register (%rbp)
+        andq      $-64, %rsp
+        subq      $1344, %rsp
+        movq      __svml_spow_data@GOTPCREL(%rip), %rax
+        vextractf32x8 $1, %zmm1, %ymm14
+        vextractf32x8 $1, %zmm0, %ymm15
+        vpsubd _NMINNORM(%rax), %zmm0, %zmm9
+        vmovups   %zmm26, 1280(%rsp)
+        vmovups _ExpMask(%rax), %zmm6
+        vpcmpd    $1, _NMAXVAL(%rax), %zmm9, %k1
+        vcvtps2pd %ymm0, %zmm5
+        vcvtps2pd %ymm1, %zmm12
+        kxnorw    %k3, %k3, %k3
+
+/* exponent bits selection */
+        vpsrlq    $20, %zmm5, %zmm3
+        vpsrlq    $32, %zmm3, %zmm2
+        vpmovqd   %zmm2, %ymm11
+        vcvtps2pd %ymm14, %zmm13
+        vmovups   .L_2il0floatpacket.23(%rip), %zmm14
+        vmovaps   %zmm14, %zmm26
+        vpandd _ABSMASK(%rax), %zmm1, %zmm8
+        vpcmpd    $1, _INF(%rax), %zmm8, %k2
+        vpandnd   %zmm9, %zmm9, %zmm26{%k1}
+        vmovups _Two10(%rax), %zmm9
+        kxnorw    %k1, %k1, %k1
+        vcvtps2pd %ymm15, %zmm4
+        vmovaps   %zmm14, %zmm15
+
+/* preserve mantissa, set input exponent to 2^(-10) */
+        vpternlogq $248, %zmm6, %zmm4, %zmm9
+        vpsrlq    $20, %zmm4, %zmm4
+
+/* reciprocal approximation good to at least 11 bits */
+        vrcp14pd  %zmm9, %zmm10
+
+/* round reciprocal to nearest integer, will have 1+9 mantissa bits */
+        vrndscalepd $8, %zmm10, %zmm3
+        vmovups _One(%rax), %zmm10
+        vfmsub213pd %zmm10, %zmm3, %zmm9
+        vpandnd   %zmm8, %zmm8, %zmm15{%k2}
+        vmovaps   %zmm6, %zmm8
+        vpternlogq $234, _Two10(%rax), %zmm5, %zmm8
+        vpsrlq    $32, %zmm4, %zmm5
+        vrcp14pd  %zmm8, %zmm7
+        vpmovqd   %zmm5, %ymm6
+        vrndscalepd $8, %zmm7, %zmm2
+        vfmsub213pd %zmm10, %zmm2, %zmm8
+
+/* table lookup */
+        vpsrlq    $40, %zmm2, %zmm10
+        vinserti32x8 $1, %ymm6, %zmm11, %zmm4
+        vpsrlq    $40, %zmm3, %zmm11
+
+/* biased exponent in DP format */
+        vextracti32x8 $1, %zmm4, %ymm7
+        vcvtdq2pd %ymm4, %zmm6
+        vpmovqd   %zmm10, %ymm4
+        vpmovqd   %zmm11, %ymm5
+        vpxord    %zmm10, %zmm10, %zmm10
+        vgatherdpd _Log2Rcp_lookup(%rax,%ymm4), %zmm10{%k3}
+        vpbroadcastq .L_2il0floatpacket.24(%rip), %zmm4
+        vpxord    %zmm11, %zmm11, %zmm11
+        vcvtdq2pd %ymm7, %zmm7
+        vgatherdpd _Log2Rcp_lookup(%rax,%ymm5), %zmm11{%k1}
+        vmovups _Threshold(%rax), %zmm5
+        vcmppd    $21, %zmm2, %zmm5, %k2
+        vcmppd    $21, %zmm3, %zmm5, %k3
+        vmovups _Bias1(%rax), %zmm3
+        vmovaps   %zmm4, %zmm2
+        vpandnq   %zmm5, %zmm5, %zmm2{%k2}
+        vpternlogq $236, _Bias(%rax), %zmm3, %zmm2
+
+/* dpP= _dbT+lJ*T_ITEM_GRAN */
+        kxnorw    %k2, %k2, %k2
+        vpandnq   %zmm5, %zmm5, %zmm4{%k3}
+        vpternlogq $248, _Bias(%rax), %zmm4, %zmm3
+        vsubpd    %zmm2, %zmm6, %zmm4
+        vmovups _poly_coeff_3(%rax), %zmm6
+        vmovups _poly_coeff_4(%rax), %zmm2
+        vsubpd    %zmm3, %zmm7, %zmm5
+        vmulpd    %zmm8, %zmm8, %zmm7
+        vfmadd213pd %zmm2, %zmm9, %zmm6
+        kxnorw    %k3, %k3, %k3
+        vmovaps   %zmm2, %zmm3
+        vmulpd    %zmm9, %zmm9, %zmm2
+        vfmadd231pd _poly_coeff_3(%rax), %zmm8, %zmm3
+
+/* reconstruction */
+        vfmadd213pd %zmm9, %zmm2, %zmm6
+        vfmadd213pd %zmm8, %zmm7, %zmm3
+        vaddpd    %zmm11, %zmm6, %zmm8
+        vaddpd    %zmm10, %zmm3, %zmm9
+        vfmadd231pd _L2(%rax), %zmm5, %zmm8
+        vfmadd132pd _L2(%rax), %zmm9, %zmm4
+        vmulpd    %zmm13, %zmm8, %zmm13
+        vmulpd    %zmm12, %zmm4, %zmm3
+        vmulpd __dbInvLn2(%rax), %zmm13, %zmm10
+        vmulpd __dbInvLn2(%rax), %zmm3, %zmm8
+
+/* hi bits */
+        vpsrlq    $32, %zmm3, %zmm4
+        vpsrlq    $32, %zmm13, %zmm13
+
+/* to round down; if dR is an integer we will get R = 1, which is ok */
+        vsubpd __dbHALF(%rax), %zmm8, %zmm12
+        vpmovqd   %zmm4, %ymm5
+        vpmovqd   %zmm13, %ymm2
+        vsubpd __dbHALF(%rax), %zmm10, %zmm9
+        vaddpd __dbShifter(%rax), %zmm12, %zmm7
+        vaddpd __dbShifter(%rax), %zmm9, %zmm9
+        vsubpd __dbShifter(%rax), %zmm7, %zmm11
+        vsubpd __dbShifter(%rax), %zmm9, %zmm12
+        vinserti32x8 $1, %ymm2, %zmm5, %zmm3
+
+/* iAbsX = iAbsX&iAbsMask */
+        vpandd __iAbsMask(%rax), %zmm3, %zmm4
+
+/* iRangeMask = (iAbsX>iDomainRange) */
+        vpcmpd    $2, __iDomainRange(%rax), %zmm4, %k1
+        vpandnd   %zmm4, %zmm4, %zmm14{%k1}
+        vpternlogd $254, %zmm15, %zmm26, %zmm14
+
+/* [0..1) */
+        vsubpd    %zmm11, %zmm8, %zmm15
+        vsubpd    %zmm12, %zmm10, %zmm26
+        vptestmd  %zmm14, %zmm14, %k0
+        vpsrlq    $11, %zmm7, %zmm8
+        vpsrlq    $11, %zmm9, %zmm10
+        vmulpd __dbC1(%rax), %zmm26, %zmm26
+        vmulpd __dbC1(%rax), %zmm15, %zmm15
+
+/* NB : including +/- sign for the exponent!! */
+        vpsllq    $52, %zmm10, %zmm13
+        vpsllq    $52, %zmm8, %zmm12
+        kmovw     %k0, %ecx
+
+/* low K bits */
+        vpandq __lbLOWKBITS(%rax), %zmm9, %zmm14
+        vpandq __lbLOWKBITS(%rax), %zmm7, %zmm6
+        vpmovqd   %zmm14, %ymm7
+        vpmovqd   %zmm6, %ymm9
+        vpxord    %zmm2, %zmm2, %zmm2
+        vgatherdpd 13952(%rax,%ymm7,8), %zmm2{%k3}
+        vfmadd213pd %zmm2, %zmm26, %zmm2
+        vpaddq    %zmm13, %zmm2, %zmm2
+        vcvtpd2ps %zmm2, %ymm4
+        vpxord    %zmm11, %zmm11, %zmm11
+        vgatherdpd 13952(%rax,%ymm9,8), %zmm11{%k2}
+        vfmadd213pd %zmm11, %zmm15, %zmm11
+        vpaddq    %zmm12, %zmm11, %zmm3
+        vcvtpd2ps %zmm3, %ymm5
+        vinsertf32x8 $1, %ymm4, %zmm5, %zmm2
+        testl     %ecx, %ecx
+        jne       .LBL_2_3
+
+.LBL_2_2:
+        cfi_remember_state
+        vmovups   1280(%rsp), %zmm26
+        vmovaps   %zmm2, %zmm0
+        movq      %rbp, %rsp
+        cfi_def_cfa_register (%rsp)
+        popq      %rbp
+        cfi_adjust_cfa_offset (-8)
+        cfi_restore (%rbp)
+        ret
+
+.LBL_2_3:
+        cfi_restore_state
+        vmovups   %zmm0, 1088(%rsp)
+        vmovups   %zmm1, 1152(%rsp)
+        vmovups   %zmm2, 1216(%rsp)
+        je        .LBL_2_2
+
+        xorb      %dl, %dl
+        xorl      %eax, %eax
+        kmovw     %k4, 984(%rsp)
+        kmovw     %k5, 976(%rsp)
+        kmovw     %k6, 968(%rsp)
+        kmovw     %k7, 960(%rsp)
+        vmovups   %zmm16, 896(%rsp)
+        vmovups   %zmm17, 832(%rsp)
+        vmovups   %zmm18, 768(%rsp)
+        vmovups   %zmm19, 704(%rsp)
+        vmovups   %zmm20, 640(%rsp)
+        vmovups   %zmm21, 576(%rsp)
+        vmovups   %zmm22, 512(%rsp)
+        vmovups   %zmm23, 448(%rsp)
+        vmovups   %zmm24, 384(%rsp)
+        vmovups   %zmm25, 320(%rsp)
+        vmovups   %zmm27, 256(%rsp)
+        vmovups   %zmm28, 192(%rsp)
+        vmovups   %zmm29, 128(%rsp)
+        vmovups   %zmm30, 64(%rsp)
+        vmovups   %zmm31, (%rsp)
+        movq      %rsi, 1000(%rsp)
+        movq      %rdi, 992(%rsp)
+        movq      %r12, 1032(%rsp)
+        cfi_offset_rel_rsp (12, 1032)
+        movb      %dl, %r12b
+        movq      %r13, 1024(%rsp)
+        cfi_offset_rel_rsp (13, 1024)
+        movl      %ecx, %r13d
+        movq      %r14, 1016(%rsp)
+        cfi_offset_rel_rsp (14, 1016)
+        movl      %eax, %r14d
+        movq      %r15, 1008(%rsp)
+        cfi_offset_rel_rsp (15, 1008)
+        cfi_remember_state
+
+.LBL_2_6:
+        btl       %r14d, %r13d
+        jc        .LBL_2_12
+
+.LBL_2_7:
+        lea       1(%r14), %esi
+        btl       %esi, %r13d
+        jc        .LBL_2_10
+
+.LBL_2_8:
+        incb      %r12b
+        addl      $2, %r14d
+        cmpb      $16, %r12b
+        jb        .LBL_2_6
+
+        kmovw     984(%rsp), %k4
+        kmovw     976(%rsp), %k5
+        kmovw     968(%rsp), %k6
+        kmovw     960(%rsp), %k7
+        vmovups   896(%rsp), %zmm16
+        vmovups   832(%rsp), %zmm17
+        vmovups   768(%rsp), %zmm18
+        vmovups   704(%rsp), %zmm19
+        vmovups   640(%rsp), %zmm20
+        vmovups   576(%rsp), %zmm21
+        vmovups   512(%rsp), %zmm22
+        vmovups   448(%rsp), %zmm23
+        vmovups   384(%rsp), %zmm24
+        vmovups   320(%rsp), %zmm25
+        vmovups   256(%rsp), %zmm27
+        vmovups   192(%rsp), %zmm28
+        vmovups   128(%rsp), %zmm29
+        vmovups   64(%rsp), %zmm30
+        vmovups   (%rsp), %zmm31
+        vmovups   1216(%rsp), %zmm2
+        movq      1000(%rsp), %rsi
+        movq      992(%rsp), %rdi
+        movq      1032(%rsp), %r12
+        cfi_restore (%r12)
+        movq      1024(%rsp), %r13
+        cfi_restore (%r13)
+        movq      1016(%rsp), %r14
+        cfi_restore (%r14)
+        movq      1008(%rsp), %r15
+        cfi_restore (%r15)
+        jmp       .LBL_2_2
+
+.LBL_2_10:
+        cfi_restore_state
+        movzbl    %r12b, %r15d
+        vmovss    1156(%rsp,%r15,8), %xmm1
+        vzeroupper
+        vmovss    1092(%rsp,%r15,8), %xmm0
+        call      powf@PLT
+        vmovss    %xmm0, 1220(%rsp,%r15,8)
+        jmp       .LBL_2_8
+
+.LBL_2_12:
+        movzbl    %r12b, %r15d
+        vmovss    1152(%rsp,%r15,8), %xmm1
+        vzeroupper
+        vmovss    1088(%rsp,%r15,8), %xmm0
+        call      powf@PLT
+        vmovss    %xmm0, 1216(%rsp,%r15,8)
+        jmp       .LBL_2_7
+#endif
+END (_ZGVeN16vv_powf_skx)
+
+       .section .rodata, "a"
+.L_2il0floatpacket.23:
+       .long   0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff,0xffffffff
+       .type   .L_2il0floatpacket.23,@object
+.L_2il0floatpacket.24:
+       .long   0xffffffff,0xffffffff
+       .type   .L_2il0floatpacket.24,@object
diff --git a/sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core.S b/sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core.S
new file mode 100644 (file)
index 0000000..f88b9ca
--- /dev/null
@@ -0,0 +1,38 @@
+/* Multiple versions of vectorized powf.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include <init-arch.h>
+
+       .text
+ENTRY (_ZGVbN4vv_powf)
+        .type   _ZGVbN4vv_powf, @gnu_indirect_function
+        cmpl    $0, KIND_OFFSET+__cpu_features(%rip)
+        jne     1f
+        call    __init_cpu_features
+1:      leaq    _ZGVbN4vv_powf_sse4(%rip), %rax
+        testl   $bit_SSE4_1, __cpu_features+CPUID_OFFSET+index_SSE4_1(%rip)
+        jz      2f
+        ret
+2:      leaq    _ZGVbN4vv_powf_sse2(%rip), %rax
+        ret
+END (_ZGVbN4vv_powf)
+libmvec_hidden_def (_ZGVbN4vv_powf)
+
+#define _ZGVbN4vv_powf _ZGVbN4vv_powf_sse2
+#include "../svml_s_powf4_core.S"
diff --git a/sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core_sse4.S b/sysdeps/x86_64/fpu/multiarch/svml_s_powf4_core_sse4.S
new file mode 100644 (file)
index 0000000..6068f51
--- /dev/null
@@ -0,0 +1,374 @@
+/* Function powf vectorized with SSE4.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include "svml_s_powf_data.h"
+
+       .text
+ENTRY (_ZGVbN4vv_powf_sse4)
+/*
+   ALGORITHM DESCRIPTION:
+
+     We are using the next identity: pow(x,y) = 2^(y * log2(x)).
+
+     1) log2(x) calculation
+        Here we use the following formula.
+        Let |x|=2^k1*X1, where k1 is integer, 1<=X1<2.
+        Let C ~= 1/ln(2),
+        Rcp1 ~= 1/X1,   X2=Rcp1*X1,
+        Rcp2 ~= 1/X2,   X3=Rcp2*X2,
+        Rcp3 ~= 1/X3,   Rcp3C ~= C/X3.
+        Then
+          log2|x| = k1 + log2(1/Rcp1) + log2(1/Rcp2) + log2(C/Rcp3C) +
+                    log2(X1*Rcp1*Rcp2*Rcp3C/C),
+        where X1*Rcp1*Rcp2*Rcp3C = C*(1+q), q is very small.
+
+        The values of Rcp1, log2(1/Rcp1), Rcp2, log2(1/Rcp2),
+        Rcp3C, log2(C/Rcp3C) are taken from tables.
+        Values of Rcp1, Rcp2, Rcp3C are such that RcpC=Rcp1*Rcp2*Rcp3C
+        is exactly represented in target precision.
+
+        log2(X1*Rcp1*Rcp2*Rcp3C/C) = log2(1+q) = ln(1+q)/ln2 =
+             = 1/(ln2)*q - 1/(2ln2)*q^2 + 1/(3ln2)*q^3 - ... =
+             = 1/(C*ln2)*cq - 1/(2*C^2*ln2)*cq^2 + 1/(3*C^3*ln2)*cq^3 - ... =
+             = (1 + a1)*cq + a2*cq^2 + a3*cq^3 + ...,
+        where
+             cq=X1*Rcp1*Rcp2*Rcp3C-C,
+             a1=1/(C*ln(2))-1 is small,
+             a2=1/(2*C^2*ln2),
+             a3=1/(3*C^3*ln2),
+                  ...
+        Log2 result is split by three parts: HH+HL+HLL
+
+     2) Calculation of y*log2(x)
+        Split y into YHi+YLo.
+        Get high PH and medium PL parts of y*log2|x|.
+        Get low PLL part of y*log2|x|.
+        Now we have PH+PL+PLL ~= y*log2|x|.
+
+     3) Calculation of 2^(y*log2(x))
+        Let's represent PH+PL+PLL in the form N + j/2^expK + Z,
+        where expK=7 in this implementation, N and j are integers,
+        0<=j<=2^expK-1, |Z|<2^(-expK-1). Hence
+        2^(PH+PL+PLL) ~= 2^N * 2^(j/2^expK) * 2^Z,
+        where 2^(j/2^expK) is stored in a table, and
+        2^Z ~= 1 + B1*Z + B2*Z^2 ... + B5*Z^5.
+        We compute 2^(PH+PL+PLL) as follows:
+        Break PH into PHH + PHL, where PHH = N + j/2^expK.
+        Z = PHL + PL + PLL
+        Exp2Poly = B1*Z + B2*Z^2 ... + B5*Z^5
+        Get 2^(j/2^expK) from table in the form THI+TLO.
+        Now we have 2^(PH+PL+PLL) ~= 2^N * (THI + TLO) * (1 + Exp2Poly).
+        Get significand of 2^(PH+PL+PLL) in the form ResHi+ResLo:
+        ResHi := THI
+        ResLo := THI * Exp2Poly + TLO
+        Get exponent ERes of the result:
+        Res := ResHi + ResLo:
+        Result := ex(Res) + N.  */
+
+        pushq     %rbp
+        cfi_adjust_cfa_offset (8)
+        cfi_rel_offset (%rbp, 0)
+        movq      %rsp, %rbp
+        cfi_def_cfa_register (%rbp)
+        andq      $-64, %rsp
+        subq      $256, %rsp
+        movaps    %xmm0, %xmm3
+        movhlps   %xmm0, %xmm3
+        movaps    %xmm1, %xmm5
+        movups    %xmm8, 112(%rsp)
+        movaps    %xmm5, %xmm2
+        cvtps2pd  %xmm3, %xmm8
+        cvtps2pd  %xmm5, %xmm7
+        movups    %xmm9, 96(%rsp)
+        movaps    %xmm0, %xmm4
+        cvtps2pd  %xmm0, %xmm9
+        movq      __svml_spow_data@GOTPCREL(%rip), %rdx
+        movups    %xmm10, 176(%rsp)
+        movups    %xmm13, 48(%rsp)
+        movups _ExpMask(%rdx), %xmm6
+
+/* preserve mantissa, set input exponent to 2^(-10) */
+        movaps    %xmm6, %xmm10
+        andps     %xmm8, %xmm6
+        andps     %xmm9, %xmm10
+
+/* exponent bits selection */
+        psrlq     $20, %xmm9
+        orps _Two10(%rdx), %xmm6
+        psrlq     $20, %xmm8
+        orps _Two10(%rdx), %xmm10
+
+/* reciprocal approximation good to at least 11 bits */
+        cvtpd2ps  %xmm6, %xmm13
+        cvtpd2ps  %xmm10, %xmm1
+        movlhps   %xmm13, %xmm13
+        movhlps   %xmm5, %xmm2
+        movlhps   %xmm1, %xmm1
+        movups    %xmm12, 208(%rsp)
+        rcpps     %xmm13, %xmm12
+        movups    %xmm11, 80(%rsp)
+        cvtps2pd  %xmm2, %xmm11
+        rcpps     %xmm1, %xmm2
+        movups    %xmm14, 144(%rsp)
+        cvtps2pd  %xmm12, %xmm14
+        movups    %xmm15, 160(%rsp)
+        cvtps2pd  %xmm2, %xmm15
+        shufps    $221, %xmm8, %xmm9
+
+/* round reciprocal to nearest integer, will have 1+9 mantissa bits */
+        roundpd   $0, %xmm14, %xmm14
+
+/* biased exponent in DP format */
+        pshufd    $238, %xmm9, %xmm8
+        roundpd   $0, %xmm15, %xmm15
+        cvtdq2pd  %xmm8, %xmm1
+        mulpd     %xmm15, %xmm10
+        mulpd     %xmm14, %xmm6
+        cvtdq2pd  %xmm9, %xmm2
+        subpd _One(%rdx), %xmm10
+        subpd _One(%rdx), %xmm6
+
+/* table lookup */
+        movaps    %xmm14, %xmm8
+        movaps    %xmm15, %xmm9
+        psrlq     $40, %xmm8
+        psrlq     $40, %xmm9
+        movd      %xmm8, %r8d
+        movd      %xmm9, %eax
+        psubd _NMINNORM(%rdx), %xmm4
+        movdqu _ABSMASK(%rdx), %xmm3
+        pextrd    $2, %xmm8, %r9d
+        pand      %xmm5, %xmm3
+        movups _Threshold(%rdx), %xmm8
+        pextrd    $2, %xmm9, %ecx
+        movaps    %xmm8, %xmm9
+        cmpltpd   %xmm15, %xmm9
+        cmpltpd   %xmm14, %xmm8
+        andps _Bias(%rdx), %xmm9
+        movaps    %xmm10, %xmm14
+        andps _Bias(%rdx), %xmm8
+        movaps    %xmm6, %xmm15
+        orps _Bias1(%rdx), %xmm9
+        orps _Bias1(%rdx), %xmm8
+        subpd     %xmm9, %xmm2
+        subpd     %xmm8, %xmm1
+        mulpd     %xmm10, %xmm14
+        mulpd     %xmm6, %xmm15
+        mulpd _L2(%rdx), %xmm2
+        mulpd _L2(%rdx), %xmm1
+        movups _poly_coeff_3(%rdx), %xmm9
+        movaps    %xmm9, %xmm8
+        mulpd     %xmm10, %xmm8
+        mulpd     %xmm6, %xmm9
+        addpd _poly_coeff_4(%rdx), %xmm8
+        addpd _poly_coeff_4(%rdx), %xmm9
+        mulpd     %xmm14, %xmm8
+        mulpd     %xmm15, %xmm9
+
+/* reconstruction */
+        addpd     %xmm8, %xmm10
+        addpd     %xmm9, %xmm6
+        movslq    %eax, %rax
+        movslq    %r8d, %r8
+        movslq    %ecx, %rcx
+        movslq    %r9d, %r9
+        movsd     _Log2Rcp_lookup(%rdx,%rax), %xmm13
+        movsd     _Log2Rcp_lookup(%rdx,%r8), %xmm12
+        movhpd    _Log2Rcp_lookup(%rdx,%rcx), %xmm13
+        movhpd    _Log2Rcp_lookup(%rdx,%r9), %xmm12
+        addpd     %xmm10, %xmm13
+        addpd     %xmm6, %xmm12
+        addpd     %xmm13, %xmm2
+        addpd     %xmm12, %xmm1
+        mulpd     %xmm7, %xmm2
+        mulpd     %xmm11, %xmm1
+        movups __dbInvLn2(%rdx), %xmm11
+        movdqa    %xmm4, %xmm12
+        movaps    %xmm11, %xmm10
+        mulpd     %xmm2, %xmm10
+        mulpd     %xmm1, %xmm11
+
+/* to round down; if dR is an integer we will get R = 1, which is ok */
+        movaps    %xmm10, %xmm8
+        movaps    %xmm11, %xmm9
+        subpd __dbHALF(%rdx), %xmm8
+        subpd __dbHALF(%rdx), %xmm9
+        addpd __dbShifter(%rdx), %xmm8
+        addpd __dbShifter(%rdx), %xmm9
+        movaps    %xmm8, %xmm6
+        movaps    %xmm9, %xmm7
+        subpd __dbShifter(%rdx), %xmm6
+        subpd __dbShifter(%rdx), %xmm7
+
+/* [0..1) */
+        subpd     %xmm6, %xmm10
+        subpd     %xmm7, %xmm11
+        mulpd __dbC1(%rdx), %xmm10
+        mulpd __dbC1(%rdx), %xmm11
+
+/* hi bits */
+        shufps    $221, %xmm1, %xmm2
+        movdqu _NMAXVAL(%rdx), %xmm1
+        pcmpgtd   %xmm1, %xmm12
+        pcmpeqd   %xmm1, %xmm4
+        por       %xmm4, %xmm12
+        movdqa    %xmm3, %xmm1
+        movdqu _INF(%rdx), %xmm4
+        pcmpgtd   %xmm4, %xmm1
+        pcmpeqd   %xmm4, %xmm3
+
+/* iAbsX = iAbsX&iAbsMask */
+        pand __iAbsMask(%rdx), %xmm2
+        por       %xmm3, %xmm1
+
+/* iRangeMask = (iAbsX>iDomainRange) */
+        pcmpgtd __iDomainRange(%rdx), %xmm2
+        por       %xmm1, %xmm12
+        movups __lbLOWKBITS(%rdx), %xmm3
+        por       %xmm2, %xmm12
+
+/* low K bits */
+        movaps    %xmm3, %xmm2
+        andps     %xmm9, %xmm3
+        andps     %xmm8, %xmm2
+        psrlq     $11, %xmm8
+
+/* dpP= _dbT+lJ*T_ITEM_GRAN */
+        movd      %xmm2, %r10d
+        psrlq     $11, %xmm9
+        movd      %xmm3, %ecx
+
+/* NB : including +/- sign for the exponent!! */
+        psllq     $52, %xmm8
+        psllq     $52, %xmm9
+        pextrw    $4, %xmm2, %r11d
+        pextrw    $4, %xmm3, %r8d
+        movmskps  %xmm12, %eax
+        shll      $3, %r10d
+        shll      $3, %ecx
+        shll      $3, %r11d
+        shll      $3, %r8d
+        movq      13952(%rdx,%r10), %xmm6
+        movq      13952(%rdx,%rcx), %xmm7
+        movhpd    13952(%rdx,%r11), %xmm6
+        movhpd    13952(%rdx,%r8), %xmm7
+        mulpd     %xmm6, %xmm10
+        mulpd     %xmm7, %xmm11
+        addpd     %xmm10, %xmm6
+        addpd     %xmm11, %xmm7
+        paddq     %xmm8, %xmm6
+        paddq     %xmm9, %xmm7
+        cvtpd2ps  %xmm6, %xmm1
+        cvtpd2ps  %xmm7, %xmm4
+        movlhps   %xmm4, %xmm1
+        testl     %eax, %eax
+        jne       .LBL_1_3
+
+.LBL_1_2:
+        cfi_remember_state
+        movups    112(%rsp), %xmm8
+        movaps    %xmm1, %xmm0
+        movups    96(%rsp), %xmm9
+        movups    176(%rsp), %xmm10
+        movups    80(%rsp), %xmm11
+        movups    208(%rsp), %xmm12
+        movups    48(%rsp), %xmm13
+        movups    144(%rsp), %xmm14
+        movups    160(%rsp), %xmm15
+        movq      %rbp, %rsp
+        cfi_def_cfa_register (%rsp)
+        popq      %rbp
+        cfi_adjust_cfa_offset (-8)
+        cfi_restore (%rbp)
+        ret
+
+.LBL_1_3:
+        cfi_restore_state
+        movups    %xmm0, 64(%rsp)
+        movups    %xmm5, 128(%rsp)
+        movups    %xmm1, 192(%rsp)
+        je        .LBL_1_2
+
+        xorb      %cl, %cl
+        xorl      %edx, %edx
+        movq      %rsi, 8(%rsp)
+        movq      %rdi, (%rsp)
+        movq      %r12, 40(%rsp)
+        cfi_offset_rel_rsp (12, 40)
+        movb      %cl, %r12b
+        movq      %r13, 32(%rsp)
+        cfi_offset_rel_rsp (13, 32)
+        movl      %eax, %r13d
+        movq      %r14, 24(%rsp)
+        cfi_offset_rel_rsp (14, 24)
+        movl      %edx, %r14d
+        movq      %r15, 16(%rsp)
+        cfi_offset_rel_rsp (15, 16)
+        cfi_remember_state
+
+.LBL_1_6:
+        btl       %r14d, %r13d
+        jc        .LBL_1_12
+
+.LBL_1_7:
+        lea       1(%r14), %esi
+        btl       %esi, %r13d
+        jc        .LBL_1_10
+
+.LBL_1_8:
+        incb      %r12b
+        addl      $2, %r14d
+        cmpb      $16, %r12b
+        jb        .LBL_1_6
+
+        movq      8(%rsp), %rsi
+        movq      (%rsp), %rdi
+        movq      40(%rsp), %r12
+        cfi_restore (%r12)
+        movq      32(%rsp), %r13
+        cfi_restore (%r13)
+        movq      24(%rsp), %r14
+        cfi_restore (%r14)
+        movq      16(%rsp), %r15
+        cfi_restore (%r15)
+        movups    192(%rsp), %xmm1
+        jmp       .LBL_1_2
+
+.LBL_1_10:
+        cfi_restore_state
+        movzbl    %r12b, %r15d
+        movss     68(%rsp,%r15,8), %xmm0
+        movss     132(%rsp,%r15,8), %xmm1
+
+        call      powf@PLT
+
+        movss     %xmm0, 196(%rsp,%r15,8)
+        jmp       .LBL_1_8
+
+.LBL_1_12:
+        movzbl    %r12b, %r15d
+        movss     64(%rsp,%r15,8), %xmm0
+        movss     128(%rsp,%r15,8), %xmm1
+
+        call      powf@PLT
+
+        movss     %xmm0, 192(%rsp,%r15,8)
+        jmp       .LBL_1_7
+
+END (_ZGVbN4vv_powf_sse4)
diff --git a/sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core.S b/sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core.S
new file mode 100644 (file)
index 0000000..4552e57
--- /dev/null
@@ -0,0 +1,38 @@
+/* Multiple versions of vectorized powf.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+    Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include <init-arch.h>
+
+       .text
+ENTRY (_ZGVdN8vv_powf)
+        .type   _ZGVdN8vv_powf, @gnu_indirect_function
+        cmpl    $0, KIND_OFFSET+__cpu_features(%rip)
+        jne     1f
+        call    __init_cpu_features
+1:      leaq    _ZGVdN8vv_powf_avx2(%rip), %rax
+        testl   $bit_AVX2_Usable, __cpu_features+FEATURE_OFFSET+index_AVX2_Usable(%rip)
+        jz      2f
+        ret
+2:      leaq    _ZGVdN8vv_powf_sse_wrapper(%rip), %rax
+        ret
+END (_ZGVdN8vv_powf)
+libmvec_hidden_def (_ZGVdN8vv_powf)
+
+#define _ZGVdN8vv_powf _ZGVdN8vv_powf_sse_wrapper
+#include "../svml_s_powf8_core.S"
diff --git a/sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core_avx2.S b/sysdeps/x86_64/fpu/multiarch/svml_s_powf8_core_avx2.S
new file mode 100644 (file)
index 0000000..cfb86c7
--- /dev/null
@@ -0,0 +1,357 @@
+/* Function powf vectorized with AVX2.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include "svml_s_powf_data.h"
+
+       .text
+ENTRY(_ZGVdN8vv_powf_avx2)
+/*
+   ALGORITHM DESCRIPTION:
+
+     We are using the next identity : pow(x,y) = 2^(y * log2(x)).
+
+     1) log2(x) calculation
+        Here we use the following formula.
+        Let |x|=2^k1*X1, where k1 is integer, 1<=X1<2.
+        Let C ~= 1/ln(2),
+        Rcp1 ~= 1/X1,   X2=Rcp1*X1,
+        Rcp2 ~= 1/X2,   X3=Rcp2*X2,
+        Rcp3 ~= 1/X3,   Rcp3C ~= C/X3.
+        Then
+          log2|x| = k1 + log2(1/Rcp1) + log2(1/Rcp2) + log2(C/Rcp3C) +
+                    log2(X1*Rcp1*Rcp2*Rcp3C/C),
+        where X1*Rcp1*Rcp2*Rcp3C = C*(1+q), q is very small.
+
+        The values of Rcp1, log2(1/Rcp1), Rcp2, log2(1/Rcp2),
+        Rcp3C, log2(C/Rcp3C) are taken from tables.
+        Values of Rcp1, Rcp2, Rcp3C are such that RcpC=Rcp1*Rcp2*Rcp3C
+        is exactly represented in target precision.
+
+        log2(X1*Rcp1*Rcp2*Rcp3C/C) = log2(1+q) = ln(1+q)/ln2 =
+             = 1/(ln2)*q - 1/(2ln2)*q^2 + 1/(3ln2)*q^3 - ... =
+             = 1/(C*ln2)*cq - 1/(2*C^2*ln2)*cq^2 + 1/(3*C^3*ln2)*cq^3 - ... =
+             = (1 + a1)*cq + a2*cq^2 + a3*cq^3 + ...,
+        where
+             cq=X1*Rcp1*Rcp2*Rcp3C-C,
+             a1=1/(C*ln(2))-1 is small,
+             a2=1/(2*C^2*ln2),
+             a3=1/(3*C^3*ln2),
+                  ...
+        Log2 result is split by three parts: HH+HL+HLL
+
+     2) Calculation of y*log2(x)
+        Split y into YHi+YLo.
+        Get high PH and medium PL parts of y*log2|x|.
+        Get low PLL part of y*log2|x|.
+        Now we have PH+PL+PLL ~= y*log2|x|.
+
+     3) Calculation of 2^(y*log2(x))
+        Let's represent PH+PL+PLL in the form N + j/2^expK + Z,
+        where expK=7 in this implementation, N and j are integers,
+        0<=j<=2^expK-1, |Z|<2^(-expK-1). Hence
+        2^(PH+PL+PLL) ~= 2^N * 2^(j/2^expK) * 2^Z,
+        where 2^(j/2^expK) is stored in a table, and
+        2^Z ~= 1 + B1*Z + B2*Z^2 ... + B5*Z^5.
+        We compute 2^(PH+PL+PLL) as follows:
+        Break PH into PHH + PHL, where PHH = N + j/2^expK.
+        Z = PHL + PL + PLL
+        Exp2Poly = B1*Z + B2*Z^2 ... + B5*Z^5
+        Get 2^(j/2^expK) from table in the form THI+TLO.
+        Now we have 2^(PH+PL+PLL) ~= 2^N * (THI + TLO) * (1 + Exp2Poly).
+        Get significand of 2^(PH+PL+PLL) in the form ResHi+ResLo:
+        ResHi := THI
+        ResLo := THI * Exp2Poly + TLO
+        Get exponent ERes of the result:
+        Res := ResHi + ResLo:
+        Result := ex(Res) + N.  */
+
+        pushq     %rbp
+        cfi_adjust_cfa_offset (8)
+        cfi_rel_offset (%rbp, 0)
+        movq      %rsp, %rbp
+        cfi_def_cfa_register (%rbp)
+        andq      $-64, %rsp
+        subq      $448, %rsp
+        lea       __VPACK_ODD_ind.6357.0.1(%rip), %rcx
+        vmovups   %ymm14, 320(%rsp)
+
+/* hi bits */
+        lea       __VPACK_ODD_ind.6358.0.1(%rip), %rax
+        vmovups   %ymm12, 256(%rsp)
+        vmovups   %ymm9, 96(%rsp)
+        vmovups   %ymm13, 224(%rsp)
+        vmovups   %ymm15, 352(%rsp)
+        vmovups   %ymm11, 384(%rsp)
+        vmovups   %ymm10, 288(%rsp)
+        vmovups   (%rcx), %ymm10
+        vmovups   %ymm8, 160(%rsp)
+        vmovdqa   %ymm1, %ymm9
+        movq      __svml_spow_data@GOTPCREL(%rip), %rdx
+        vextractf128 $1, %ymm0, %xmm7
+        vcvtps2pd %xmm0, %ymm14
+        vcvtps2pd %xmm7, %ymm12
+        vpsubd _NMINNORM(%rdx), %ymm0, %ymm7
+
+/* preserve mantissa, set input exponent to 2^(-10) */
+        vandpd _ExpMask(%rdx), %ymm14, %ymm3
+        vandpd _ExpMask(%rdx), %ymm12, %ymm13
+
+/* exponent bits selection */
+        vpsrlq    $20, %ymm12, %ymm12
+        vpsrlq    $20, %ymm14, %ymm14
+        vextractf128 $1, %ymm9, %xmm2
+        vcvtps2pd %xmm9, %ymm1
+        vpand _ABSMASK(%rdx), %ymm9, %ymm8
+        vcvtps2pd %xmm2, %ymm6
+        vorpd _Two10(%rdx), %ymm3, %ymm2
+        vorpd _Two10(%rdx), %ymm13, %ymm3
+
+/* reciprocal approximation good to at least 11 bits */
+        vcvtpd2ps %ymm2, %xmm5
+        vcvtpd2ps %ymm3, %xmm15
+        vrcpps    %xmm5, %xmm4
+        vrcpps    %xmm15, %xmm11
+        vcvtps2pd %xmm4, %ymm13
+        vcvtps2pd %xmm11, %ymm4
+        vpermps   %ymm12, %ymm10, %ymm11
+
+/* round reciprocal to nearest integer, will have 1+9 mantissa bits */
+        vroundpd  $0, %ymm13, %ymm12
+        vpermps   %ymm14, %ymm10, %ymm5
+        vroundpd  $0, %ymm4, %ymm14
+        vmovupd _One(%rdx), %ymm4
+
+/* table lookup */
+        vpsrlq    $40, %ymm12, %ymm10
+        vfmsub213pd %ymm4, %ymm12, %ymm2
+        vfmsub213pd %ymm4, %ymm14, %ymm3
+        vcmpgt_oqpd _Threshold(%rdx), %ymm12, %ymm12
+        vxorpd    %ymm4, %ymm4, %ymm4
+        vandpd _Bias(%rdx), %ymm12, %ymm12
+
+/* biased exponent in DP format */
+        vcvtdq2pd %xmm11, %ymm13
+        vpcmpeqd  %ymm11, %ymm11, %ymm11
+        vgatherqpd %ymm11, _Log2Rcp_lookup(%rdx,%ymm10), %ymm4
+        vpsrlq    $40, %ymm14, %ymm10
+        vcmpgt_oqpd _Threshold(%rdx), %ymm14, %ymm14
+        vpcmpeqd  %ymm11, %ymm11, %ymm11
+        vandpd _Bias(%rdx), %ymm14, %ymm14
+        vcvtdq2pd %xmm5, %ymm15
+        vxorpd    %ymm5, %ymm5, %ymm5
+        vgatherqpd %ymm11, _Log2Rcp_lookup(%rdx,%ymm10), %ymm5
+        vorpd _Bias1(%rdx), %ymm12, %ymm11
+        vorpd _Bias1(%rdx), %ymm14, %ymm10
+        vsubpd    %ymm11, %ymm15, %ymm11
+        vsubpd    %ymm10, %ymm13, %ymm14
+        vmovupd _poly_coeff_4(%rdx), %ymm15
+        vmovupd _poly_coeff_3(%rdx), %ymm13
+        vmulpd    %ymm3, %ymm3, %ymm10
+        vfmadd213pd %ymm15, %ymm3, %ymm13
+        vmovdqa   %ymm15, %ymm12
+        vfmadd231pd _poly_coeff_3(%rdx), %ymm2, %ymm12
+        vmulpd    %ymm2, %ymm2, %ymm15
+
+/* reconstruction */
+        vfmadd213pd %ymm3, %ymm10, %ymm13
+        vfmadd213pd %ymm2, %ymm15, %ymm12
+        vaddpd    %ymm5, %ymm13, %ymm13
+        vaddpd    %ymm4, %ymm12, %ymm2
+        vfmadd231pd _L2(%rdx), %ymm14, %ymm13
+        vfmadd132pd _L2(%rdx), %ymm2, %ymm11
+        vmulpd    %ymm6, %ymm13, %ymm2
+        vmulpd    %ymm1, %ymm11, %ymm10
+        vmulpd __dbInvLn2(%rdx), %ymm2, %ymm6
+        vmulpd __dbInvLn2(%rdx), %ymm10, %ymm15
+
+/* to round down; if dR is an integer we will get R = 1, which is ok */
+        vsubpd __dbHALF(%rdx), %ymm6, %ymm3
+        vsubpd __dbHALF(%rdx), %ymm15, %ymm1
+        vaddpd __dbShifter(%rdx), %ymm3, %ymm13
+        vaddpd __dbShifter(%rdx), %ymm1, %ymm14
+        vsubpd __dbShifter(%rdx), %ymm13, %ymm12
+        vmovups   (%rax), %ymm1
+        vsubpd __dbShifter(%rdx), %ymm14, %ymm11
+
+/* [0..1) */
+        vsubpd    %ymm12, %ymm6, %ymm6
+        vpermps   %ymm10, %ymm1, %ymm3
+        vpermps   %ymm2, %ymm1, %ymm10
+        vpcmpgtd _NMAXVAL(%rdx), %ymm7, %ymm4
+        vpcmpgtd _INF(%rdx), %ymm8, %ymm1
+        vpcmpeqd _NMAXVAL(%rdx), %ymm7, %ymm7
+        vpcmpeqd _INF(%rdx), %ymm8, %ymm8
+        vpor      %ymm7, %ymm4, %ymm2
+        vpor      %ymm8, %ymm1, %ymm1
+        vsubpd    %ymm11, %ymm15, %ymm7
+        vinsertf128 $1, %xmm10, %ymm3, %ymm10
+        vpor      %ymm1, %ymm2, %ymm3
+
+/* iAbsX = iAbsX&iAbsMask */
+        vandps __iAbsMask(%rdx), %ymm10, %ymm10
+
+/* iRangeMask = (iAbsX>iDomainRange) */
+        vpcmpgtd __iDomainRange(%rdx), %ymm10, %ymm4
+        vpor      %ymm4, %ymm3, %ymm5
+        vmulpd __dbC1(%rdx), %ymm7, %ymm4
+        vmovmskps %ymm5, %ecx
+        vmulpd __dbC1(%rdx), %ymm6, %ymm5
+
+/* low K bits */
+        vandps __lbLOWKBITS(%rdx), %ymm14, %ymm6
+
+/* dpP= _dbT+lJ*T_ITEM_GRAN */
+        vxorpd    %ymm7, %ymm7, %ymm7
+        vpcmpeqd  %ymm1, %ymm1, %ymm1
+        vandps __lbLOWKBITS(%rdx), %ymm13, %ymm2
+        vxorpd    %ymm10, %ymm10, %ymm10
+        vpcmpeqd  %ymm3, %ymm3, %ymm3
+        vgatherqpd %ymm1, 13952(%rdx,%ymm6,8), %ymm7
+        vgatherqpd %ymm3, 13952(%rdx,%ymm2,8), %ymm10
+        vpsrlq    $11, %ymm14, %ymm14
+        vpsrlq    $11, %ymm13, %ymm13
+        vfmadd213pd %ymm7, %ymm4, %ymm7
+        vfmadd213pd %ymm10, %ymm5, %ymm10
+
+/* NB : including +/- sign for the exponent!! */
+        vpsllq    $52, %ymm14, %ymm8
+        vpsllq    $52, %ymm13, %ymm11
+        vpaddq    %ymm8, %ymm7, %ymm12
+        vpaddq    %ymm11, %ymm10, %ymm1
+        vcvtpd2ps %ymm12, %xmm15
+        vcvtpd2ps %ymm1, %xmm2
+        vinsertf128 $1, %xmm2, %ymm15, %ymm1
+        testl     %ecx, %ecx
+        jne       .LBL_1_3
+
+.LBL_1_2:
+        cfi_remember_state
+        vmovups   160(%rsp), %ymm8
+        vmovups   96(%rsp), %ymm9
+        vmovups   288(%rsp), %ymm10
+        vmovups   384(%rsp), %ymm11
+        vmovups   256(%rsp), %ymm12
+        vmovups   224(%rsp), %ymm13
+        vmovups   320(%rsp), %ymm14
+        vmovups   352(%rsp), %ymm15
+        vmovdqa   %ymm1, %ymm0
+        movq      %rbp, %rsp
+        cfi_def_cfa_register (%rsp)
+        popq      %rbp
+        cfi_adjust_cfa_offset (-8)
+        cfi_restore (%rbp)
+        ret
+
+.LBL_1_3:
+        cfi_restore_state
+        vmovups   %ymm0, 64(%rsp)
+        vmovups   %ymm9, 128(%rsp)
+        vmovups   %ymm1, 192(%rsp)
+        je        .LBL_1_2
+
+        xorb      %dl, %dl
+        xorl      %eax, %eax
+        movq      %rsi, 8(%rsp)
+        movq      %rdi, (%rsp)
+        movq      %r12, 40(%rsp)
+        cfi_offset_rel_rsp (12, 40)
+        movb      %dl, %r12b
+        movq      %r13, 32(%rsp)
+        cfi_offset_rel_rsp (13, 32)
+        movl      %ecx, %r13d
+        movq      %r14, 24(%rsp)
+        cfi_offset_rel_rsp (14, 24)
+        movl      %eax, %r14d
+        movq      %r15, 16(%rsp)
+        cfi_offset_rel_rsp (15, 16)
+        cfi_remember_state
+
+.LBL_1_6:
+        btl       %r14d, %r13d
+        jc        .LBL_1_12
+
+.LBL_1_7:
+        lea       1(%r14), %esi
+        btl       %esi, %r13d
+        jc        .LBL_1_10
+
+.LBL_1_8:
+        incb      %r12b
+        addl      $2, %r14d
+        cmpb      $16, %r12b
+        jb        .LBL_1_6
+
+        movq      8(%rsp), %rsi
+        movq      (%rsp), %rdi
+        movq      40(%rsp), %r12
+        cfi_restore (%r12)
+        movq      32(%rsp), %r13
+        cfi_restore (%r13)
+        movq      24(%rsp), %r14
+        cfi_restore (%r14)
+        movq      16(%rsp), %r15
+        cfi_restore (%r15)
+        vmovups   192(%rsp), %ymm1
+        jmp       .LBL_1_2
+
+.LBL_1_10:
+        cfi_restore_state
+        movzbl    %r12b, %r15d
+        vmovss    68(%rsp,%r15,8), %xmm0
+        vmovss    132(%rsp,%r15,8), %xmm1
+        vzeroupper
+
+        call      powf@PLT
+
+        vmovss    %xmm0, 196(%rsp,%r15,8)
+        jmp       .LBL_1_8
+
+.LBL_1_12:
+        movzbl    %r12b, %r15d
+        vmovss    64(%rsp,%r15,8), %xmm0
+        vmovss    128(%rsp,%r15,8), %xmm1
+        vzeroupper
+
+        call      powf@PLT
+
+        vmovss    %xmm0, 192(%rsp,%r15,8)
+        jmp       .LBL_1_7
+
+END(_ZGVdN8vv_powf_avx2)
+
+       .section .rodata, "a"
+__VPACK_ODD_ind.6357.0.1:
+       .long   1
+       .long   3
+       .long   5
+       .long   7
+       .long   0
+       .long   0
+       .long   0
+       .long   0
+       .space 32, 0x00
+__VPACK_ODD_ind.6358.0.1:
+       .long   1
+       .long   3
+       .long   5
+       .long   7
+       .long   0
+       .long   0
+       .long   0
+       .long   0
diff --git a/sysdeps/x86_64/fpu/svml_s_powf16_core.S b/sysdeps/x86_64/fpu/svml_s_powf16_core.S
new file mode 100644 (file)
index 0000000..efd84c2
--- /dev/null
@@ -0,0 +1,25 @@
+/* Function powf vectorized with AVX-512. Wrapper to AVX2 version.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include "svml_s_wrapper_impl.h"
+
+       .text
+ENTRY (_ZGVeN16vv_powf)
+WRAPPER_IMPL_AVX512_ff _ZGVdN8vv_powf
+END (_ZGVeN16vv_powf)
diff --git a/sysdeps/x86_64/fpu/svml_s_powf4_core.S b/sysdeps/x86_64/fpu/svml_s_powf4_core.S
new file mode 100644 (file)
index 0000000..81f0f53
--- /dev/null
@@ -0,0 +1,29 @@
+/* Function powf vectorized with SSE2.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include "svml_s_wrapper_impl.h"
+
+       .text
+ENTRY (_ZGVbN4vv_powf)
+WRAPPER_IMPL_SSE2_ff powf
+END (_ZGVbN4vv_powf)
+
+#ifndef USE_MULTIARCH
+ libmvec_hidden_def (_ZGVbN4vv_powf)
+#endif
diff --git a/sysdeps/x86_64/fpu/svml_s_powf8_core.S b/sysdeps/x86_64/fpu/svml_s_powf8_core.S
new file mode 100644 (file)
index 0000000..8fed6c7
--- /dev/null
@@ -0,0 +1,29 @@
+/* Function powf vectorized with AVX2, wrapper version.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include "svml_s_wrapper_impl.h"
+
+       .text
+ENTRY (_ZGVdN8vv_powf)
+WRAPPER_IMPL_AVX_ff _ZGVbN4vv_powf
+END (_ZGVdN8vv_powf)
+
+#ifndef USE_MULTIARCH
+ libmvec_hidden_def (_ZGVdN8vv_powf)
+#endif
diff --git a/sysdeps/x86_64/fpu/svml_s_powf8_core_avx.S b/sysdeps/x86_64/fpu/svml_s_powf8_core_avx.S
new file mode 100644 (file)
index 0000000..eeeb66d
--- /dev/null
@@ -0,0 +1,25 @@
+/* Function powf vectorized in AVX ISA as wrapper to SSE4 ISA version.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+#include "svml_s_wrapper_impl.h"
+
+        .text
+ENTRY(_ZGVcN8vv_powf)
+WRAPPER_IMPL_AVX_ff _ZGVbN4vv_powf
+END(_ZGVcN8vv_powf)
diff --git a/sysdeps/x86_64/fpu/svml_s_powf_data.S b/sysdeps/x86_64/fpu/svml_s_powf_data.S
new file mode 100644 (file)
index 0000000..4a4799a
--- /dev/null
@@ -0,0 +1,3759 @@
+/* Data for function powf.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include "svml_s_powf_data.h"
+
+       .section .rodata, "a"
+       .align 64
+
+/* Data table for vector implementations of function powf.
+   The table may contain polynomial, reduction, lookup coefficients and
+   other coefficients obtained through different methods of research
+   and experimental work.  */
+
+       .globl __svml_spow_data
+__svml_spow_data:
+
+/* General purpose constants for H+L multiplication:
+ * NMINNORM */
+float_vector _NMINNORM 0x80800000
+
+/* NMAXVAL */
+float_vector _NMAXVAL 0xfeffffff
+
+/* INF */
+float_vector _INF 0x7f800000
+
+/* ABSMASK */
+float_vector _ABSMASK 0x7fffffff
+
+/* DOMAINRANGE */
+float_vector _DOMAINRANGE 0x42ae9a00
+
+/* Log(2) lookup High+Low table for logarithmic part */
+.if .-__svml_spow_data != _Log_HA_table
+.err
+.endif
+       .quad   0xc086232bdd7a8300
+       .quad   0xbe1ce91eef3fb100
+       .quad   0xc086232fdc7ad828
+       .quad   0xbe1cefcffda73b6a
+       .quad   0xc0862333d97d2ba0
+       .quad   0xbe1cef406748f1ff
+       .quad   0xc0862337d48378e0
+       .quad   0xbe1cef2a9429925a
+       .quad   0xc086233bcd8fb878
+       .quad   0xbe1cf138d17ebecb
+       .quad   0xc086233fc4a3e018
+       .quad   0xbe1ceff2dbbbb29e
+       .quad   0xc0862343b9c1e270
+       .quad   0xbe1cf1a42aae437b
+       .quad   0xc0862347acebaf68
+       .quad   0xbe1cef3b152048af
+       .quad   0xc086234b9e2333f0
+       .quad   0xbe1cef20e127805e
+       .quad   0xc086234f8d6a5a30
+       .quad   0xbe1cf00ad6052cf4
+       .quad   0xc08623537ac30980
+       .quad   0xbe1cefc4642ee597
+       .quad   0xc0862357662f2660
+       .quad   0xbe1cf1f277d36e16
+       .quad   0xc086235b4fb092a0
+       .quad   0xbe1ceed009e8d8e6
+       .quad   0xc086235f37492d28
+       .quad   0xbe1cf1e4038cb362
+       .quad   0xc08623631cfad250
+       .quad   0xbe1cf0b0873b8557
+       .quad   0xc086236700c75b98
+       .quad   0xbe1cf15bb3227c0b
+       .quad   0xc086236ae2b09fe0
+       .quad   0xbe1cf151ef8ca9ed
+       .quad   0xc086236ec2b87358
+       .quad   0xbe1cefe1dc2cd2ed
+       .quad   0xc0862372a0e0a780
+       .quad   0xbe1cf0d1eec5454f
+       .quad   0xc08623767d2b0b48
+       .quad   0xbe1ceeefd570bbce
+       .quad   0xc086237a57996af0
+       .quad   0xbe1cee99ae91b3a7
+       .quad   0xc086237e302d9028
+       .quad   0xbe1cf0412830fbd1
+       .quad   0xc086238206e94218
+       .quad   0xbe1ceee898588610
+       .quad   0xc0862385dbce4548
+       .quad   0xbe1cee9a1fbcaaea
+       .quad   0xc0862389aede5bc0
+       .quad   0xbe1ceed8e7cc1ad6
+       .quad   0xc086238d801b4500
+       .quad   0xbe1cf10c8d059da6
+       .quad   0xc08623914f86be18
+       .quad   0xbe1ceee6c63a8165
+       .quad   0xc08623951d228180
+       .quad   0xbe1cf0c3592d2ff1
+       .quad   0xc0862398e8f04758
+       .quad   0xbe1cf0026cc4cb1b
+       .quad   0xc086239cb2f1c538
+       .quad   0xbe1cf15d48d8e670
+       .quad   0xc08623a07b28ae60
+       .quad   0xbe1cef359363787c
+       .quad   0xc08623a44196b390
+       .quad   0xbe1cefdf1ab2e82c
+       .quad   0xc08623a8063d8338
+       .quad   0xbe1cefe43c02aa84
+       .quad   0xc08623abc91ec960
+       .quad   0xbe1cf044f5ae35b7
+       .quad   0xc08623af8a3c2fb8
+       .quad   0xbe1cf0b0b4001e1b
+       .quad   0xc08623b349975d98
+       .quad   0xbe1cf1bae76dfbcf
+       .quad   0xc08623b70731f810
+       .quad   0xbe1cef0a72e13a62
+       .quad   0xc08623bac30da1c8
+       .quad   0xbe1cf184007d2b6b
+       .quad   0xc08623be7d2bfb40
+       .quad   0xbe1cf16f4b239e98
+       .quad   0xc08623c2358ea2a0
+       .quad   0xbe1cf0976acada87
+       .quad   0xc08623c5ec3733d0
+       .quad   0xbe1cf066318a16ff
+       .quad   0xc08623c9a1274880
+       .quad   0xbe1ceffaa7148798
+       .quad   0xc08623cd54607820
+       .quad   0xbe1cf23ab02e9b6e
+       .quad   0xc08623d105e45800
+       .quad   0xbe1cefdfef7d4fde
+       .quad   0xc08623d4b5b47b20
+       .quad   0xbe1cf17fece44f2b
+       .quad   0xc08623d863d27270
+       .quad   0xbe1cf18f907d0d7c
+       .quad   0xc08623dc103fccb0
+       .quad   0xbe1cee61fe072c98
+       .quad   0xc08623dfbafe1668
+       .quad   0xbe1cf022dd891e2f
+       .quad   0xc08623e3640eda20
+       .quad   0xbe1ceecc1daf4358
+       .quad   0xc08623e70b73a028
+       .quad   0xbe1cf0173c4fa380
+       .quad   0xc08623eab12deec8
+       .quad   0xbe1cf16a2150c2f4
+       .quad   0xc08623ee553f4a30
+       .quad   0xbe1cf1bf980b1f4b
+       .quad   0xc08623f1f7a93480
+       .quad   0xbe1cef8b731663c2
+       .quad   0xc08623f5986d2dc0
+       .quad   0xbe1cee9a664d7ef4
+       .quad   0xc08623f9378cb3f0
+       .quad   0xbe1cf1eda2af6400
+       .quad   0xc08623fcd5094320
+       .quad   0xbe1cf1923f9d68d7
+       .quad   0xc086240070e45548
+       .quad   0xbe1cf0747cd3e03a
+       .quad   0xc08624040b1f6260
+       .quad   0xbe1cf22ee855bd6d
+       .quad   0xc0862407a3bbe078
+       .quad   0xbe1cf0d57360c00b
+       .quad   0xc086240b3abb4398
+       .quad   0xbe1ceebc815cd575
+       .quad   0xc086240ed01efdd0
+       .quad   0xbe1cf03bfb970951
+       .quad   0xc086241263e87f50
+       .quad   0xbe1cf16e74768529
+       .quad   0xc0862415f6193658
+       .quad   0xbe1cefec64b8becb
+       .quad   0xc086241986b28f30
+       .quad   0xbe1cf0838d210baa
+       .quad   0xc086241d15b5f448
+       .quad   0xbe1cf0ea86e75b11
+       .quad   0xc0862420a324ce28
+       .quad   0xbe1cf1708d11d805
+       .quad   0xc08624242f008380
+       .quad   0xbe1ceea988c5a417
+       .quad   0xc0862427b94a7910
+       .quad   0xbe1cef166a7bbca5
+       .quad   0xc086242b420411d0
+       .quad   0xbe1cf0c9d9e86a38
+       .quad   0xc086242ec92eaee8
+       .quad   0xbe1cef0946455411
+       .quad   0xc08624324ecbaf98
+       .quad   0xbe1cefea60907739
+       .quad   0xc0862435d2dc7160
+       .quad   0xbe1cf1ed0934ce42
+       .quad   0xc086243955624ff8
+       .quad   0xbe1cf191ba746c7d
+       .quad   0xc086243cd65ea548
+       .quad   0xbe1ceeec78cf2a7e
+       .quad   0xc086244055d2c968
+       .quad   0xbe1cef345284c119
+       .quad   0xc0862443d3c012b8
+       .quad   0xbe1cf24f77355219
+       .quad   0xc08624475027d5e8
+       .quad   0xbe1cf05bf087e114
+       .quad   0xc086244acb0b65d0
+       .quad   0xbe1cef3504a32189
+       .quad   0xc086244e446c1398
+       .quad   0xbe1ceff54b2a406f
+       .quad   0xc0862451bc4b2eb8
+       .quad   0xbe1cf0757d54ed4f
+       .quad   0xc086245532aa04f0
+       .quad   0xbe1cf0c8099fdfd5
+       .quad   0xc0862458a789e250
+       .quad   0xbe1cf0b173796a31
+       .quad   0xc086245c1aec1138
+       .quad   0xbe1cf11d8734540d
+       .quad   0xc086245f8cd1da60
+       .quad   0xbe1cf1916a723ceb
+       .quad   0xc0862462fd3c84d8
+       .quad   0xbe1cf19a911e1da7
+       .quad   0xc08624666c2d5608
+       .quad   0xbe1cf23a9ef72e4f
+       .quad   0xc0862469d9a591c0
+       .quad   0xbe1cef503d947663
+       .quad   0xc086246d45a67a18
+       .quad   0xbe1cf0fceeb1a0b2
+       .quad   0xc0862470b0314fa8
+       .quad   0xbe1cf107e27e4fbc
+       .quad   0xc086247419475160
+       .quad   0xbe1cf03dd9922331
+       .quad   0xc086247780e9bc98
+       .quad   0xbe1cefce1a10e129
+       .quad   0xc086247ae719cd18
+       .quad   0xbe1ceea47f73c4f6
+       .quad   0xc086247e4bd8bd10
+       .quad   0xbe1ceec0ac56d100
+       .quad   0xc0862481af27c528
+       .quad   0xbe1cee8a6593278a
+       .quad   0xc086248511081c70
+       .quad   0xbe1cf2231dd9dec7
+       .quad   0xc0862488717af888
+       .quad   0xbe1cf0b4b8ed7da8
+       .quad   0xc086248bd0818d68
+       .quad   0xbe1cf1bd8d835002
+       .quad   0xc086248f2e1d0d98
+       .quad   0xbe1cf259acc107f4
+       .quad   0xc08624928a4eaa20
+       .quad   0xbe1cee897636b00c
+       .quad   0xc0862495e5179270
+       .quad   0xbe1cee757f20c326
+       .quad   0xc08624993e78f490
+       .quad   0xbe1cefafd3aa54a4
+       .quad   0xc086249c9673fd10
+       .quad   0xbe1cee7298d38b97
+       .quad   0xc086249fed09d6f8
+       .quad   0xbe1ceedc158d4ceb
+       .quad   0xc08624a3423babe0
+       .quad   0xbe1cf2282987cb2e
+       .quad   0xc08624a6960aa400
+       .quad   0xbe1cefe7381ecc4b
+       .quad   0xc08624a9e877e600
+       .quad   0xbe1cef328dbbce80
+       .quad   0xc08624ad39849728
+       .quad   0xbe1cefde45f3cc71
+       .quad   0xc08624b08931db58
+       .quad   0xbe1cefa8b89433b9
+       .quad   0xc08624b3d780d500
+       .quad   0xbe1cef6773c0b139
+       .quad   0xc08624b72472a528
+       .quad   0xbe1cf031c931c11f
+       .quad   0xc08624ba70086b78
+       .quad   0xbe1cf088f49275e7
+       .quad   0xc08624bdba434630
+       .quad   0xbe1cf17de0eaa86d
+       .quad   0xc08624c103245238
+       .quad   0xbe1cefd492f1ba75
+       .quad   0xc08624c44aacab08
+       .quad   0xbe1cf1253e154466
+       .quad   0xc08624c790dd6ad0
+       .quad   0xbe1cf0fb09ee6d55
+       .quad   0xc08624cad5b7aa58
+       .quad   0xbe1cf1f08dd048fe
+       .quad   0xc08624ce193c8120
+       .quad   0xbe1ceeca0809697f
+       .quad   0xc08624d15b6d0538
+       .quad   0xbe1cef8d5662d968
+       .quad   0xc08624d49c4a4b78
+       .quad   0xbe1cee97b556ed78
+       .quad   0xc08624d7dbd56750
+       .quad   0xbe1cf1b14b6acb75
+       .quad   0xc08624db1a0f6b00
+       .quad   0xbe1cef1e860623f2
+       .quad   0xc08624de56f96758
+       .quad   0xbe1ceeaf4d156f3d
+       .quad   0xc08624e192946bf0
+       .quad   0xbe1ceecc12b400ed
+       .quad   0xc08624e4cce18710
+       .quad   0xbe1cf180c40c794f
+       .quad   0xc08624e805e1c5c8
+       .quad   0xbe1cf185a08f7f65
+       .quad   0xc08624eb3d9633d8
+       .quad   0xbe1cef45fc924078
+       .quad   0xc08624ee73ffdbb0
+       .quad   0xbe1cf1e4f457f32a
+       .quad   0xc08624f1a91fc6a0
+       .quad   0xbe1cf040147b8a5a
+       .quad   0xc08624f4dcf6fc98
+       .quad   0xbe1cf1effca0dfb2
+       .quad   0xc08624f80f868468
+       .quad   0xbe1cf0470146e5bc
+       .quad   0xc08624fb40cf6390
+       .quad   0xbe1cef4dd186e501
+       .quad   0xc08624fe70d29e60
+       .quad   0xbe1ceebe257f66c7
+       .quad   0xc08625019f9137f0
+       .quad   0xbe1ceefb7a1c395c
+       .quad   0xc0862504cd0c3220
+       .quad   0xbe1cf209dedfed8c
+       .quad   0xc0862507f9448db0
+       .quad   0xbe1cf082da464994
+       .quad   0xc086250b243b4a18
+       .quad   0xbe1cee88694a73cf
+       .quad   0xc086250e4df165a0
+       .quad   0xbe1cf0b61e8f0531
+       .quad   0xc08625117667dd78
+       .quad   0xbe1cf1106599c962
+       .quad   0xc08625149d9fad98
+       .quad   0xbe1ceff1ee88af1f
+       .quad   0xc0862517c399d0c8
+       .quad   0xbe1cf0f746994ef6
+       .quad   0xc086251ae85740b8
+       .quad   0xbe1cefe8a1d077e4
+       .quad   0xc086251e0bd8f5e0
+       .quad   0xbe1cf1a1da036092
+       .quad   0xc08625212e1fe7a8
+       .quad   0xbe1cf0f8a7786fcd
+       .quad   0xc08625244f2d0c48
+       .quad   0xbe1cefa1174a07a7
+       .quad   0xc08625276f0158d8
+       .quad   0xbe1cef1043aa5b25
+       .quad   0xc086252a8d9dc150
+       .quad   0xbe1cf15d521c169d
+       .quad   0xc086252dab033898
+       .quad   0xbe1cf220bba8861f
+       .quad   0xc0862530c732b078
+       .quad   0xbe1cef51e310eae2
+       .quad   0xc0862533e22d1988
+       .quad   0xbe1cf222fcedd8ae
+       .quad   0xc0862536fbf36370
+       .quad   0xbe1cefdb4da4bda8
+       .quad   0xc086253a14867ca0
+       .quad   0xbe1ceeafc1112171
+       .quad   0xc086253d2be75280
+       .quad   0xbe1cee99dfb4b408
+       .quad   0xc08625404216d160
+       .quad   0xbe1cf22d2536f06b
+       .quad   0xc08625435715e498
+       .quad   0xbe1cef6abbf2e268
+       .quad   0xc08625466ae57648
+       .quad   0xbe1cf093a14789f5
+       .quad   0xc08625497d866fa0
+       .quad   0xbe1cf0f93655603c
+       .quad   0xc086254c8ef9b8b8
+       .quad   0xbe1cf1cc40c9aafc
+       .quad   0xc086254f9f4038a8
+       .quad   0xbe1ceeea5f4e9157
+       .quad   0xc0862552ae5ad568
+       .quad   0xbe1cefa9f52d4997
+       .quad   0xc0862555bc4a7400
+       .quad   0xbe1cefa490a638ff
+       .quad   0xc0862558c90ff868
+       .quad   0xbe1cef7fcf797d6f
+       .quad   0xc086255bd4ac4590
+       .quad   0xbe1cf1b4c51113c9
+       .quad   0xc086255edf203d78
+       .quad   0xbe1cef55e5b4a55d
+       .quad   0xc0862561e86cc100
+       .quad   0xbe1cf0d37a25f9dc
+       .quad   0xc0862564f092b028
+       .quad   0xbe1ceebe9efc19d9
+       .quad   0xc0862567f792e9d8
+       .quad   0xbe1cee8ad30a57b5
+       .quad   0xc086256afd6e4c08
+       .quad   0xbe1cef4e1817b90b
+       .quad   0xc086256e0225b3b8
+       .quad   0xbe1cee7fa9229996
+       .quad   0xc086257105b9fce0
+       .quad   0xbe1cf0b54963d945
+       .quad   0xc0862574082c0298
+       .quad   0xbe1cee5f2f3c7995
+       .quad   0xc0862577097c9ee0
+       .quad   0xbe1cf0828e303a2c
+       .quad   0xc086257a09acaae0
+       .quad   0xbe1cf172c3078947
+       .quad   0xc086257d08bcfec0
+       .quad   0xbe1cf189252afa22
+       .quad   0xc086258006ae71b8
+       .quad   0xbe1cefdb80426923
+       .quad   0xc08625830381da08
+       .quad   0xbe1ceef1391a0372
+       .quad   0xc0862585ff380d00
+       .quad   0xbe1cf17720c78d13
+       .quad   0xc0862588f9d1df18
+       .quad   0xbe1ceef1f9027d83
+       .quad   0xc086258bf35023b8
+       .quad   0xbe1cf06fac99dec9
+       .quad   0xc086258eebb3ad78
+       .quad   0xbe1cf1373eeb45c0
+       .quad   0xc0862591e2fd4e00
+       .quad   0xbe1cef777536bb81
+       .quad   0xc0862594d92dd600
+       .quad   0xbe1cf0f43ca40766
+       .quad   0xc0862597ce461558
+       .quad   0xbe1cefb2cfc6766b
+       .quad   0xc086259ac246daf0
+       .quad   0xbe1ceea49e64ffa2
+       .quad   0xc086259db530f4c8
+       .quad   0xbe1cf250fa457dec
+       .quad   0xc08625a0a7053018
+       .quad   0xbe1cf17d8bb2a44e
+       .quad   0xc08625a397c45918
+       .quad   0xbe1cf1d5906d54b7
+       .quad   0xc08625a6876f3b30
+       .quad   0xbe1cf08fe7b31780
+       .quad   0xc08625a97606a0e0
+       .quad   0xbe1cef13edfc9d11
+       .quad   0xc08625ac638b53c8
+       .quad   0xbe1cef9d2b107219
+       .quad   0xc08625af4ffe1cb0
+       .quad   0xbe1cf1ddd4ff6160
+       .quad   0xc08625b23b5fc390
+       .quad   0xbe1cefa02a996495
+       .quad   0xc08625b525b10f68
+       .quad   0xbe1cf166a7e37ee5
+       .quad   0xc08625b80ef2c680
+       .quad   0xbe1cef0b171068a5
+       .quad   0xc08625baf725ae28
+       .quad   0xbe1cf05c80779283
+       .quad   0xc08625bdde4a8af0
+       .quad   0xbe1cf1bbfbffb889
+       .quad   0xc08625c0c4622090
+       .quad   0xbe1cf0b8666c0124
+       .quad   0xc08625c3a96d31e0
+       .quad   0xbe1cf0a8fcf47a86
+       .quad   0xc08625c68d6c80f0
+       .quad   0xbe1cef46e18cb092
+       .quad   0xc08625c97060cef0
+       .quad   0xbe1cf1458a350efb
+       .quad   0xc08625cc524adc58
+       .quad   0xbe1ceeea1dadce12
+       .quad   0xc08625cf332b68b0
+       .quad   0xbe1cf0a1bfdc44c7
+       .quad   0xc08625d2130332d0
+       .quad   0xbe1cef96d02da73e
+       .quad   0xc08625d4f1d2f8a8
+       .quad   0xbe1cf2451c3c7701
+       .quad   0xc08625d7cf9b7778
+       .quad   0xbe1cf10d08f83812
+       .quad   0xc08625daac5d6ba0
+       .quad   0xbe1ceec5b4895c5e
+       .quad   0xc08625dd881990b0
+       .quad   0xbe1cf14e1325c5e4
+       .quad   0xc08625e062d0a188
+       .quad   0xbe1cf21d0904be12
+       .quad   0xc08625e33c835838
+       .quad   0xbe1ceed0839bcf21
+       .quad   0xc08625e615326df0
+       .quad   0xbe1cf1bb944889d2
+       .quad   0xc08625e8ecde9b48
+       .quad   0xbe1cee738e85eece
+       .quad   0xc08625ebc38897e0
+       .quad   0xbe1cf25c2bc6ef12
+       .quad   0xc08625ee99311ac8
+       .quad   0xbe1cf132b70a41ad
+       .quad   0xc08625f16dd8da28
+       .quad   0xbe1cf1984236a6e3
+       .quad   0xc08625f441808b78
+       .quad   0xbe1cf19ae74998f9
+       .quad   0xc08625f71428e370
+       .quad   0xbe1cef3e175d61a1
+       .quad   0xc08625f9e5d295f8
+       .quad   0xbe1cf101f9868fd9
+       .quad   0xc08625fcb67e5658
+       .quad   0xbe1cee69db83dcd2
+       .quad   0xc08625ff862cd6f8
+       .quad   0xbe1cf081b636af51
+       .quad   0xc086260254dec9a8
+       .quad   0xbe1cee62c7d59b3e
+       .quad   0xc08626052294df58
+       .quad   0xbe1cf1b745c57716
+       .quad   0xc0862607ef4fc868
+       .quad   0xbe1cef3d2800ea23
+       .quad   0xc086260abb103458
+       .quad   0xbe1cef480ff1acd2
+       .quad   0xc086260d85d6d200
+       .quad   0xbe1cf2424c9a17ef
+       .quad   0xc08626104fa44f90
+       .quad   0xbe1cf12cfde90fd5
+       .quad   0xc086261318795a68
+       .quad   0xbe1cf21f590dd5b6
+       .quad   0xc0862615e0569f48
+       .quad   0xbe1cf0c50f9cd28a
+       .quad   0xc0862618a73cca30
+       .quad   0xbe1ceedbdb520545
+       .quad   0xc086261b6d2c8668
+       .quad   0xbe1cf0b030396011
+       .quad   0xc086261e32267e98
+       .quad   0xbe1cf19917010e96
+       .quad   0xc0862620f62b5cb0
+       .quad   0xbe1cf07331355985
+       .quad   0xc0862623b93bc9e8
+       .quad   0xbe1cf01ae921a1c3
+       .quad   0xc08626267b586ed0
+       .quad   0xbe1cefe5cf0dbf0c
+       .quad   0xc08626293c81f348
+       .quad   0xbe1cf01b258aeb50
+       .quad   0xc086262bfcb8fe88
+       .quad   0xbe1cee6b9e7f4c68
+       .quad   0xc086262ebbfe3710
+       .quad   0xbe1cee684a9b21c9
+       .quad   0xc08626317a5242b8
+       .quad   0xbe1cf1f8bcde9a8b
+       .quad   0xc086263437b5c6c0
+       .quad   0xbe1cf1d063d36238
+       .quad   0xc0862636f42967a8
+       .quad   0xbe1cf1e31a19075e
+       .quad   0xc0862639afadc950
+       .quad   0xbe1cf1d8efdf7e7d
+       .quad   0xc086263c6a438ef0
+       .quad   0xbe1cf1812ee72dba
+       .quad   0xc086263f23eb5b18
+       .quad   0xbe1cf1449a9a2279
+       .quad   0xc0862641dca5cfb8
+       .quad   0xbe1cee96edce5085
+       .quad   0xc086264494738e08
+       .quad   0xbe1cf06797bd03b2
+       .quad   0xc08626474b5536b8
+       .quad   0xbe1cef91b9b7ffc1
+       .quad   0xc086264a014b69c0
+       .quad   0xbe1cef4b6721278f
+       .quad   0xc086264cb656c678
+       .quad   0xbe1cf1942925eb4a
+       .quad   0xc086264f6a77eba8
+       .quad   0xbe1cefa2c7bc2e39
+       .quad   0xc08626521daf7758
+       .quad   0xbe1cf252595aceb3
+       .quad   0xc0862654cffe0718
+       .quad   0xbe1cee8e9ae47ec2
+       .quad   0xc0862657816437a8
+       .quad   0xbe1cf1bf913828fa
+       .quad   0xc086265a31e2a558
+       .quad   0xbe1cf23475d6b366
+       .quad   0xc086265ce179ebc8
+       .quad   0xbe1cef8df00a922b
+       .quad   0xc086265f902aa5f0
+       .quad   0xbe1cef279bfa43e0
+       .quad   0xc08626623df56e38
+       .quad   0xbe1cf080e10b8365
+       .quad   0xc0862664eadade70
+       .quad   0xbe1cf1a518f9b544
+       .quad   0xc086266796db8fd0
+       .quad   0xbe1cef9308fed9e9
+       .quad   0xc086266a41f81ae8
+       .quad   0xbe1ceea3ae6b19c9
+       .quad   0xc086266cec3117b8
+       .quad   0xbe1ceef06003d4c2
+       .quad   0xc086266f95871da8
+       .quad   0xbe1cf0b8457ffb0c
+       .quad   0xc08626723dfac390
+       .quad   0xbe1cf0c526745ad6
+       .quad   0xc0862674e58c9fa8
+       .quad   0xbe1cf0cf91ff7b5d
+       .quad   0xc08626778c3d4798
+       .quad   0xbe1cefe260819380
+       .quad   0xc086267a320d5070
+       .quad   0xbe1ceebd90aa27a3
+       .quad   0xc086267cd6fd4ea8
+       .quad   0xbe1cf0388121dffa
+       .quad   0xc086267f7b0dd630
+       .quad   0xbe1cf1a3881435f1
+       .quad   0xc08626821e3f7a68
+       .quad   0xbe1cef28e9d9ac52
+       .quad   0xc0862684c092ce08
+       .quad   0xbe1cf02d300062dd
+       .quad   0xc086268762086350
+       .quad   0xbe1cefaee1edfa35
+       .quad   0xc086268a02a0cbe0
+       .quad   0xbe1cf0a5a052e936
+       .quad   0xc086268ca25c98d8
+       .quad   0xbe1cee60a4a497ed
+       .quad   0xc086268f413c5ab0
+       .quad   0xbe1cf0e4a5d0cf49
+       .quad   0xc0862691df40a170
+       .quad   0xbe1cf149235a4e6e
+       .quad   0xc08626947c69fc80
+       .quad   0xbe1cf215180b9fcc
+       .quad   0xc086269718b8fac8
+       .quad   0xbe1cef9b156a9840
+       .quad   0xc0862699b42e2a90
+       .quad   0xbe1cf054c91441be
+       .quad   0xc086269c4eca19a8
+       .quad   0xbe1cf13ded26512c
+       .quad   0xc086269ee88d5550
+       .quad   0xbe1cf22ea4d8ac06
+       .quad   0xc08626a181786a40
+       .quad   0xbe1cf2354666ee2e
+       .quad   0xc08626a4198be4a8
+       .quad   0xbe1cefef936752b3
+       .quad   0xc08626a6b0c85020
+       .quad   0xbe1cf1e360a9db68
+       .quad   0xc08626a9472e37d8
+       .quad   0xbe1ceed6aeb812c5
+       .quad   0xc08626abdcbe2650
+       .quad   0xbe1cf227340b4986
+       .quad   0xc08626ae7178a5b0
+       .quad   0xbe1cf0215a0cbe0d
+       .quad   0xc08626b1055e3f70
+       .quad   0xbe1cf256adf0ae26
+       .quad   0xc08626b3986f7ca8
+       .quad   0xbe1ceff3c67aed06
+       .quad   0xc08626b62aace5c8
+       .quad   0xbe1cf2159fb93652
+       .quad   0xc08626b8bc1702e0
+       .quad   0xbe1cf01e6dbd1c7f
+       .quad   0xc08626bb4cae5b60
+       .quad   0xbe1cf009e75d1c0c
+       .quad   0xc08626bddc737648
+       .quad   0xbe1ceec10a020e73
+       .quad   0xc08626c06b66da08
+       .quad   0xbe1cf06d5783eee7
+       .quad   0xc08626c2f9890ca0
+       .quad   0xbe1cf0cb8f169ffe
+       .quad   0xc08626c586da9388
+       .quad   0xbe1cef7de2452430
+       .quad   0xc08626c8135bf3b0
+       .quad   0xbe1cf05da6f783ae
+       .quad   0xc08626ca9f0db198
+       .quad   0xbe1cefcc877d681d
+       .quad   0xc08626cd29f05138
+       .quad   0xbe1cef0531954ab3
+       .quad   0xc08626cfb4045608
+       .quad   0xbe1cf06b8565ea3d
+       .quad   0xc08626d23d4a4310
+       .quad   0xbe1cefdc455d9d7e
+       .quad   0xc08626d4c5c29ad0
+       .quad   0xbe1ceefc47e8fa64
+       .quad   0xc08626d74d6ddf48
+       .quad   0xbe1cf1872bf033f2
+       .quad   0xc08626d9d44c9210
+       .quad   0xbe1cf19d91087f9d
+       .quad   0xc08626dc5a5f3438
+       .quad   0xbe1cf012d444c6ab
+       .quad   0xc08626dedfa64650
+       .quad   0xbe1cf0ba528ee153
+       .quad   0xc08626e164224880
+       .quad   0xbe1ceeb431709788
+       .quad   0xc08626e3e7d3ba60
+       .quad   0xbe1cf0b9af31a6a5
+       .quad   0xc08626e66abb1b28
+       .quad   0xbe1cf168fb2e135b
+       .quad   0xc08626e8ecd8e990
+       .quad   0xbe1cef9097461c93
+       .quad   0xc08626eb6e2da3d0
+       .quad   0xbe1cee7a434735d8
+       .quad   0xc08626edeeb9c7a8
+       .quad   0xbe1cf235732b86f2
+       .quad   0xc08626f06e7dd280
+       .quad   0xbe1cefe1510b89e6
+       .quad   0xc08626f2ed7a4120
+       .quad   0xbe1cf1f64b9b80ef
+       .quad   0xc08626f56baf9000
+       .quad   0xbe1cf08f320ca339
+       .quad   0xc08626f7e91e3b08
+       .quad   0xbe1cf1b1de2808a1
+       .quad   0xc08626fa65c6bdc0
+       .quad   0xbe1cf1976d778b28
+       .quad   0xc08626fce1a99338
+       .quad   0xbe1ceef40a4f076f
+       .quad   0xc08626ff5cc73600
+       .quad   0xbe1cef3e45869ce3
+       .quad   0xc0862701d7202048
+       .quad   0xbe1ceef601b4c9d6
+       .quad   0xc086270450b4cbc0
+       .quad   0xbe1cf1eaf0b57fd6
+       .quad   0xc0862706c985b1c0
+       .quad   0xbe1cef82a44990f3
+       .quad   0xc086270941934b10
+       .quad   0xbe1ceefe32981f2c
+       .quad   0xc086270bb8de1018
+       .quad   0xbe1cefbf6f5a0445
+       .quad   0xc086270e2f6678d0
+       .quad   0xbe1cf18dba75792c
+       .quad   0xc0862710a52cfcc8
+       .quad   0xbe1cf0da64ce995f
+       .quad   0xc08627131a321318
+       .quad   0xbe1cef04ac0fb802
+       .quad   0xc08627158e763268
+       .quad   0xbe1cee9d4e2ad9bd
+       .quad   0xc086271801f9d0f8
+       .quad   0xbe1cefa9b55407b5
+       .quad   0xc086271a74bd64a0
+       .quad   0xbe1cefe6bd329570
+       .quad   0xc086271ce6c162c8
+       .quad   0xbe1cef0b1205dc85
+       .quad   0xc086271f58064068
+       .quad   0xbe1cef092a785e3f
+       .quad   0xc0862721c88c7210
+       .quad   0xbe1cf050dcdaac30
+       .quad   0xc086272438546be8
+       .quad   0xbe1cf210907ded8b
+       .quad   0xc0862726a75ea1b8
+       .quad   0xbe1cee760be44f99
+       .quad   0xc086272915ab86c0
+       .quad   0xbe1ceeeee07c2bcc
+       .quad   0xc086272b833b8df0
+       .quad   0xbe1cf06874992df5
+       .quad   0xc086272df00f29d0
+       .quad   0xbe1cef8fac5d4899
+       .quad   0xc08627305c26cc70
+       .quad   0xbe1cf1103241cc99
+       .quad   0xc0862732c782e788
+       .quad   0xbe1cf1d35fef83fe
+       .quad   0xc08627353223ec68
+       .quad   0xbe1cef3ec8133e1d
+       .quad   0xc08627379c0a4be8
+       .quad   0xbe1cef7261daccd8
+       .quad   0xc086273a05367688
+       .quad   0xbe1cf18656c50806
+       .quad   0xc086273c6da8dc68
+       .quad   0xbe1cf1c8736e049a
+       .quad   0xc086273ed561ed38
+       .quad   0xbe1cf1f93bff4911
+       .quad   0xc08627413c621848
+       .quad   0xbe1cf188a4ea680c
+       .quad   0xc0862743a2a9cc80
+       .quad   0xbe1cf1d270930c80
+       .quad   0xc086274608397868
+       .quad   0xbe1cf25a328c28e2
+       .quad   0xc08627486d118a28
+       .quad   0xbe1cf106f90aa3b8
+       .quad   0xc086274ad1326f80
+       .quad   0xbe1cee5e9d2e885a
+       .quad   0xc086274d349c95c0
+       .quad   0xbe1cf1c0bac27228
+       .quad   0xc086274f975069f8
+       .quad   0xbe1cf1a1500f9b1c
+       .quad   0xc0862751f94e58c0
+       .quad   0xbe1cefc30663ac44
+       .quad   0xc08627545a96ce48
+       .quad   0xbe1cf17123e427a2
+       .quad   0xc0862756bb2a3678
+       .quad   0xbe1cefb92749fea4
+       .quad   0xc08627591b08fcc0
+       .quad   0xbe1cefa40e1ea74a
+       .quad   0xc086275b7a338c40
+       .quad   0xbe1cee6f4612c3e9
+       .quad   0xc086275dd8aa4fa8
+       .quad   0xbe1cf1c54a053627
+       .quad   0xc0862760366db168
+       .quad   0xbe1ceff5eb503d9e
+       .quad   0xc0862762937e1b70
+       .quad   0xbe1cf02e47f10cee
+       .quad   0xc0862764efdbf768
+       .quad   0xbe1ceeb06e1d0dad
+       .quad   0xc08627674b87ae88
+       .quad   0xbe1cf10aadd6dba5
+       .quad   0xc0862769a681a9c0
+       .quad   0xbe1cf24e9913d30f
+       .quad   0xc086276c00ca51a0
+       .quad   0xbe1cef47b301e312
+       .quad   0xc086276e5a620e48
+       .quad   0xbe1ceeb1cefc2e85
+       .quad   0xc0862770b3494788
+       .quad   0xbe1cf16f1fbbe011
+       .quad   0xc08627730b8064e8
+       .quad   0xbe1ceebdf75174c7
+       .quad   0xc08627756307cd70
+       .quad   0xbe1cf06e3871a0da
+       .quad   0xc0862777b9dfe7f0
+       .quad   0xbe1cef16799fd554
+       .quad   0xc086277a10091ac0
+       .quad   0xbe1cf248dabf5377
+       .quad   0xc086277c6583cc00
+       .quad   0xbe1cf0c78d92a2cd
+       .quad   0xc086277eba506158
+       .quad   0xbe1cf0b911b029f0
+       .quad   0xc08627810e6f4028
+       .quad   0xbe1cefdc24719766
+       .quad   0xc086278361e0cd70
+       .quad   0xbe1cefbb6562b7e7
+       .quad   0xc0862785b4a56dd8
+       .quad   0xbe1cf1e0afb349ec
+       .quad   0xc086278806bd85c0
+       .quad   0xbe1cf008292e52fc
+       .quad   0xc086278a58297918
+       .quad   0xbe1cf053073872bf
+       .quad   0xc086278ca8e9ab88
+       .quad   0xbe1cf17a0a55a947
+       .quad   0xc086278ef8fe8068
+       .quad   0xbe1ceeffb0b60234
+       .quad   0xc086279148685aa0
+       .quad   0xbe1cf162204794a8
+       .quad   0xc086279397279ce0
+       .quad   0xbe1cf24cc8cb48ac
+       .quad   0xc0862795e53ca978
+       .quad   0xbe1cf0c9be68d5c3
+       .quad   0xc086279832a7e258
+       .quad   0xbe1cf172cd3d7388
+       .quad   0xc086279a7f69a930
+       .quad   0xbe1ceea2465fbce5
+       .quad   0xc086279ccb825f40
+       .quad   0xbe1cf0a386d2500f
+       .quad   0xc086279f16f26590
+       .quad   0xbe1cf1e338ddc18a
+       .quad   0xc08627a161ba1cd0
+       .quad   0xbe1cef1f5049867f
+       .quad   0xc08627a3abd9e548
+       .quad   0xbe1cef96c1ea8b1f
+       .quad   0xc08627a5f5521f00
+       .quad   0xbe1cf138f6fd3c26
+       .quad   0xc08627a83e2329b0
+       .quad   0xbe1cf0d4fcbfdf3a
+       .quad   0xc08627aa864d64b0
+       .quad   0xbe1cf24870c12c81
+       .quad   0xc08627accdd12f18
+       .quad   0xbe1cf0ae2a56348d
+       .quad   0xc08627af14aee7a0
+       .quad   0xbe1cee8ca1a9b893
+       .quad   0xc08627b15ae6eca8
+       .quad   0xbe1cf20414d637b0
+       .quad   0xc08627b3a0799c60
+       .quad   0xbe1cf0fc6b7b12d8
+       .quad   0xc08627b5e5675488
+       .quad   0xbe1cf152d93c4a00
+       .quad   0xc08627b829b072a0
+       .quad   0xbe1cf1073f9b77c2
+       .quad   0xc08627ba6d5553d8
+       .quad   0xbe1cee694f97d5a4
+       .quad   0xc08627bcb0565500
+       .quad   0xbe1cf0456b8239d7
+       .quad   0xc08627bef2b3d2b0
+       .quad   0xbe1cf211497127e3
+       .quad   0xc08627c1346e2930
+       .quad   0xbe1cf01856c0384d
+       .quad   0xc08627c37585b468
+       .quad   0xbe1cefa7dd05479e
+       .quad   0xc08627c5b5fad000
+       .quad   0xbe1cef3ae8e50b93
+       .quad   0xc08627c7f5cdd750
+       .quad   0xbe1ceea5f32fdd3a
+       .quad   0xc08627ca34ff2560
+       .quad   0xbe1cef424caeb8d9
+       .quad   0xc08627cc738f14f0
+       .quad   0xbe1cf0194d07a81f
+       .quad   0xc08627ceb17e0070
+       .quad   0xbe1cf20f452000c1
+       .quad   0xc08627d0eecc4210
+       .quad   0xbe1cf00e356218e4
+       .quad   0xc08627d32b7a33a0
+       .quad   0xbe1cef30484b4bcb
+       .quad   0xc08627d567882eb0
+       .quad   0xbe1ceeea11a6641b
+       .quad   0xc08627d7a2f68c80
+       .quad   0xbe1cf13492d5bd7b
+       .quad   0xc08627d9ddc5a618
+       .quad   0xbe1ceeb7048fad96
+       .quad   0xc08627dc17f5d418
+       .quad   0xbe1ceef0666f0477
+       .quad   0xc08627de51876ee8
+       .quad   0xbe1cf060d4b8b5c2
+       .quad   0xc08627e08a7acea8
+       .quad   0xbe1cf0b2a4b6ff8c
+       .quad   0xc08627e2c2d04b28
+       .quad   0xbe1cf0e34809a875
+       .quad   0xc08627e4fa883bf0
+       .quad   0xbe1cf16bf74a3522
+       .quad   0xc08627e731a2f848
+       .quad   0xbe1cee6a24623d57
+       .quad   0xc08627e96820d718
+       .quad   0xbe1cefc7b4f1528e
+       .quad   0xc08627eb9e022f18
+       .quad   0xbe1cf163051f3548
+       .quad   0xc08627edd34756b8
+       .quad   0xbe1cef36b3366305
+       .quad   0xc08627f007f0a408
+       .quad   0xbe1cf18134625550
+       .quad   0xc08627f23bfe6cf0
+       .quad   0xbe1cf0ec32ec1a11
+       .quad   0xc08627f46f710700
+       .quad   0xbe1ceeb3b64f3edc
+       .quad   0xc08627f6a248c778
+       .quad   0xbe1cf0cd15805bc8
+       .quad   0xc08627f8d4860368
+       .quad   0xbe1cf20db3bddebe
+       .quad   0xc08627fb06290f90
+       .quad   0xbe1cf25188430e25
+       .quad   0xc08627fd37324070
+       .quad   0xbe1ceea1713490f9
+       .quad   0xc08627ff67a1ea28
+       .quad   0xbe1cf159521d234c
+       .quad   0xc0862801977860b8
+       .quad   0xbe1cf24dfe50783b
+       .quad   0xc0862803c6b5f7d0
+       .quad   0xbe1ceef2ef89a60b
+       .quad   0xc0862805f55b02c8
+       .quad   0xbe1cee7fc919d62c
+       .quad   0xc08628082367d4c0
+       .quad   0xbe1cf215a7fb513a
+       .quad   0xc086280a50dcc0a8
+       .quad   0xbe1cf0e4401c5ed4
+       .quad   0xc086280c7dba1910
+       .quad   0xbe1cf04ec734d256
+       .quad   0xc086280eaa003050
+       .quad   0xbe1cf010ad787fea
+       .quad   0xc0862810d5af5880
+       .quad   0xbe1cee622478393d
+       .quad   0xc086281300c7e368
+       .quad   0xbe1cf01c7482564f
+       .quad   0xc08628152b4a22a0
+       .quad   0xbe1cf0de20d33536
+       .quad   0xc086281755366778
+       .quad   0xbe1cef2edae5837d
+       .quad   0xc08628197e8d02f0
+       .quad   0xbe1cf0a345318cc9
+       .quad   0xc086281ba74e45d8
+       .quad   0xbe1cf20085aa34b8
+       .quad   0xc086281dcf7a80c0
+       .quad   0xbe1cef5fa845ad83
+       .quad   0xc086281ff71203e0
+       .quad   0xbe1cf050d1df69c4
+       .quad   0xc08628221e151f48
+       .quad   0xbe1ceffe43c035b9
+       .quad   0xc0862824448422b8
+       .quad   0xbe1cf14f3018d3c2
+       .quad   0xc08628266a5f5dc0
+       .quad   0xbe1cef0a5fbae83d
+       .quad   0xc08628288fa71f98
+       .quad   0xbe1ceff8a95b72a1
+       .quad   0xc086282ab45bb750
+       .quad   0xbe1cef073aa9849b
+       .quad   0xc086282cd87d73a8
+       .quad   0xbe1cef69b3835c02
+       .quad   0xc086282efc0ca328
+       .quad   0xbe1cf0bc139379a9
+       .quad   0xc08628311f099420
+       .quad   0xbe1cef247a9ec596
+       .quad   0xc086283341749490
+       .quad   0xbe1cef74bbcc488a
+       .quad   0xc0862835634df248
+       .quad   0xbe1cef4bc42e7b8e
+       .quad   0xc08628378495fad0
+       .quad   0xbe1cf136d4d5a810
+       .quad   0xc0862839a54cfb80
+       .quad   0xbe1cf0d290b24dd8
+       .quad   0xc086283bc5734168
+       .quad   0xbe1ceeebde8e0065
+       .quad   0xc086283de5091950
+       .quad   0xbe1cf1a09f60aa1e
+       .quad   0xc0862840040ecfe0
+       .quad   0xbe1cf0803947a234
+       .quad   0xc08628422284b168
+       .quad   0xbe1cf0abf7638127
+       .quad   0xc0862844406b0a08
+       .quad   0xbe1cf0f73ee12058
+       .quad   0xc08628465dc225a0
+       .quad   0xbe1cf2079971b26c
+       .quad   0xc08628487a8a4fe0
+       .quad   0xbe1cee74957564b1
+       .quad   0xc086284a96c3d420
+       .quad   0xbe1ceee77c1b7d43
+       .quad   0xc086284cb26efd90
+       .quad   0xbe1cf23addba6e09
+       .quad   0xc086284ecd8c1730
+       .quad   0xbe1cf199f4a1da60
+       .quad   0xc0862850e81b6bb0
+       .quad   0xbe1cf09fdea81393
+       .quad   0xc0862853021d4588
+       .quad   0xbe1cf176adb417f7
+       .quad   0xc08628551b91ef00
+       .quad   0xbe1cf0f64f84a8da
+       .quad   0xc08628573479b220
+       .quad   0xbe1ceec34cf49523
+       .quad   0xc08628594cd4d8a8
+       .quad   0xbe1cf16d60fbe0bb
+       .quad   0xc086285b64a3ac40
+       .quad   0xbe1cee8de7acfc7b
+       .quad   0xc086285d7be67630
+       .quad   0xbe1ceee6256cce8d
+       .quad   0xc086285f929d7fa0
+       .quad   0xbe1cee7d66a3d8a5
+       .quad   0xc0862861a8c91170
+       .quad   0xbe1cf0bef8265792
+       .quad   0xc0862863be697458
+       .quad   0xbe1cf097f890c6f8
+       .quad   0xc0862865d37ef0c8
+       .quad   0xbe1cf09502d5c3fc
+       .quad   0xc0862867e809cf00
+       .quad   0xbe1ceeffb239dac7
+       .quad   0xc0862869fc0a56f8
+       .quad   0xbe1cf1fbfff95c98
+       .quad   0xc086286c0f80d090
+       .quad   0xbe1cefa57ad3eef7
+       .quad   0xc086286e226d8348
+       .quad   0xbe1cf22c58b9183d
+       .quad   0xc086287034d0b690
+       .quad   0xbe1ceff262d0a248
+       .quad   0xc086287246aab180
+       .quad   0xbe1cefa7bc194186
+       .quad   0xc086287457fbbb08
+       .quad   0xbe1cf06782d784d9
+       .quad   0xc086287668c419e0
+       .quad   0xbe1cf1d44d0eaa07
+       .quad   0xc086287879041490
+       .quad   0xbe1cf034803c8a48
+       .quad   0xc086287a88bbf158
+       .quad   0xbe1cf08e84916b6f
+       .quad   0xc086287c97ebf650
+       .quad   0xbe1cf0c4d3dc1bc7
+       .quad   0xc086287ea6946958
+       .quad   0xbe1cefb1e4625943
+       .quad   0xc0862880b4b59010
+       .quad   0xbe1cf143efdd1fd0
+       .quad   0xc0862882c24faff8
+       .quad   0xbe1cee9896d016da
+       .quad   0xc0862884cf630e38
+       .quad   0xbe1cf2186072f2cc
+       .quad   0xc0862886dbefeff0
+       .quad   0xbe1cef9217633d34
+       .quad   0xc0862888e7f699e0
+       .quad   0xbe1cf05603549486
+       .quad   0xc086288af37750b0
+       .quad   0xbe1cef50fff513d3
+       .quad   0xc086288cfe7258c0
+       .quad   0xbe1cf127713b32d0
+       .quad   0xc086288f08e7f650
+       .quad   0xbe1cf05015520f3d
+       .quad   0xc086289112d86d58
+       .quad   0xbe1cf12eb458b26f
+       .quad   0xc08628931c4401a8
+       .quad   0xbe1cf22eae2887ed
+       .quad   0xc0862895252af6e0
+       .quad   0xbe1cefdd6656dd2d
+       .quad   0xc08628972d8d9058
+       .quad   0xbe1cf1048ea4e646
+       .quad   0xc0862899356c1150
+       .quad   0xbe1ceec4501167e9
+       .quad   0xc086289b3cc6bcb8
+       .quad   0xbe1cf0ad52becc3f
+       .quad   0xc086289d439dd568
+       .quad   0xbe1cf0daa4e00e35
+       .quad   0xc086289f49f19df8
+       .quad   0xbe1cf00b80de8d6a
+       .quad   0xc08628a14fc258c8
+       .quad   0xbe1cf1bcf2ea8464
+       .quad   0xc08628a355104818
+       .quad   0xbe1cf0435e2782b0
+       .quad   0xc08628a559dbade0
+       .quad   0xbe1cf0e3e1a5f56c
+       .quad   0xc08628a75e24cbf8
+       .quad   0xbe1cefed9d5a721d
+       .quad   0xc08628a961ebe3f8
+       .quad   0xbe1cf0d2d74321e2
+       .quad   0xc08628ab65313750
+       .quad   0xbe1cf24200eb55e9
+       .quad   0xc08628ad67f50740
+       .quad   0xbe1cf23e9d7cf979
+       .quad   0xc08628af6a3794d0
+       .quad   0xbe1cf23a088f421c
+       .quad   0xc08628b16bf920e0
+       .quad   0xbe1cef2c1de1ab32
+       .quad   0xc08628b36d39ec08
+       .quad   0xbe1cf1abc231f7b2
+       .quad   0xc08628b56dfa36d0
+       .quad   0xbe1cf2074d5ba303
+       .quad   0xc08628b76e3a4180
+       .quad   0xbe1cf05cd5eed880
+       .rept   48
+       .byte   0
+       .endr
+
+/* Log(2) lookup table for logarithmic part */
+.if .-__svml_spow_data != _Log_LA_table
+.err
+.endif
+       .quad   0x8000000000000000
+       .quad   0xbf5ff802a9ab10e6
+       .quad   0xbf6ff00aa2b10bc0
+       .quad   0xbf77ee11ebd82e94
+       .quad   0xbf7fe02a6b106789
+       .quad   0xbf83e7295d25a7d9
+       .quad   0xbf87dc475f810a77
+       .quad   0xbf8bcf712c74384c
+       .quad   0xbf8fc0a8b0fc03e4
+       .quad   0xbf91d7f7eb9eebe7
+       .quad   0xbf93cea44346a575
+       .quad   0xbf95c45a51b8d389
+       .quad   0xbf97b91b07d5b11b
+       .quad   0xbf99ace7551cc514
+       .quad   0xbf9b9fc027af9198
+       .quad   0xbf9d91a66c543cc4
+       .quad   0xbf9f829b0e783300
+       .quad   0xbfa0b94f7c196176
+       .quad   0xbfa1b0d98923d980
+       .quad   0xbfa2a7ec2214e873
+       .quad   0xbfa39e87b9febd60
+       .quad   0xbfa494acc34d911c
+       .quad   0xbfa58a5bafc8e4d5
+       .quad   0xbfa67f94f094bd98
+       .quad   0xbfa77458f632dcfc
+       .quad   0xbfa868a83083f6cf
+       .quad   0xbfa95c830ec8e3eb
+       .quad   0xbfaa4fe9ffa3d235
+       .quad   0xbfab42dd711971bf
+       .quad   0xbfac355dd0921f2d
+       .quad   0xbfad276b8adb0b52
+       .quad   0xbfae19070c276016
+       .quad   0xbfaf0a30c01162a6
+       .quad   0xbfaffae9119b9303
+       .quad   0xbfb075983598e471
+       .quad   0xbfb0ed839b5526fe
+       .quad   0xbfb16536eea37ae1
+       .quad   0xbfb1dcb263db1944
+       .quad   0xbfb253f62f0a1417
+       .quad   0xbfb2cb0283f5de1f
+       .quad   0xbfb341d7961bd1d1
+       .quad   0xbfb3b87598b1b6ee
+       .quad   0xbfb42edcbea646f0
+       .quad   0xbfb4a50d3aa1b040
+       .quad   0xbfb51b073f06183f
+       .quad   0xbfb590cafdf01c28
+       .quad   0xbfb60658a93750c4
+       .quad   0xbfb67bb0726ec0fc
+       .quad   0xbfb6f0d28ae56b4c
+       .quad   0xbfb765bf23a6be13
+       .quad   0xbfb7da766d7b12cd
+       .quad   0xbfb84ef898e8282a
+       .quad   0xbfb8c345d6319b21
+       .quad   0xbfb9375e55595ede
+       .quad   0xbfb9ab42462033ad
+       .quad   0xbfba1ef1d8061cd4
+       .quad   0xbfba926d3a4ad563
+       .quad   0xbfbb05b49bee43fe
+       .quad   0xbfbb78c82bb0eda1
+       .quad   0xbfbbeba818146765
+       .quad   0xbfbc5e548f5bc743
+       .quad   0xbfbcd0cdbf8c13e1
+       .quad   0xbfbd4313d66cb35d
+       .quad   0xbfbdb5270187d927
+       .quad   0xbfbe27076e2af2e6
+       .quad   0xbfbe98b549671467
+       .quad   0xbfbf0a30c01162a6
+       .quad   0xbfbf7b79fec37ddf
+       .quad   0xbfbfec9131dbeabb
+       .quad   0xbfc02ebb42bf3d4b
+       .quad   0xbfc0671512ca596e
+       .quad   0xbfc09f561ee719c3
+       .quad   0xbfc0d77e7cd08e59
+       .quad   0xbfc10f8e422539b1
+       .quad   0xbfc14785846742ac
+       .quad   0xbfc17f6458fca611
+       .quad   0xbfc1b72ad52f67a0
+       .quad   0xbfc1eed90e2dc2c3
+       .quad   0xbfc2266f190a5acb
+       .quad   0xbfc25ded0abc6ad2
+       .quad   0xbfc29552f81ff523
+       .quad   0xbfc2cca0f5f5f251
+       .quad   0xbfc303d718e47fd3
+       .quad   0xbfc33af575770e4f
+       .quad   0xbfc371fc201e8f74
+       .quad   0xbfc3a8eb2d31a376
+       .quad   0xbfc3dfc2b0ecc62a
+       .quad   0xbfc41682bf727bc0
+       .quad   0xbfc44d2b6ccb7d1e
+       .quad   0xbfc483bccce6e3dd
+       .quad   0xbfc4ba36f39a55e5
+       .quad   0xbfc4f099f4a230b2
+       .quad   0xbfc526e5e3a1b438
+       .quad   0xbfc55d1ad4232d6f
+       .quad   0xbfc59338d9982086
+       .quad   0xbfc5c940075972b9
+       .quad   0xbfc5ff3070a793d4
+       .quad   0xbfc6350a28aaa758
+       .quad   0xbfc66acd4272ad51
+       .quad   0xbfc6a079d0f7aad2
+       .quad   0xbfc6d60fe719d21d
+       .quad   0xbfc70b8f97a1aa75
+       .quad   0xbfc740f8f54037a5
+       .quad   0xbfc7764c128f2127
+       .quad   0xbfc7ab890210d909
+       .quad   0xbfc7e0afd630c274
+       .quad   0xbfc815c0a14357eb
+       .quad   0xbfc84abb75865139
+       .quad   0xbfc87fa06520c911
+       .quad   0xbfc8b46f8223625b
+       .quad   0xbfc8e928de886d41
+       .quad   0xbfc91dcc8c340bde
+       .quad   0xbfc9525a9cf456b4
+       .quad   0xbfc986d3228180ca
+       .quad   0xbfc9bb362e7dfb83
+       .quad   0xbfc9ef83d2769a34
+       .quad   0xbfca23bc1fe2b563
+       .quad   0xbfca57df28244dcd
+       .quad   0xbfca8becfc882f19
+       .quad   0xbfcabfe5ae46124c
+       .quad   0xbfcaf3c94e80bff3
+       .quad   0xbfcb2797ee46320c
+       .quad   0xbfcb5b519e8fb5a4
+       .quad   0xbfcb8ef670420c3b
+       .quad   0xbfcbc286742d8cd6
+       .quad   0xbfcbf601bb0e44e2
+       .quad   0xbfcc2968558c18c1
+       .quad   0xbfcc5cba543ae425
+       .quad   0xbfcc8ff7c79a9a22
+       .quad   0xbfccc320c0176502
+       .quad   0xbfccf6354e09c5dc
+       .quad   0xbfcd293581b6b3e7
+       .quad   0xbfcd5c216b4fbb91
+       .quad   0xbfcd8ef91af31d5e
+       .quad   0xbfcdc1bca0abec7d
+       .quad   0xbfcdf46c0c722d2f
+       .quad   0xbfce27076e2af2e6
+       .quad   0xbfce598ed5a87e2f
+       .quad   0xbfce8c0252aa5a60
+       .quad   0xbfcebe61f4dd7b0b
+       .quad   0xbfcef0adcbdc5936
+       .quad   0xbfcf22e5e72f105d
+       .quad   0xbfcf550a564b7b37
+       .quad   0xbfcf871b28955045
+       .quad   0xbfcfb9186d5e3e2b
+       .quad   0xbfcfeb0233e607cc
+       .quad   0xbfd00e6c45ad501d
+       .quad   0xbfd0274dc16c232f
+       .quad   0xbfd0402594b4d041
+       .quad   0xbfd058f3c703ebc6
+       .quad   0xbfd071b85fcd590d
+       .quad   0xbfd08a73667c57af
+       .quad   0xbfd0a324e27390e3
+       .quad   0xbfd0bbccdb0d24bd
+       .quad   0xbfd0d46b579ab74b
+       .quad   0xbfd0ed005f657da4
+       .quad   0xbfd1058bf9ae4ad5
+       .quad   0xbfd11e0e2dad9cb7
+       .quad   0xbfd136870293a8b0
+       .quad   0xbfd14ef67f88685a
+       .quad   0xbfd1675cababa60e
+       .quad   0xbfd17fb98e15095d
+       .quad   0xbfd1980d2dd4236f
+       .quad   0xbfd1b05791f07b49
+       .quad   0xbfd1c898c16999fb
+       .quad   0xbfd1e0d0c33716be
+       .quad   0xbfd1f8ff9e48a2f3
+       .quad   0xbfd211255986160c
+       .quad   0xbfd22941fbcf7966
+       .quad   0xbfd241558bfd1404
+       .quad   0xbfd2596010df763a
+       .quad   0xbfd27161913f853d
+       .quad   0xbfd2895a13de86a3
+       .quad   0xbfd2a1499f762bc9
+       .quad   0xbfd2b9303ab89d25
+       .quad   0xbfd2d10dec508583
+       .quad   0xbfd2e8e2bae11d31
+       .quad   0xbfd300aead06350c
+       .quad   0xbfd31871c9544185
+       .quad   0xbfd3302c16586588
+       .quad   0xbfd347dd9a987d55
+       .quad   0xbfd35f865c93293e
+       .quad   0xbfd3772662bfd85b
+       .quad   0xbfd38ebdb38ed321
+       .quad   0xbfd3a64c556945ea
+       .quad   0xbfd3bdd24eb14b6a
+       .quad   0xbfd3d54fa5c1f710
+       .quad   0xbfd3ecc460ef5f50
+       .quad   0xbfd404308686a7e4
+       .quad   0xbfd41b941cce0bee
+       .quad   0xbfd432ef2a04e814
+       .quad   0xbfd44a41b463c47c
+       .quad   0xbfd4618bc21c5ec2
+       .quad   0xbfd478cd5959b3d9
+       .quad   0xbfd49006804009d1
+       .quad   0xbfd4a7373cecf997
+       .quad   0xbfd4be5f957778a1
+       .quad   0xbfd4d57f8fefe27f
+       .quad   0xbfd4ec973260026a
+       .quad   0xbfd503a682cb1cb3
+       .quad   0xbfd51aad872df82d
+       .quad   0xbfd531ac457ee77e
+       .quad   0xbfd548a2c3add263
+       .quad   0xbfd55f9107a43ee2
+       .quad   0xbfd5767717455a6c
+       .quad   0xbfd58d54f86e02f2
+       .quad   0xbfd5a42ab0f4cfe2
+       .quad   0xbfd5baf846aa1b19
+       .quad   0xbfd5d1bdbf5809ca
+       .quad   0xbfd5e87b20c2954a
+       .quad   0xbfd5ff3070a793d4
+       .quad   0xbfd615ddb4bec13c
+       .quad   0xbfd62c82f2b9c795
+       .quad   0x3fd61965cdb02c1f
+       .quad   0x3fd602d08af091ec
+       .quad   0x3fd5ec433d5c35ae
+       .quad   0x3fd5d5bddf595f30
+       .quad   0x3fd5bf406b543db2
+       .quad   0x3fd5a8cadbbedfa1
+       .quad   0x3fd5925d2b112a59
+       .quad   0x3fd57bf753c8d1fb
+       .quad   0x3fd565995069514c
+       .quad   0x3fd54f431b7be1a9
+       .quad   0x3fd538f4af8f72fe
+       .quad   0x3fd522ae0738a3d8
+       .quad   0x3fd50c6f1d11b97c
+       .quad   0x3fd4f637ebba9810
+       .quad   0x3fd4e0086dd8baca
+       .quad   0x3fd4c9e09e172c3c
+       .quad   0x3fd4b3c077267e9a
+       .quad   0x3fd49da7f3bcc41f
+       .quad   0x3fd487970e958770
+       .quad   0x3fd4718dc271c41b
+       .quad   0x3fd45b8c0a17df13
+       .quad   0x3fd44591e0539f49
+       .quad   0x3fd42f9f3ff62642
+       .quad   0x3fd419b423d5e8c7
+       .quad   0x3fd403d086cea79c
+       .quad   0x3fd3edf463c1683e
+       .quad   0x3fd3d81fb5946dba
+       .quad   0x3fd3c25277333184
+       .quad   0x3fd3ac8ca38e5c5f
+       .quad   0x3fd396ce359bbf54
+       .quad   0x3fd3811728564cb2
+       .quad   0x3fd36b6776be1117
+       .quad   0x3fd355bf1bd82c8b
+       .quad   0x3fd3401e12aecba1
+       .quad   0x3fd32a84565120a8
+       .quad   0x3fd314f1e1d35ce4
+       .quad   0x3fd2ff66b04ea9d4
+       .quad   0x3fd2e9e2bce12286
+       .quad   0x3fd2d46602adccee
+       .quad   0x3fd2bef07cdc9354
+       .quad   0x3fd2a982269a3dbf
+       .quad   0x3fd2941afb186b7c
+       .quad   0x3fd27ebaf58d8c9d
+       .quad   0x3fd269621134db92
+       .quad   0x3fd25410494e56c7
+       .quad   0x3fd23ec5991eba49
+       .quad   0x3fd22981fbef797b
+       .quad   0x3fd214456d0eb8d4
+       .quad   0x3fd1ff0fe7cf47a7
+       .quad   0x3fd1e9e1678899f4
+       .quad   0x3fd1d4b9e796c245
+       .quad   0x3fd1bf99635a6b95
+       .quad   0x3fd1aa7fd638d33f
+       .quad   0x3fd1956d3b9bc2fa
+       .quad   0x3fd180618ef18adf
+       .quad   0x3fd16b5ccbacfb73
+       .quad   0x3fd1565eed455fc3
+       .quad   0x3fd14167ef367783
+       .quad   0x3fd12c77cd00713b
+       .quad   0x3fd1178e8227e47c
+       .quad   0x3fd102ac0a35cc1c
+       .quad   0x3fd0edd060b78081
+       .quad   0x3fd0d8fb813eb1ef
+       .quad   0x3fd0c42d676162e3
+       .quad   0x3fd0af660eb9e279
+       .quad   0x3fd09aa572e6c6d4
+       .quad   0x3fd085eb8f8ae797
+       .quad   0x3fd07138604d5862
+       .quad   0x3fd05c8be0d9635a
+       .quad   0x3fd047e60cde83b8
+       .quad   0x3fd03346e0106062
+       .quad   0x3fd01eae5626c691
+       .quad   0x3fd00a1c6adda473
+       .quad   0x3fcfeb2233ea07cd
+       .quad   0x3fcfc218be620a5e
+       .quad   0x3fcf991c6cb3b379
+       .quad   0x3fcf702d36777df0
+       .quad   0x3fcf474b134df229
+       .quad   0x3fcf1e75fadf9bde
+       .quad   0x3fcef5ade4dcffe6
+       .quad   0x3fceccf2c8fe920a
+       .quad   0x3fcea4449f04aaf5
+       .quad   0x3fce7ba35eb77e2a
+       .quad   0x3fce530effe71012
+       .quad   0x3fce2a877a6b2c12
+       .quad   0x3fce020cc6235ab5
+       .quad   0x3fcdd99edaf6d7e9
+       .quad   0x3fcdb13db0d48940
+       .quad   0x3fcd88e93fb2f450
+       .quad   0x3fcd60a17f903515
+       .quad   0x3fcd38666871f465
+       .quad   0x3fcd1037f2655e7b
+       .quad   0x3fcce816157f1988
+       .quad   0x3fccc000c9db3c52
+       .quad   0x3fcc97f8079d44ec
+       .quad   0x3fcc6ffbc6f00f71
+       .quad   0x3fcc480c0005ccd1
+       .quad   0x3fcc2028ab17f9b4
+       .quad   0x3fcbf851c067555f
+       .quad   0x3fcbd087383bd8ad
+       .quad   0x3fcba8c90ae4ad19
+       .quad   0x3fcb811730b823d2
+       .quad   0x3fcb5971a213acdb
+       .quad   0x3fcb31d8575bce3d
+       .quad   0x3fcb0a4b48fc1b46
+       .quad   0x3fcae2ca6f672bd4
+       .quad   0x3fcabb55c31693ad
+       .quad   0x3fca93ed3c8ad9e3
+       .quad   0x3fca6c90d44b704e
+       .quad   0x3fca454082e6ab05
+       .quad   0x3fca1dfc40f1b7f1
+       .quad   0x3fc9f6c407089664
+       .quad   0x3fc9cf97cdce0ec3
+       .quad   0x3fc9a8778debaa38
+       .quad   0x3fc981634011aa75
+       .quad   0x3fc95a5adcf7017f
+       .quad   0x3fc9335e5d594989
+       .quad   0x3fc90c6db9fcbcd9
+       .quad   0x3fc8e588ebac2dbf
+       .quad   0x3fc8beafeb38fe8c
+       .quad   0x3fc897e2b17b19a5
+       .quad   0x3fc871213750e994
+       .quad   0x3fc84a6b759f512f
+       .quad   0x3fc823c16551a3c2
+       .quad   0x3fc7fd22ff599d4f
+       .quad   0x3fc7d6903caf5ad0
+       .quad   0x3fc7b0091651528c
+       .quad   0x3fc7898d85444c73
+       .quad   0x3fc7631d82935a86
+       .quad   0x3fc73cb9074fd14d
+       .quad   0x3fc716600c914054
+       .quad   0x3fc6f0128b756abc
+       .quad   0x3fc6c9d07d203fc7
+       .quad   0x3fc6a399dabbd383
+       .quad   0x3fc67d6e9d785771
+       .quad   0x3fc6574ebe8c133a
+       .quad   0x3fc6313a37335d76
+       .quad   0x3fc60b3100b09476
+       .quad   0x3fc5e533144c1719
+       .quad   0x3fc5bf406b543db2
+       .quad   0x3fc59958ff1d52f1
+       .quad   0x3fc5737cc9018cdd
+       .quad   0x3fc54dabc26105d2
+       .quad   0x3fc527e5e4a1b58d
+       .quad   0x3fc5022b292f6a45
+       .quad   0x3fc4dc7b897bc1c8
+       .quad   0x3fc4b6d6fefe22a4
+       .quad   0x3fc4913d8333b561
+       .quad   0x3fc46baf0f9f5db7
+       .quad   0x3fc4462b9dc9b3dc
+       .quad   0x3fc420b32740fdd4
+       .quad   0x3fc3fb45a59928cc
+       .quad   0x3fc3d5e3126bc27f
+       .quad   0x3fc3b08b6757f2a9
+       .quad   0x3fc38b3e9e027479
+       .quad   0x3fc365fcb0159016
+       .quad   0x3fc340c59741142e
+       .quad   0x3fc31b994d3a4f85
+       .quad   0x3fc2f677cbbc0a96
+       .quad   0x3fc2d1610c86813a
+       .quad   0x3fc2ac55095f5c59
+       .quad   0x3fc28753bc11aba5
+       .quad   0x3fc2625d1e6ddf57
+       .quad   0x3fc23d712a49c202
+       .quad   0x3fc2188fd9807263
+       .quad   0x3fc1f3b925f25d41
+       .quad   0x3fc1ceed09853752
+       .quad   0x3fc1aa2b7e23f72a
+       .quad   0x3fc185747dbecf34
+       .quad   0x3fc160c8024b27b1
+       .quad   0x3fc13c2605c398c3
+       .quad   0x3fc1178e8227e47c
+       .quad   0x3fc0f301717cf0fb
+       .quad   0x3fc0ce7ecdccc28d
+       .quad   0x3fc0aa06912675d5
+       .quad   0x3fc08598b59e3a07
+       .quad   0x3fc06135354d4b18
+       .quad   0x3fc03cdc0a51ec0d
+       .quad   0x3fc0188d2ecf6140
+       .quad   0x3fbfe89139dbd566
+       .quad   0x3fbfa01c9db57ce2
+       .quad   0x3fbf57bc7d9005db
+       .quad   0x3fbf0f70cdd992e3
+       .quad   0x3fbec739830a1120
+       .quad   0x3fbe7f1691a32d3e
+       .quad   0x3fbe3707ee30487b
+       .quad   0x3fbdef0d8d466db9
+       .quad   0x3fbda727638446a2
+       .quad   0x3fbd5f55659210e2
+       .quad   0x3fbd179788219364
+       .quad   0x3fbccfedbfee13a8
+       .quad   0x3fbc885801bc4b23
+       .quad   0x3fbc40d6425a5cb1
+       .quad   0x3fbbf968769fca11
+       .quad   0x3fbbb20e936d6974
+       .quad   0x3fbb6ac88dad5b1c
+       .quad   0x3fbb23965a52ff00
+       .quad   0x3fbadc77ee5aea8c
+       .quad   0x3fba956d3ecade63
+       .quad   0x3fba4e7640b1bc38
+       .quad   0x3fba0792e9277cac
+       .quad   0x3fb9c0c32d4d2548
+       .quad   0x3fb97a07024cbe74
+       .quad   0x3fb9335e5d594989
+       .quad   0x3fb8ecc933aeb6e8
+       .quad   0x3fb8a6477a91dc29
+       .quad   0x3fb85fd927506a48
+       .quad   0x3fb8197e2f40e3f0
+       .quad   0x3fb7d33687c293c9
+       .quad   0x3fb78d02263d82d3
+       .quad   0x3fb746e100226ed9
+       .quad   0x3fb700d30aeac0e1
+       .quad   0x3fb6bad83c1883b6
+       .quad   0x3fb674f089365a7a
+       .quad   0x3fb62f1be7d77743
+       .quad   0x3fb5e95a4d9791cb
+       .quad   0x3fb5a3abb01ade25
+       .quad   0x3fb55e10050e0384
+       .quad   0x3fb518874226130a
+       .quad   0x3fb4d3115d207eac
+       .quad   0x3fb48dae4bc31018
+       .quad   0x3fb4485e03dbdfad
+       .quad   0x3fb403207b414b7f
+       .quad   0x3fb3bdf5a7d1ee64
+       .quad   0x3fb378dd7f749714
+       .quad   0x3fb333d7f8183f4b
+       .quad   0x3fb2eee507b40301
+       .quad   0x3fb2aa04a44717a5
+       .quad   0x3fb26536c3d8c369
+       .quad   0x3fb2207b5c78549e
+       .quad   0x3fb1dbd2643d190b
+       .quad   0x3fb1973bd1465567
+       .quad   0x3fb152b799bb3cc9
+       .quad   0x3fb10e45b3cae831
+       .quad   0x3fb0c9e615ac4e17
+       .quad   0x3fb08598b59e3a07
+       .quad   0x3fb0415d89e74444
+       .quad   0x3faffa6911ab9301
+       .quad   0x3faf723b517fc523
+       .quad   0x3faeea31c006b87c
+       .quad   0x3fae624c4a0b5e1b
+       .quad   0x3fadda8adc67ee4e
+       .quad   0x3fad52ed6405d86f
+       .quad   0x3faccb73cdddb2cc
+       .quad   0x3fac441e06f72a9e
+       .quad   0x3fabbcebfc68f420
+       .quad   0x3fab35dd9b58baad
+       .quad   0x3faaaef2d0fb10fc
+       .quad   0x3faa282b8a936171
+       .quad   0x3fa9a187b573de7c
+       .quad   0x3fa91b073efd7314
+       .quad   0x3fa894aa149fb343
+       .quad   0x3fa80e7023d8ccc4
+       .quad   0x3fa788595a3577ba
+       .quad   0x3fa70265a550e777
+       .quad   0x3fa67c94f2d4bb58
+       .quad   0x3fa5f6e73078efb8
+       .quad   0x3fa5715c4c03ceef
+       .quad   0x3fa4ebf43349e26f
+       .quad   0x3fa466aed42de3ea
+       .quad   0x3fa3e18c1ca0ae92
+       .quad   0x3fa35c8bfaa1306b
+       .quad   0x3fa2d7ae5c3c5bae
+       .quad   0x3fa252f32f8d183f
+       .quad   0x3fa1ce5a62bc353a
+       .quad   0x3fa149e3e4005a8d
+       .quad   0x3fa0c58fa19dfaaa
+       .quad   0x3fa0415d89e74444
+       .quad   0x3f9f7a9b16782856
+       .quad   0x3f9e72bf2813ce51
+       .quad   0x3f9d6b2725979802
+       .quad   0x3f9c63d2ec14aaf2
+       .quad   0x3f9b5cc258b718e6
+       .quad   0x3f9a55f548c5c43f
+       .quad   0x3f994f6b99a24475
+       .quad   0x3f98492528c8cabf
+       .quad   0x3f974321d3d006d3
+       .quad   0x3f963d6178690bd6
+       .quad   0x3f9537e3f45f3565
+       .quad   0x3f9432a925980cc1
+       .quad   0x3f932db0ea132e22
+       .quad   0x3f9228fb1fea2e28
+       .quad   0x3f912487a5507f70
+       .quad   0x3f90205658935847
+       .quad   0x3f8e38ce3033310c
+       .quad   0x3f8c317384c75f06
+       .quad   0x3f8a2a9c6c170462
+       .quad   0x3f882448a388a2aa
+       .quad   0x3f861e77e8b53fc6
+       .quad   0x3f841929f96832f0
+       .quad   0x3f82145e939ef1e9
+       .quad   0x3f8010157588de71
+       .quad   0x3f7c189cbb0e27fb
+       .quad   0x3f78121214586b54
+       .quad   0x3f740c8a747878e2
+       .quad   0x3f70080559588b35
+       .quad   0x3f680904828985c0
+       .quad   0x3f60040155d5889e
+       .quad   0x3f50020055655889
+       .quad   0x0000000000000000
+       .rept   56
+       .byte   0
+       .endr
+
+/* Polynomial coefficients for log part:
+ * coeff4 */
+double_vector _poly_coeff_1 0x3fc9999cacdb4d0a
+
+/* coeff3 */
+double_vector _poly_coeff_2 0xbfd0000148058ee1
+
+/* coeff2 */
+double_vector _poly_coeff_3 0x3fd55555555543c5
+
+/* coeff1 */
+double_vector _poly_coeff_4 0xbfdffffffffff81f
+
+/* General purpose constants for log part: ExpMask */
+double_vector _ExpMask 0x000fffffffffffff
+
+/* Two10 */
+double_vector _Two10 0x3f50000000000000
+
+/* MinNorm */
+double_vector _MinNorm 0x0010000000000000
+
+/* MaxNorm */
+double_vector _MaxNorm 0x7fefffffffffffff
+
+/* HalfMask */
+double_vector _HalfMask 0xfffffffffc000000
+
+/* One */
+double_vector _One 0x3ff0000000000000
+
+/* L2H */
+double_vector _L2H 0x3fe62e42fefa0000
+
+/* L2L */
+double_vector _L2L 0x3d7cf79abc9e0000
+
+/* Threshold */
+double_vector _Threshold 0x4086a00000000000
+
+/* Bias */
+double_vector _Bias 0x408ff80000000000
+
+/* Bias1 */
+double_vector _Bias1 0x408ff00000000000
+
+/* L2L */
+double_vector _L2 0x3fe62e42fefa39ef
+
+/* dInfs = DP infinity, +/- == */
+.if .-__svml_spow_data != _dInfs
+.err
+.endif
+       .quad   0x7ff0000000000000
+       .quad   0xfff0000000000000
+       .rept   48
+       .byte   0
+       .endr
+
+/* dOnes = DP one, +/- == */
+.if .-__svml_spow_data != _dOnes
+.err
+.endif
+       .quad   0x3ff0000000000000
+       .quad   0xbff0000000000000
+       .rept   48
+       .byte   0
+       .endr
+
+/* dZeros = DP zero +/- == */
+.if .-__svml_spow_data != _dZeros
+.err
+.endif
+       .quad   0x0000000000000000
+       .quad   0x8000000000000000
+       .rept   48
+       .byte   0
+       .endr
+.if .-__svml_spow_data != __dbT
+.err
+.endif
+       .quad   0x3feffffffc27dd9e
+       .quad   0x3ff00162f1a4047d
+       .quad   0x3ff002c603f68252
+       .quad   0x3ff00429350e12af
+       .quad   0x3ff0058c84ed6032
+       .quad   0x3ff006eff39715b2
+       .quad   0x3ff00853810dde41
+       .quad   0x3ff009b72d54652f
+       .quad   0x3ff00b1af86d5604
+       .quad   0x3ff00c7ee25b5c86
+       .quad   0x3ff00de2eb2124b3
+       .quad   0x3ff00f4712c15ac8
+       .quad   0x3ff010ab593eab39
+       .quad   0x3ff0120fbe9bc2ba
+       .quad   0x3ff0137442db4e38
+       .quad   0x3ff014d8e5fffada
+       .quad   0x3ff0163da80c7604
+       .quad   0x3ff017a289036d56
+       .quad   0x3ff0190788e78eab
+       .quad   0x3ff01a6ca7bb8818
+       .quad   0x3ff01bd1e58207ef
+       .quad   0x3ff01d37423dbcbc
+       .quad   0x3ff01e9cbdf15549
+       .quad   0x3ff02002589f8099
+       .quad   0x3ff02168124aedec
+       .quad   0x3ff022cdeaf64cbc
+       .quad   0x3ff02433e2a44cc1
+       .quad   0x3ff02599f9579ded
+       .quad   0x3ff027002f12f06d
+       .quad   0x3ff0286683d8f4ac
+       .quad   0x3ff029ccf7ac5b4d
+       .quad   0x3ff02b338a8fd532
+       .quad   0x3ff02c9a3c861379
+       .quad   0x3ff02e010d91c778
+       .quad   0x3ff02f67fdb5a2c4
+       .quad   0x3ff030cf0cf4572d
+       .quad   0x3ff032363b5096bc
+       .quad   0x3ff0339d88cd13bc
+       .quad   0x3ff03504f56c80ae
+       .quad   0x3ff0366c81319053
+       .quad   0x3ff037d42c1ef5a2
+       .quad   0x3ff0393bf63763d5
+       .quad   0x3ff03aa3df7d8e5f
+       .quad   0x3ff03c0be7f428eb
+       .quad   0x3ff03d740f9de766
+       .quad   0x3ff03edc567d7df7
+       .quad   0x3ff04044bc95a0fe
+       .quad   0x3ff041ad41e9051d
+       .quad   0x3ff04315e67a5f2a
+       .quad   0x3ff0447eaa4c643e
+       .quad   0x3ff045e78d61c9ac
+       .quad   0x3ff047508fbd4502
+       .quad   0x3ff048b9b1618c0b
+       .quad   0x3ff04a22f25154cd
+       .quad   0x3ff04b8c528f558b
+       .quad   0x3ff04cf5d21e44c4
+       .quad   0x3ff04e5f7100d935
+       .quad   0x3ff04fc92f39c9d4
+       .quad   0x3ff051330ccbcdd5
+       .quad   0x3ff0529d09b99ca8
+       .quad   0x3ff054072605edfb
+       .quad   0x3ff0557161b379b3
+       .quad   0x3ff056dbbcc4f7f8
+       .quad   0x3ff05846373d212a
+       .quad   0x3ff059b0d11eade5
+       .quad   0x3ff05b1b8a6c5706
+       .quad   0x3ff05c866328d5a2
+       .quad   0x3ff05df15b56e30a
+       .quad   0x3ff05f5c72f938cf
+       .quad   0x3ff060c7aa1290bd
+       .quad   0x3ff0623300a5a4db
+       .quad   0x3ff0639e76b52f6e
+       .quad   0x3ff0650a0c43eaf6
+       .quad   0x3ff06675c1549232
+       .quad   0x3ff067e195e9e01a
+       .quad   0x3ff0694d8a068fe7
+       .quad   0x3ff06ab99dad5d0c
+       .quad   0x3ff06c25d0e10338
+       .quad   0x3ff06d9223a43e58
+       .quad   0x3ff06efe95f9ca95
+       .quad   0x3ff0706b27e46455
+       .quad   0x3ff071d7d966c83a
+       .quad   0x3ff07344aa83b324
+       .quad   0x3ff074b19b3de22f
+       .quad   0x3ff0761eab9812b4
+       .quad   0x3ff0778bdb950247
+       .quad   0x3ff078f92b376ebc
+       .quad   0x3ff07a669a821621
+       .quad   0x3ff07bd42977b6c4
+       .quad   0x3ff07d41d81b0f2b
+       .quad   0x3ff07eafa66ede1e
+       .quad   0x3ff0801d9475e2a0
+       .quad   0x3ff0818ba232dbee
+       .quad   0x3ff082f9cfa88985
+       .quad   0x3ff084681cd9ab21
+       .quad   0x3ff085d689c900b6
+       .quad   0x3ff0874516794a79
+       .quad   0x3ff088b3c2ed48d9
+       .quad   0x3ff08a228f27bc86
+       .quad   0x3ff08b917b2b6667
+       .quad   0x3ff08d0086fb07a6
+       .quad   0x3ff08e6fb29961a8
+       .quad   0x3ff08fdefe09360d
+       .quad   0x3ff0914e694d46b6
+       .quad   0x3ff092bdf46855c0
+       .quad   0x3ff0942d9f5d2582
+       .quad   0x3ff0959d6a2e7893
+       .quad   0x3ff0970d54df11c8
+       .quad   0x3ff0987d5f71b432
+       .quad   0x3ff099ed89e9231e
+       .quad   0x3ff09b5dd448221a
+       .quad   0x3ff09cce3e9174ec
+       .quad   0x3ff09e3ec8c7df9d
+       .quad   0x3ff09faf72ee2670
+       .quad   0x3ff0a1203d070de5
+       .quad   0x3ff0a29127155abd
+       .quad   0x3ff0a402311bd1f0
+       .quad   0x3ff0a5735b1d38bb
+       .quad   0x3ff0a6e4a51c5493
+       .quad   0x3ff0a8560f1beb2c
+       .quad   0x3ff0a9c7991ec278
+       .quad   0x3ff0ab394327a0a7
+       .quad   0x3ff0acab0d394c25
+       .quad   0x3ff0ae1cf7568b9d
+       .quad   0x3ff0af8f018225f7
+       .quad   0x3ff0b1012bbee259
+       .quad   0x3ff0b273760f8825
+       .quad   0x3ff0b3e5e076defc
+       .quad   0x3ff0b5586af7aebc
+       .quad   0x3ff0b6cb1594bf84
+       .quad   0x3ff0b83de050d9ab
+       .quad   0x3ff0b9b0cb2ec5ca
+       .quad   0x3ff0bb23d6314cb7
+       .quad   0x3ff0bc97015b3783
+       .quad   0x3ff0be0a4caf4f81
+       .quad   0x3ff0bf7db8305e3f
+       .quad   0x3ff0c0f143e12d8a
+       .quad   0x3ff0c264efc4876c
+       .quad   0x3ff0c3d8bbdd362e
+       .quad   0x3ff0c54ca82e0455
+       .quad   0x3ff0c6c0b4b9bca6
+       .quad   0x3ff0c834e1832a24
+       .quad   0x3ff0c9a92e8d180e
+       .quad   0x3ff0cb1d9bda51e1
+       .quad   0x3ff0cc92296da35b
+       .quad   0x3ff0ce06d749d876
+       .quad   0x3ff0cf7ba571bd6a
+       .quad   0x3ff0d0f093e81eab
+       .quad   0x3ff0d265a2afc8f1
+       .quad   0x3ff0d3dad1cb892b
+       .quad   0x3ff0d550213e2c8c
+       .quad   0x3ff0d6c5910a8081
+       .quad   0x3ff0d83b213352b8
+       .quad   0x3ff0d9b0d1bb711b
+       .quad   0x3ff0db26a2a5a9d4
+       .quad   0x3ff0dc9c93f4cb4a
+       .quad   0x3ff0de12a5aba423
+       .quad   0x3ff0df88d7cd0344
+       .quad   0x3ff0e0ff2a5bb7cd
+       .quad   0x3ff0e2759d5a9121
+       .quad   0x3ff0e3ec30cc5edd
+       .quad   0x3ff0e562e4b3f0df
+       .quad   0x3ff0e6d9b9141745
+       .quad   0x3ff0e850adefa265
+       .quad   0x3ff0e9c7c34962db
+       .quad   0x3ff0eb3ef924297d
+       .quad   0x3ff0ecb64f82c75e
+       .quad   0x3ff0ee2dc6680dd6
+       .quad   0x3ff0efa55dd6ce75
+       .quad   0x3ff0f11d15d1db0c
+       .quad   0x3ff0f294ee5c05ab
+       .quad   0x3ff0f40ce77820a2
+       .quad   0x3ff0f5850128fe7a
+       .quad   0x3ff0f6fd3b717200
+       .quad   0x3ff0f87596544e3f
+       .quad   0x3ff0f9ee11d4667f
+       .quad   0x3ff0fb66adf48e46
+       .quad   0x3ff0fcdf6ab7995c
+       .quad   0x3ff0fe5848205bc4
+       .quad   0x3ff0ffd14631a9c2
+       .quad   0x3ff1014a64ee57d9
+       .quad   0x3ff102c3a4593ac9
+       .quad   0x3ff1043d04752792
+       .quad   0x3ff105b68544f373
+       .quad   0x3ff1073026cb73e9
+       .quad   0x3ff108a9e90b7eb2
+       .quad   0x3ff10a23cc07e9c6
+       .quad   0x3ff10b9dcfc38b63
+       .quad   0x3ff10d17f44139fe
+       .quad   0x3ff10e923983cc53
+       .quad   0x3ff1100c9f8e1955
+       .quad   0x3ff111872662f83e
+       .quad   0x3ff11301ce054081
+       .quad   0x3ff1147c9677c9d2
+       .quad   0x3ff115f77fbd6c23
+       .quad   0x3ff1177289d8ffa9
+       .quad   0x3ff118edb4cd5cd4
+       .quad   0x3ff11a69009d5c54
+       .quad   0x3ff11be46d4bd71a
+       .quad   0x3ff11d5ffadba653
+       .quad   0x3ff11edba94fa36e
+       .quad   0x3ff1205778aaa817
+       .quad   0x3ff121d368ef8e3b
+       .quad   0x3ff1234f7a213008
+       .quad   0x3ff124cbac4267e5
+       .quad   0x3ff12647ff56107f
+       .quad   0x3ff127c4735f04bd
+       .quad   0x3ff1294108601fcb
+       .quad   0x3ff12abdbe5c3d0f
+       .quad   0x3ff12c3a95563832
+       .quad   0x3ff12db78d50ed19
+       .quad   0x3ff12f34a64f37ed
+       .quad   0x3ff130b1e053f513
+       .quad   0x3ff1322f3b62012e
+       .quad   0x3ff133acb77c3927
+       .quad   0x3ff1352a54a57a1f
+       .quad   0x3ff136a812e0a17c
+       .quad   0x3ff13825f2308ce0
+       .quad   0x3ff139a3f2981a2e
+       .quad   0x3ff13b22141a278a
+       .quad   0x3ff13ca056b99356
+       .quad   0x3ff13e1eba793c33
+       .quad   0x3ff13f9d3f5c0103
+       .quad   0x3ff1411be564c0e7
+       .quad   0x3ff1429aac965b40
+       .quad   0x3ff1441994f3afae
+       .quad   0x3ff145989e7f9e13
+       .quad   0x3ff14717c93d068e
+       .quad   0x3ff14897152ec980
+       .quad   0x3ff14a168257c787
+       .quad   0x3ff14b9610bae185
+       .quad   0x3ff14d15c05af897
+       .quad   0x3ff14e95913aee1e
+       .quad   0x3ff15015835da3b8
+       .quad   0x3ff1519596c5fb46
+       .quad   0x3ff15315cb76d6e5
+       .quad   0x3ff15496217318f6
+       .quad   0x3ff1561698bda417
+       .quad   0x3ff1579731595b27
+       .quad   0x3ff15917eb492145
+       .quad   0x3ff15a98c68fd9d1
+       .quad   0x3ff15c19c330686b
+       .quad   0x3ff15d9ae12db0ef
+       .quad   0x3ff15f1c208a977f
+       .quad   0x3ff1609d814a007b
+       .quad   0x3ff1621f036ed081
+       .quad   0x3ff163a0a6fbec71
+       .quad   0x3ff165226bf4396d
+       .quad   0x3ff166a4525a9cd3
+       .quad   0x3ff168265a31fc44
+       .quad   0x3ff169a8837d3da3
+       .quad   0x3ff16b2ace3f4710
+       .quad   0x3ff16cad3a7afeeb
+       .quad   0x3ff16e2fc8334bd8
+       .quad   0x3ff16fb2776b14b8
+       .quad   0x3ff17135482540ad
+       .quad   0x3ff172b83a64b71a
+       .quad   0x3ff1743b4e2c5fa4
+       .quad   0x3ff175be837f222d
+       .quad   0x3ff17741da5fe6da
+       .quad   0x3ff178c552d1960f
+       .quad   0x3ff17a48ecd71873
+       .quad   0x3ff17bcca87356e9
+       .quad   0x3ff17d5085a93a9b
+       .quad   0x3ff17ed4847bacec
+       .quad   0x3ff18058a4ed9787
+       .quad   0x3ff181dce701e451
+       .quad   0x3ff183614abb7d75
+       .quad   0x3ff184e5d01d4d5b
+       .quad   0x3ff1866a772a3ead
+       .quad   0x3ff187ef3fe53c58
+       .quad   0x3ff189742a513185
+       .quad   0x3ff18af9367109a1
+       .quad   0x3ff18c7e6447b059
+       .quad   0x3ff18e03b3d8119c
+       .quad   0x3ff18f8925251997
+       .quad   0x3ff1910eb831b4ba
+       .quad   0x3ff192946d00cfb6
+       .quad   0x3ff1941a4395577c
+       .quad   0x3ff195a03bf2393e
+       .quad   0x3ff19726561a626d
+       .quad   0x3ff198ac9210c0c1
+       .quad   0x3ff19a32efd8422c
+       .quad   0x3ff19bb96f73d4e5
+       .quad   0x3ff19d4010e66763
+       .quad   0x3ff19ec6d432e85c
+       .quad   0x3ff1a04db95c46cc
+       .quad   0x3ff1a1d4c06571ed
+       .quad   0x3ff1a35be9515937
+       .quad   0x3ff1a4e33422ec69
+       .quad   0x3ff1a66aa0dd1b81
+       .quad   0x3ff1a7f22f82d6bc
+       .quad   0x3ff1a979e0170e9a
+       .quad   0x3ff1ab01b29cb3dd
+       .quad   0x3ff1ac89a716b786
+       .quad   0x3ff1ae11bd880ada
+       .quad   0x3ff1af99f5f39f5d
+       .quad   0x3ff1b122505c66d5
+       .quad   0x3ff1b2aaccc5534b
+       .quad   0x3ff1b4336b315705
+       .quad   0x3ff1b5bc2ba3648e
+       .quad   0x3ff1b7450e1e6eb3
+       .quad   0x3ff1b8ce12a56880
+       .quad   0x3ff1ba57393b4544
+       .quad   0x3ff1bbe081e2f88e
+       .quad   0x3ff1bd69ec9f762f
+       .quad   0x3ff1bef37973b23b
+       .quad   0x3ff1c07d2862a105
+       .quad   0x3ff1c206f96f3724
+       .quad   0x3ff1c390ec9c696f
+       .quad   0x3ff1c51b01ed2cfe
+       .quad   0x3ff1c6a53964772e
+       .quad   0x3ff1c82f93053d99
+       .quad   0x3ff1c9ba0ed2761e
+       .quad   0x3ff1cb44accf16dc
+       .quad   0x3ff1cccf6cfe1634
+       .quad   0x3ff1ce5a4f626acb
+       .quad   0x3ff1cfe553ff0b83
+       .quad   0x3ff1d1707ad6ef85
+       .quad   0x3ff1d2fbc3ed0e37
+       .quad   0x3ff1d4872f445f44
+       .quad   0x3ff1d612bcdfda99
+       .quad   0x3ff1d79e6cc27863
+       .quad   0x3ff1d92a3eef3111
+       .quad   0x3ff1dab63368fd56
+       .quad   0x3ff1dc424a32d624
+       .quad   0x3ff1ddce834fb4b0
+       .quad   0x3ff1df5adec29273
+       .quad   0x3ff1e0e75c8e6927
+       .quad   0x3ff1e273fcb632c5
+       .quad   0x3ff1e400bf3ce98b
+       .quad   0x3ff1e58da42587fa
+       .quad   0x3ff1e71aab7308d1
+       .quad   0x3ff1e8a7d5286717
+       .quad   0x3ff1ea3521489e0e
+       .quad   0x3ff1ebc28fd6a942
+       .quad   0x3ff1ed5020d5847a
+       .quad   0x3ff1eeddd4482bc3
+       .quad   0x3ff1f06baa319b6b
+       .quad   0x3ff1f1f9a294d004
+       .quad   0x3ff1f387bd74c660
+       .quad   0x3ff1f515fad47b95
+       .quad   0x3ff1f6a45ab6ecfa
+       .quad   0x3ff1f832dd1f1829
+       .quad   0x3ff1f9c1820ffafe
+       .quad   0x3ff1fb50498c9397
+       .quad   0x3ff1fcdf3397e057
+       .quad   0x3ff1fe6e4034dfdf
+       .quad   0x3ff1fffd6f669115
+       .quad   0x3ff2018cc12ff324
+       .quad   0x3ff2031c35940574
+       .quad   0x3ff204abcc95c7b4
+       .quad   0x3ff2063b863839d2
+       .quad   0x3ff207cb627e5c01
+       .quad   0x3ff2095b616b2eb7
+       .quad   0x3ff20aeb8301b2aa
+       .quad   0x3ff20c7bc744e8d5
+       .quad   0x3ff20e0c2e37d274
+       .quad   0x3ff20f9cb7dd7108
+       .quad   0x3ff2112d6438c651
+       .quad   0x3ff212be334cd455
+       .quad   0x3ff2144f251c9d5b
+       .quad   0x3ff215e039ab23ee
+       .quad   0x3ff2177170fb6adb
+       .quad   0x3ff21902cb107531
+       .quad   0x3ff21a9447ed4643
+       .quad   0x3ff21c25e794e1a7
+       .quad   0x3ff21db7aa0a4b34
+       .quad   0x3ff21f498f508707
+       .quad   0x3ff220db976a997e
+       .quad   0x3ff2226dc25b8739
+       .quad   0x3ff224001026551c
+       .quad   0x3ff2259280ce084e
+       .quad   0x3ff227251455a63b
+       .quad   0x3ff228b7cac0348e
+       .quad   0x3ff22a4aa410b938
+       .quad   0x3ff22bdda04a3a6b
+       .quad   0x3ff22d70bf6fbea0
+       .quad   0x3ff22f0401844c8d
+       .quad   0x3ff23097668aeb31
+       .quad   0x3ff2322aee86a1ca
+       .quad   0x3ff233be997a77db
+       .quad   0x3ff235526769752b
+       .quad   0x3ff236e65856a1c4
+       .quad   0x3ff2387a6c4505ef
+       .quad   0x3ff23a0ea337aa40
+       .quad   0x3ff23ba2fd319789
+       .quad   0x3ff23d377a35d6de
+       .quad   0x3ff23ecc1a47719b
+       .quad   0x3ff24060dd69715c
+       .quad   0x3ff241f5c39ee002
+       .quad   0x3ff2438acceac7b2
+       .quad   0x3ff2451ff95032d1
+       .quad   0x3ff246b548d22c0c
+       .quad   0x3ff2484abb73be50
+       .quad   0x3ff249e05137f4cf
+       .quad   0x3ff24b760a21daff
+       .quad   0x3ff24d0be6347c98
+       .quad   0x3ff24ea1e572e597
+       .quad   0x3ff2503807e0223a
+       .quad   0x3ff251ce4d7f3f08
+       .quad   0x3ff25364b65348c6
+       .quad   0x3ff254fb425f4c80
+       .quad   0x3ff25691f1a65784
+       .quad   0x3ff25828c42b7763
+       .quad   0x3ff259bfb9f1b9f7
+       .quad   0x3ff25b56d2fc2d55
+       .quad   0x3ff25cee0f4ddfdd
+       .quad   0x3ff25e856ee9e031
+       .quad   0x3ff2601cf1d33d35
+       .quad   0x3ff261b4980d0613
+       .quad   0x3ff2634c619a4a36
+       .quad   0x3ff264e44e7e1952
+       .quad   0x3ff2667c5ebb8358
+       .quad   0x3ff2681492559883
+       .quad   0x3ff269ace94f694f
+       .quad   0x3ff26b4563ac067d
+       .quad   0x3ff26cde016e8111
+       .quad   0x3ff26e76c299ea53
+       .quad   0x3ff2700fa73153d1
+       .quad   0x3ff271a8af37cf5b
+       .quad   0x3ff27341dab06f07
+       .quad   0x3ff274db299e452c
+       .quad   0x3ff276749c046468
+       .quad   0x3ff2780e31e5df9c
+       .quad   0x3ff279a7eb45c9ef
+       .quad   0x3ff27b41c82736c8
+       .quad   0x3ff27cdbc88d39d8
+       .quad   0x3ff27e75ec7ae70f
+       .quad   0x3ff2801033f352a4
+       .quad   0x3ff281aa9ef99111
+       .quad   0x3ff283452d90b716
+       .quad   0x3ff284dfdfbbd9b7
+       .quad   0x3ff2867ab57e0e3a
+       .quad   0x3ff28815aeda6a2d
+       .quad   0x3ff289b0cbd4035f
+       .quad   0x3ff28b4c0c6defe6
+       .quad   0x3ff28ce770ab461b
+       .quad   0x3ff28e82f88f1c9e
+       .quad   0x3ff2901ea41c8a50
+       .quad   0x3ff291ba7356a657
+       .quad   0x3ff2935666408820
+       .quad   0x3ff294f27cdd475a
+       .quad   0x3ff2968eb72ffbfc
+       .quad   0x3ff2982b153bbe3d
+       .quad   0x3ff299c79703a69e
+       .quad   0x3ff29b643c8acdde
+       .quad   0x3ff29d0105d44d08
+       .quad   0x3ff29e9df2e33d66
+       .quad   0x3ff2a03b03bab88b
+       .quad   0x3ff2a1d8385dd84a
+       .quad   0x3ff2a37590cfb6bf
+       .quad   0x3ff2a5130d136e49
+       .quad   0x3ff2a6b0ad2c198d
+       .quad   0x3ff2a84e711cd374
+       .quad   0x3ff2a9ec58e8b729
+       .quad   0x3ff2ab8a6492e024
+       .quad   0x3ff2ad28941e6a18
+       .quad   0x3ff2aec6e78e7104
+       .quad   0x3ff2b0655ee61129
+       .quad   0x3ff2b203fa28670e
+       .quad   0x3ff2b3a2b9588f7f
+       .quad   0x3ff2b5419c79a78c
+       .quad   0x3ff2b6e0a38ecc8b
+       .quad   0x3ff2b87fce9b1c18
+       .quad   0x3ff2ba1f1da1b412
+       .quad   0x3ff2bbbe90a5b29e
+       .quad   0x3ff2bd5e27aa3627
+       .quad   0x3ff2befde2b25d5c
+       .quad   0x3ff2c09dc1c14733
+       .quad   0x3ff2c23dc4da12e4
+       .quad   0x3ff2c3ddebffdff0
+       .quad   0x3ff2c57e3735ce1a
+       .quad   0x3ff2c71ea67efd6d
+       .quad   0x3ff2c8bf39de8e38
+       .quad   0x3ff2ca5ff157a10f
+       .quad   0x3ff2cc00cced56cd
+       .quad   0x3ff2cda1cca2d08f
+       .quad   0x3ff2cf42f07b2fbd
+       .quad   0x3ff2d0e4387995fe
+       .quad   0x3ff2d285a4a12544
+       .quad   0x3ff2d42734f4ffc3
+       .quad   0x3ff2d5c8e97847f6
+       .quad   0x3ff2d76ac22e209d
+       .quad   0x3ff2d90cbf19acbd
+       .quad   0x3ff2daaee03e0fa3
+       .quad   0x3ff2dc51259e6ce0
+       .quad   0x3ff2ddf38f3de848
+       .quad   0x3ff2df961d1fa5f9
+       .quad   0x3ff2e138cf46ca57
+       .quad   0x3ff2e2dba5b67a06
+       .quad   0x3ff2e47ea071d9f4
+       .quad   0x3ff2e621bf7c0f57
+       .quad   0x3ff2e7c502d83fa4
+       .quad   0x3ff2e9686a89909e
+       .quad   0x3ff2eb0bf6932845
+       .quad   0x3ff2ecafa6f82ce7
+       .quad   0x3ff2ee537bbbc512
+       .quad   0x3ff2eff774e1179d
+       .quad   0x3ff2f19b926b4ba5
+       .quad   0x3ff2f33fd45d888a
+       .quad   0x3ff2f4e43abaf5f5
+       .quad   0x3ff2f688c586bbd5
+       .quad   0x3ff2f82d74c4025c
+       .quad   0x3ff2f9d24875f205
+       .quad   0x3ff2fb77409fb390
+       .quad   0x3ff2fd1c5d447003
+       .quad   0x3ff2fec19e6750ab
+       .quad   0x3ff30067040b7f19
+       .quad   0x3ff3020c8e342527
+       .quad   0x3ff303b23ce46cf4
+       .quad   0x3ff30558101f80e3
+       .quad   0x3ff306fe07e88ba0
+       .quad   0x3ff308a42442b81d
+       .quad   0x3ff30a4a65313191
+       .quad   0x3ff30bf0cab7237a
+       .quad   0x3ff30d9754d7b99d
+       .quad   0x3ff30f3e03962005
+       .quad   0x3ff310e4d6f58302
+       .quad   0x3ff3128bcef90f2b
+       .quad   0x3ff31432eba3f15f
+       .quad   0x3ff315da2cf956c2
+       .quad   0x3ff3178192fc6cbf
+       .quad   0x3ff319291db06106
+       .quad   0x3ff31ad0cd186190
+       .quad   0x3ff31c78a1379c9b
+       .quad   0x3ff31e209a1140ab
+       .quad   0x3ff31fc8b7a87c8c
+       .quad   0x3ff32170fa007f51
+       .quad   0x3ff32319611c7851
+       .quad   0x3ff324c1ecff972d
+       .quad   0x3ff3266a9dad0bca
+       .quad   0x3ff3281373280654
+       .quad   0x3ff329bc6d73b741
+       .quad   0x3ff32b658c934f48
+       .quad   0x3ff32d0ed089ff6c
+       .quad   0x3ff32eb8395af8f4
+       .quad   0x3ff33061c7096d6f
+       .quad   0x3ff3320b79988eb2
+       .quad   0x3ff333b5510b8eda
+       .quad   0x3ff3355f4d65a04a
+       .quad   0x3ff337096ea9f5ab
+       .quad   0x3ff338b3b4dbc1f0
+       .quad   0x3ff33a5e1ffe384f
+       .quad   0x3ff33c08b0148c49
+       .quad   0x3ff33db36521f1a3
+       .quad   0x3ff33f5e3f299c69
+       .quad   0x3ff341093e2ec0f2
+       .quad   0x3ff342b4623493d7
+       .quad   0x3ff3445fab3e49fa
+       .quad   0x3ff3460b194f1887
+       .quad   0x3ff347b6ac6a34ec
+       .quad   0x3ff349626492d4e2
+       .quad   0x3ff34b0e41cc2e67
+       .quad   0x3ff34cba441977c4
+       .quad   0x3ff34e666b7de784
+       .quad   0x3ff35012b7fcb47d
+       .quad   0x3ff351bf299915c9
+       .quad   0x3ff3536bc05642cf
+       .quad   0x3ff355187c377337
+       .quad   0x3ff356c55d3fdef4
+       .quad   0x3ff358726372be40
+       .quad   0x3ff35a1f8ed3499b
+       .quad   0x3ff35bccdf64b9cf
+       .quad   0x3ff35d7a552a47ea
+       .quad   0x3ff35f27f0272d45
+       .quad   0x3ff360d5b05ea37f
+       .quad   0x3ff3628395d3e47d
+       .quad   0x3ff36431a08a2a6f
+       .quad   0x3ff365dfd084afc9
+       .quad   0x3ff3678e25c6af48
+       .quad   0x3ff3693ca05363f3
+       .quad   0x3ff36aeb402e0915
+       .quad   0x3ff36c9a0559da43
+       .quad   0x3ff36e48efda1358
+       .quad   0x3ff36ff7ffb1f078
+       .quad   0x3ff371a734e4ae11
+       .quad   0x3ff373568f7588d3
+       .quad   0x3ff375060f67bdb9
+       .quad   0x3ff376b5b4be8a0a
+       .quad   0x3ff378657f7d2b4c
+       .quad   0x3ff37a156fa6df54
+       .quad   0x3ff37bc5853ee43d
+       .quad   0x3ff37d75c0487869
+       .quad   0x3ff37f2620c6da82
+       .quad   0x3ff380d6a6bd497c
+       .quad   0x3ff38287522f048e
+       .quad   0x3ff38438231f4b3f
+       .quad   0x3ff385e919915d57
+       .quad   0x3ff3879a35887ae9
+       .quad   0x3ff3894b7707e450
+       .quad   0x3ff38afcde12da2f
+       .quad   0x3ff38cae6aac9d71
+       .quad   0x3ff38e601cd86f48
+       .quad   0x3ff39011f4999132
+       .quad   0x3ff391c3f1f344f1
+       .quad   0x3ff3937614e8cc90
+       .quad   0x3ff395285d7d6a65
+       .quad   0x3ff396dacbb4610c
+       .quad   0x3ff3988d5f90f36a
+       .quad   0x3ff39a40191664ac
+       .quad   0x3ff39bf2f847f847
+       .quad   0x3ff39da5fd28f1f8
+       .quad   0x3ff39f5927bc95c8
+       .quad   0x3ff3a10c78062804
+       .quad   0x3ff3a2bfee08ed45
+       .quad   0x3ff3a47389c82a68
+       .quad   0x3ff3a6274b472498
+       .quad   0x3ff3a7db32892144
+       .quad   0x3ff3a98f3f916626
+       .quad   0x3ff3ab4372633941
+       .quad   0x3ff3acf7cb01e0de
+       .quad   0x3ff3aeac4970a392
+       .quad   0x3ff3b060edb2c837
+       .quad   0x3ff3b215b7cb95f3
+       .quad   0x3ff3b3caa7be5434
+       .quad   0x3ff3b57fbd8e4aae
+       .quad   0x3ff3b734f93ec163
+       .quad   0x3ff3b8ea5ad30097
+       .quad   0x3ff3ba9fe24e50dd
+       .quad   0x3ff3bc558fb3fb0d
+       .quad   0x3ff3be0b6307484a
+       .quad   0x3ff3bfc15c4b81ff
+       .quad   0x3ff3c1777b83f1e0
+       .quad   0x3ff3c32dc0b3e1ea
+       .quad   0x3ff3c4e42bde9c62
+       .quad   0x3ff3c69abd076bd8
+       .quad   0x3ff3c85174319b24
+       .quad   0x3ff3ca0851607565
+       .quad   0x3ff3cbbf54974607
+       .quad   0x3ff3cd767dd958bd
+       .quad   0x3ff3cf2dcd29f984
+       .quad   0x3ff3d0e5428c749e
+       .quad   0x3ff3d29cde04169e
+       .quad   0x3ff3d4549f942c57
+       .quad   0x3ff3d60c874002ee
+       .quad   0x3ff3d7c4950ae7cb
+       .quad   0x3ff3d97cc8f828a2
+       .quad   0x3ff3db35230b136f
+       .quad   0x3ff3dceda346f679
+       .quad   0x3ff3dea649af204f
+       .quad   0x3ff3e05f1646dfca
+       .quad   0x3ff3e2180911840c
+       .quad   0x3ff3e3d122125c7f
+       .quad   0x3ff3e58a614cb8db
+       .quad   0x3ff3e743c6c3e91b
+       .quad   0x3ff3e8fd527b3d8a
+       .quad   0x3ff3eab7047606b7
+       .quad   0x3ff3ec70dcb7957e
+       .quad   0x3ff3ee2adb433b04
+       .quad   0x3ff3efe5001c48b5
+       .quad   0x3ff3f19f4b46104c
+       .quad   0x3ff3f359bcc3e3c8
+       .quad   0x3ff3f51454991573
+       .quad   0x3ff3f6cf12c8f7e5
+       .quad   0x3ff3f889f756ddfa
+       .quad   0x3ff3fa4502461adb
+       .quad   0x3ff3fc00339a01f9
+       .quad   0x3ff3fdbb8b55e710
+       .quad   0x3ff3ff77097d1e26
+       .quad   0x3ff40132ae12fb8a
+       .quad   0x3ff402ee791ad3d5
+       .quad   0x3ff404aa6a97fbea
+       .quad   0x3ff40666828dc8f6
+       .quad   0x3ff40822c0ff9071
+       .quad   0x3ff409df25f0a81b
+       .quad   0x3ff40b9bb16465fe
+       .quad   0x3ff40d58635e2070
+       .quad   0x3ff40f153be12e0f
+       .quad   0x3ff410d23af0e5c5
+       .quad   0x3ff4128f60909ec4
+       .quad   0x3ff4144cacc3b08a
+       .quad   0x3ff4160a1f8d72dd
+       .quad   0x3ff417c7b8f13dd0
+       .quad   0x3ff4198578f269be
+       .quad   0x3ff41b435f944f4c
+       .quad   0x3ff41d016cda476c
+       .quad   0x3ff41ebfa0c7ab57
+       .quad   0x3ff4207dfb5fd491
+       .quad   0x3ff4223c7ca61cea
+       .quad   0x3ff423fb249dde7b
+       .quad   0x3ff425b9f34a73a7
+       .quad   0x3ff42778e8af371d
+       .quad   0x3ff4293804cf83d5
+       .quad   0x3ff42af747aeb511
+       .quad   0x3ff42cb6b1502661
+       .quad   0x3ff42e7641b73399
+       .quad   0x3ff43035f8e738de
+       .quad   0x3ff431f5d6e3929c
+       .quad   0x3ff433b5dbaf9d8b
+       .quad   0x3ff43576074eb6ac
+       .quad   0x3ff4373659c43b4c
+       .quad   0x3ff438f6d3138902
+       .quad   0x3ff43ab7733ffdb1
+       .quad   0x3ff43c783a4cf784
+       .quad   0x3ff43e39283dd4f5
+       .quad   0x3ff43ffa3d15f4c3
+       .quad   0x3ff441bb78d8b5fc
+       .quad   0x3ff4437cdb8977f9
+       .quad   0x3ff4453e652b9a59
+       .quad   0x3ff4470015c27d0e
+       .quad   0x3ff448c1ed51804b
+       .quad   0x3ff44a83ebdc0497
+       .quad   0x3ff44c4611656abf
+       .quad   0x3ff44e085df113da
+       .quad   0x3ff44fcad182614e
+       .quad   0x3ff4518d6c1cb4c9
+       .quad   0x3ff453502dc37045
+       .quad   0x3ff455131679f608
+       .quad   0x3ff456d62643a8a0
+       .quad   0x3ff458995d23eae9
+       .quad   0x3ff45a5cbb1e2009
+       .quad   0x3ff45c204035ab72
+       .quad   0x3ff45de3ec6df0df
+       .quad   0x3ff45fa7bfca5459
+       .quad   0x3ff4616bba4e3a34
+       .quad   0x3ff4632fdbfd070c
+       .quad   0x3ff464f424da1fcc
+       .quad   0x3ff466b894e8e9a6
+       .quad   0x3ff4687d2c2cca1e
+       .quad   0x3ff46a41eaa926fc
+       .quad   0x3ff46c06d061665a
+       .quad   0x3ff46dcbdd58ee98
+       .quad   0x3ff46f9111932664
+       .quad   0x3ff471566d1374b7
+       .quad   0x3ff4731befdd40d6
+       .quad   0x3ff474e199f3f251
+       .quad   0x3ff476a76b5af103
+       .quad   0x3ff4786d6415a514
+       .quad   0x3ff47a33842776f6
+       .quad   0x3ff47bf9cb93cf67
+       .quad   0x3ff47dc03a5e1772
+       .quad   0x3ff47f86d089b86d
+       .quad   0x3ff4814d8e1a1bf8
+       .quad   0x3ff483147312ac00
+       .quad   0x3ff484db7f76d2be
+       .quad   0x3ff486a2b349fab7
+       .quad   0x3ff4886a0e8f8ebb
+       .quad   0x3ff48a31914af9e6
+       .quad   0x3ff48bf93b7fa79f
+       .quad   0x3ff48dc10d31039b
+       .quad   0x3ff48f89066279da
+       .quad   0x3ff49151271776a6
+       .quad   0x3ff493196f536698
+       .quad   0x3ff494e1df19b693
+       .quad   0x3ff496aa766dd3c6
+       .quad   0x3ff4987335532bad
+       .quad   0x3ff49a3c1bcd2c0f
+       .quad   0x3ff49c0529df4300
+       .quad   0x3ff49dce5f8cdee0
+       .quad   0x3ff49f97bcd96e5a
+       .quad   0x3ff4a16141c86066
+       .quad   0x3ff4a32aee5d2449
+       .quad   0x3ff4a4f4c29b2993
+       .quad   0x3ff4a6bebe85e020
+       .quad   0x3ff4a888e220b819
+       .quad   0x3ff4aa532d6f21f4
+       .quad   0x3ff4ac1da0748e6f
+       .quad   0x3ff4ade83b346e9c
+       .quad   0x3ff4afb2fdb233d4
+       .quad   0x3ff4b17de7f14fbb
+       .quad   0x3ff4b348f9f53446
+       .quad   0x3ff4b51433c153b3
+       .quad   0x3ff4b6df9559208f
+       .quad   0x3ff4b8ab1ec00db1
+       .quad   0x3ff4ba76cff98e3e
+       .quad   0x3ff4bc42a90915a7
+       .quad   0x3ff4be0ea9f217aa
+       .quad   0x3ff4bfdad2b80852
+       .quad   0x3ff4c1a7235e5bf6
+       .quad   0x3ff4c3739be88737
+       .quad   0x3ff4c5403c59ff09
+       .quad   0x3ff4c70d04b638a6
+       .quad   0x3ff4c8d9f500a999
+       .quad   0x3ff4caa70d3cc7b9
+       .quad   0x3ff4cc744d6e0926
+       .quad   0x3ff4ce41b597e454
+       .quad   0x3ff4d00f45bdcffe
+       .quad   0x3ff4d1dcfde3432d
+       .quad   0x3ff4d3aade0bb539
+       .quad   0x3ff4d578e63a9dc2
+       .quad   0x3ff4d747167374bd
+       .quad   0x3ff4d9156eb9b264
+       .quad   0x3ff4dae3ef10cf42
+       .quad   0x3ff4dcb2977c442f
+       .quad   0x3ff4de8167ff8a4e
+       .quad   0x3ff4e050609e1b11
+       .quad   0x3ff4e21f815b7036
+       .quad   0x3ff4e3eeca3b03c9
+       .quad   0x3ff4e5be3b405022
+       .quad   0x3ff4e78dd46ecfe6
+       .quad   0x3ff4e95d95c9fe0b
+       .quad   0x3ff4eb2d7f5555ce
+       .quad   0x3ff4ecfd911452bd
+       .quad   0x3ff4eecdcb0a70b3
+       .quad   0x3ff4f09e2d3b2bd8
+       .quad   0x3ff4f26eb7aa00a1
+       .quad   0x3ff4f43f6a5a6bd2
+       .quad   0x3ff4f610454fea79
+       .quad   0x3ff4f7e1488df9f4
+       .quad   0x3ff4f9b2741817ee
+       .quad   0x3ff4fb83c7f1c25e
+       .quad   0x3ff4fd55441e778b
+       .quad   0x3ff4ff26e8a1b608
+       .quad   0x3ff500f8b57efcb6
+       .quad   0x3ff502caaab9cac1
+       .quad   0x3ff5049cc8559fa7
+       .quad   0x3ff5066f0e55fb31
+       .quad   0x3ff508417cbe5d77
+       .quad   0x3ff50a14139246db
+       .quad   0x3ff50be6d2d53812
+       .quad   0x3ff50db9ba8ab21a
+       .quad   0x3ff50f8ccab63642
+       .quad   0x3ff51160035b4625
+       .quad   0x3ff51333647d63ad
+       .quad   0x3ff51506ee201112
+       .quad   0x3ff516daa046d0d6
+       .quad   0x3ff518ae7af525ce
+       .quad   0x3ff51a827e2e931a
+       .quad   0x3ff51c56a9f69c2a
+       .quad   0x3ff51e2afe50c4b9
+       .quad   0x3ff51fff7b4090d2
+       .quad   0x3ff521d420c984ce
+       .quad   0x3ff523a8eeef2553
+       .quad   0x3ff5257de5b4f757
+       .quad   0x3ff52753051e801a
+       .quad   0x3ff529284d2f4530
+       .quad   0x3ff52afdbdeacc76
+       .quad   0x3ff52cd357549c19
+       .quad   0x3ff52ea919703a95
+       .quad   0x3ff5307f04412eb4
+       .quad   0x3ff5325517caff8d
+       .quad   0x3ff5342b54113485
+       .quad   0x3ff53601b9175551
+       .quad   0x3ff537d846e0e9f5
+       .quad   0x3ff539aefd717ac0
+       .quad   0x3ff53b85dccc9053
+       .quad   0x3ff53d5ce4f5b39a
+       .quad   0x3ff53f3415f06dd2
+       .quad   0x3ff5410b6fc04885
+       .quad   0x3ff542e2f268cd8c
+       .quad   0x3ff544ba9ded870f
+       .quad   0x3ff546927251ff84
+       .quad   0x3ff5486a6f99c1b1
+       .quad   0x3ff54a4295c858a6
+       .quad   0x3ff54c1ae4e14fc7
+       .quad   0x3ff54df35ce832c3
+       .quad   0x3ff54fcbfde08d9b
+       .quad   0x3ff551a4c7cdec9c
+       .quad   0x3ff5537dbab3dc60
+       .quad   0x3ff55556d695e9d6
+       .quad   0x3ff557301b77a236
+       .quad   0x3ff55909895c9309
+       .quad   0x3ff55ae320484a28
+       .quad   0x3ff55cbce03e55b7
+       .quad   0x3ff55e96c942442b
+       .quad   0x3ff56070db57a44b
+       .quad   0x3ff5624b16820529
+       .quad   0x3ff564257ac4f625
+       .quad   0x3ff56600082406f4
+       .quad   0x3ff567dabea2c792
+       .quad   0x3ff569b59e44c851
+       .quad   0x3ff56b90a70d99ce
+       .quad   0x3ff56d6bd900ccf5
+       .quad   0x3ff56f473421f304
+       .quad   0x3ff57122b8749d87
+       .quad   0x3ff572fe65fc5e58
+       .quad   0x3ff574da3cbcc7a0
+       .quad   0x3ff576b63cb96bd8
+       .quad   0x3ff5789265f5ddca
+       .quad   0x3ff57a6eb875b08c
+       .quad   0x3ff57c4b343c7786
+       .quad   0x3ff57e27d94dc66d
+       .quad   0x3ff58004a7ad3148
+       .quad   0x3ff581e19f5e4c6a
+       .quad   0x3ff583bec064ac79
+       .quad   0x3ff5859c0ac3e669
+       .quad   0x3ff587797e7f8f7c
+       .quad   0x3ff589571b9b3d44
+       .quad   0x3ff58b34e21a85a7
+       .quad   0x3ff58d12d200fed2
+       .quad   0x3ff58ef0eb523f4a
+       .quad   0x3ff590cf2e11ddde
+       .quad   0x3ff592ad9a4371af
+       .quad   0x3ff5948c2fea922e
+       .quad   0x3ff5966aef0ad71b
+       .quad   0x3ff59849d7a7d883
+       .quad   0x3ff59a28e9c52ec9
+       .quad   0x3ff59c0825667299
+       .quad   0x3ff59de78a8f3cf4
+       .quad   0x3ff59fc719432727
+       .quad   0x3ff5a1a6d185cad3
+       .quad   0x3ff5a386b35ac1e4
+       .quad   0x3ff5a566bec5a699
+       .quad   0x3ff5a746f3ca1381
+       .quad   0x3ff5a927526ba378
+       .quad   0x3ff5ab07daadf1af
+       .quad   0x3ff5ace88c9499a3
+       .quad   0x3ff5aec968233721
+       .quad   0x3ff5b0aa6d5d6649
+       .quad   0x3ff5b28b9c46c389
+       .quad   0x3ff5b46cf4e2eb9d
+       .quad   0x3ff5b64e77357b97
+       .quad   0x3ff5b830234210d3
+       .quad   0x3ff5ba11f90c4902
+       .quad   0x3ff5bbf3f897c221
+       .quad   0x3ff5bdd621e81a81
+       .quad   0x3ff5bfb87500f0c1
+       .quad   0x3ff5c19af1e5e3d2
+       .quad   0x3ff5c37d989a92f2
+       .quad   0x3ff5c56069229db4
+       .quad   0x3ff5c7436381a3f7
+       .quad   0x3ff5c92687bb45ed
+       .quad   0x3ff5cb09d5d3241a
+       .quad   0x3ff5cced4dccdf4c
+       .quad   0x3ff5ced0efac18aa
+       .quad   0x3ff5d0b4bb7471a6
+       .quad   0x3ff5d298b1298c02
+       .quad   0x3ff5d47cd0cf09d4
+       .quad   0x3ff5d6611a688d81
+       .quad   0x3ff5d8458df9b9bf
+       .quad   0x3ff5da2a2b863193
+       .quad   0x3ff5dc0ef3119855
+       .quad   0x3ff5ddf3e49f91ad
+       .quad   0x3ff5dfd90033c193
+       .quad   0x3ff5e1be45d1cc4f
+       .quad   0x3ff5e3a3b57d567d
+       .quad   0x3ff5e5894f3a0506
+       .quad   0x3ff5e76f130b7d27
+       .quad   0x3ff5e95500f5646d
+       .quad   0x3ff5eb3b18fb60b3
+       .quad   0x3ff5ed215b21182a
+       .quad   0x3ff5ef07c76a314e
+       .quad   0x3ff5f0ee5dda52f4
+       .quad   0x3ff5f2d51e752439
+       .quad   0x3ff5f4bc093e4c90
+       .quad   0x3ff5f6a31e3973bf
+       .quad   0x3ff5f88a5d6a41d9
+       .quad   0x3ff5fa71c6d45f43
+       .quad   0x3ff5fc595a7b74b4
+       .quad   0x3ff5fe4118632b33
+       .quad   0x3ff60029008f2c1b
+       .quad   0x3ff6021113032116
+       .quad   0x3ff603f94fc2b41f
+       .quad   0x3ff605e1b6d18f82
+       .quad   0x3ff607ca48335ddf
+       .quad   0x3ff609b303ebca24
+       .quad   0x3ff60b9be9fe7f93
+       .quad   0x3ff60d84fa6f29bf
+       .quad   0x3ff60f6e3541748a
+       .quad   0x3ff611579a790c29
+       .quad   0x3ff613412a199d25
+       .quad   0x3ff6152ae426d453
+       .quad   0x3ff61714c8a45edf
+       .quad   0x3ff618fed795ea44
+       .quad   0x3ff61ae910ff244e
+       .quad   0x3ff61cd374e3bb1b
+       .quad   0x3ff61ebe03475d1c
+       .quad   0x3ff620a8bc2db914
+       .quad   0x3ff622939f9a7e14
+       .quad   0x3ff6247ead915b83
+       .quad   0x3ff62669e6160116
+       .quad   0x3ff62855492c1ed7
+       .quad   0x3ff62a40d6d76521
+       .quad   0x3ff62c2c8f1b84a0
+       .quad   0x3ff62e1871fc2e52
+       .quad   0x3ff630047f7d1386
+       .quad   0x3ff631f0b7a1e5e1
+       .quad   0x3ff633dd1a6e5753
+       .quad   0x3ff635c9a7e61a25
+       .quad   0x3ff637b6600ce0ed
+       .quad   0x3ff639a342e65e97
+       .quad   0x3ff63b905076465f
+       .quad   0x3ff63d7d88c04bd0
+       .quad   0x3ff63f6aebc822cd
+       .quad   0x3ff6415879917f88
+       .quad   0x3ff6434632201685
+       .quad   0x3ff6453415779c9b
+       .quad   0x3ff64722239bc6f3
+       .quad   0x3ff649105c904b09
+       .quad   0x3ff64afec058dea9
+       .quad   0x3ff64ced4ef937f3
+       .quad   0x3ff64edc08750d5b
+       .quad   0x3ff650caecd015a3
+       .quad   0x3ff652b9fc0e07e3
+       .quad   0x3ff654a936329b85
+       .quad   0x3ff656989b418844
+       .quad   0x3ff658882b3e862e
+       .quad   0x3ff65a77e62d4da4
+       .quad   0x3ff65c67cc119759
+       .quad   0x3ff65e57dcef1c54
+       .quad   0x3ff6604818c995ed
+       .quad   0x3ff662387fa4bdce
+       .quad   0x3ff6642911844df6
+       .quad   0x3ff66619ce6c00b4
+       .quad   0x3ff6680ab65f90ac
+       .quad   0x3ff669fbc962b8d3
+       .quad   0x3ff66bed07793473
+       .quad   0x3ff66dde70a6bf26
+       .quad   0x3ff66fd004ef14db
+       .quad   0x3ff671c1c455f1d2
+       .quad   0x3ff673b3aedf129f
+       .quad   0x3ff675a5c48e342a
+       .quad   0x3ff67798056713aa
+       .quad   0x3ff6798a716d6eaf
+       .quad   0x3ff67b7d08a50316
+       .quad   0x3ff67d6fcb118f12
+       .quad   0x3ff67f62b8b6d12a
+       .quad   0x3ff68155d1988835
+       .quad   0x3ff6834915ba7361
+       .quad   0x3ff6853c8520522a
+       .quad   0x3ff687301fcde464
+       .quad   0x3ff68923e5c6ea33
+       .quad   0x3ff68b17d70f2412
+       .quad   0x3ff68d0bf3aa52c9
+       .quad   0x3ff68f003b9c3779
+       .quad   0x3ff690f4aee89395
+       .quad   0x3ff692e94d9328e0
+       .quad   0x3ff694de179fb976
+       .quad   0x3ff696d30d1207c0
+       .quad   0x3ff698c82dedd681
+       .quad   0x3ff69abd7a36e8c9
+       .quad   0x3ff69cb2f1f101ff
+       .quad   0x3ff69ea8951fe5e0
+       .quad   0x3ff6a09e63c75876
+       .quad   0x3ff6a2945deb1e23
+       .quad   0x3ff6a48a838efb9d
+       .quad   0x3ff6a680d4b6b5ec
+       .quad   0x3ff6a8775166126a
+       .quad   0x3ff6aa6df9a0d6c8
+       .quad   0x3ff6ac64cd6ac90a
+       .quad   0x3ff6ae5bccc7af86
+       .quad   0x3ff6b052f7bb50e6
+       .quad   0x3ff6b24a4e497429
+       .quad   0x3ff6b441d075e0a1
+       .quad   0x3ff6b6397e445df5
+       .quad   0x3ff6b83157b8b41e
+       .quad   0x3ff6ba295cd6ab6a
+       .quad   0x3ff6bc218da20c7a
+       .quad   0x3ff6be19ea1ea046
+       .quad   0x3ff6c01272503016
+       .quad   0x3ff6c20b263a8587
+       .quad   0x3ff6c40405e16a8b
+       .quad   0x3ff6c5fd1148a969
+       .quad   0x3ff6c7f648740cb9
+       .quad   0x3ff6c9efab675f6a
+       .quad   0x3ff6cbe93a266cbe
+       .quad   0x3ff6cde2f4b5004b
+       .quad   0x3ff6cfdcdb16e5fb
+       .quad   0x3ff6d1d6ed4fea0d
+       .quad   0x3ff6d3d12b63d914
+       .quad   0x3ff6d5cb95567ff7
+       .quad   0x3ff6d7c62b2babf1
+       .quad   0x3ff6d9c0ece72a93
+       .quad   0x3ff6dbbbda8cc9c0
+       .quad   0x3ff6ddb6f42057b0
+       .quad   0x3ff6dfb239a5a2f3
+       .quad   0x3ff6e1adab207a67
+       .quad   0x3ff6e3a94894ad43
+       .quad   0x3ff6e5a512060b13
+       .quad   0x3ff6e7a1077863b4
+       .quad   0x3ff6e99d28ef875a
+       .quad   0x3ff6eb99766f468d
+       .quad   0x3ff6ed95effb722a
+       .quad   0x3ff6ef929597db64
+       .quad   0x3ff6f18f674853bf
+       .quad   0x3ff6f38c6510ad16
+       .quad   0x3ff6f5898ef4b99a
+       .quad   0x3ff6f786e4f84bcd
+       .quad   0x3ff6f984671f368a
+       .quad   0x3ff6fb82156d4cfe
+       .quad   0x3ff6fd7fefe662ac
+       .quad   0x3ff6ff7df68e4b6c
+       .quad   0x3ff7017c2968db6b
+       .quad   0x3ff7037a8879e729
+       .quad   0x3ff7057913c5437d
+       .quad   0x3ff70777cb4ec594
+       .quad   0x3ff70976af1a42ec
+       .quad   0x3ff70b75bf2b915c
+       .quad   0x3ff70d74fb868710
+       .quad   0x3ff70f74642efa85
+       .quad   0x3ff71173f928c291
+       .quad   0x3ff71373ba77b65f
+       .quad   0x3ff71573a81fad6d
+       .quad   0x3ff71773c2247f90
+       .quad   0x3ff71974088a04f2
+       .quad   0x3ff71b747b541612
+       .quad   0x3ff71d751a868bc4
+       .quad   0x3ff71f75e6253f32
+       .quad   0x3ff72176de3409db
+       .quad   0x3ff7237802b6c593
+       .quad   0x3ff7257953b14c84
+       .quad   0x3ff7277ad127792f
+       .quad   0x3ff7297c7b1d2667
+       .quad   0x3ff72b7e51962f56
+       .quad   0x3ff72d8054966f7e
+       .quad   0x3ff72f828421c2b3
+       .quad   0x3ff73184e03c0520
+       .quad   0x3ff7338768e91346
+       .quad   0x3ff7358a1e2cc9fc
+       .quad   0x3ff7378d000b066d
+       .quad   0x3ff739900e87a61c
+       .quad   0x3ff73b9349a686df
+       .quad   0x3ff73d96b16b86e5
+       .quad   0x3ff73f9a45da84b1
+       .quad   0x3ff7419e06f75f1a
+       .quad   0x3ff743a1f4c5f551
+       .quad   0x3ff745a60f4a26da
+       .quad   0x3ff747aa5687d38f
+       .quad   0x3ff749aeca82dba1
+       .quad   0x3ff74bb36b3f1f98
+       .quad   0x3ff74db838c0804e
+       .quad   0x3ff74fbd330adef7
+       .quad   0x3ff751c25a221d1c
+       .quad   0x3ff753c7ae0a1c9b
+       .quad   0x3ff755cd2ec6bfaa
+       .quad   0x3ff757d2dc5be8d3
+       .quad   0x3ff759d8b6cd7af8
+       .quad   0x3ff75bdebe1f5950
+       .quad   0x3ff75de4f2556769
+       .quad   0x3ff75feb53738927
+       .quad   0x3ff761f1e17da2c4
+       .quad   0x3ff763f89c7798d0
+       .quad   0x3ff765ff84655034
+       .quad   0x3ff76806994aae2c
+       .quad   0x3ff76a0ddb2b984c
+       .quad   0x3ff76c154a0bf47d
+       .quad   0x3ff76e1ce5efa903
+       .quad   0x3ff77024aeda9c72
+       .quad   0x3ff7722ca4d0b5ba
+       .quad   0x3ff77434c7d5dc1c
+       .quad   0x3ff7763d17edf738
+       .quad   0x3ff77845951ceefb
+       .quad   0x3ff77a4e3f66abb0
+       .quad   0x3ff77c5716cf15f4
+       .quad   0x3ff77e601b5a16bd
+       .quad   0x3ff780694d0b9758
+       .quad   0x3ff78272abe78169
+       .quad   0x3ff7847c37f1bee8
+       .quad   0x3ff78685f12e3a27
+       .quad   0x3ff7888fd7a0ddcc
+       .quad   0x3ff78a99eb4d94d8
+       .quad   0x3ff78ca42c384a9f
+       .quad   0x3ff78eae9a64eacc
+       .quad   0x3ff790b935d76165
+       .quad   0x3ff792c3fe939ac3
+       .quad   0x3ff794cef49d8396
+       .quad   0x3ff796da17f908e9
+       .quad   0x3ff798e568aa181a
+       .quad   0x3ff79af0e6b49ee0
+       .quad   0x3ff79cfc921c8b49
+       .quad   0x3ff79f086ae5cbba
+       .quad   0x3ff7a11471144eef
+       .quad   0x3ff7a320a4ac03fa
+       .quad   0x3ff7a52d05b0da48
+       .quad   0x3ff7a7399426c19b
+       .quad   0x3ff7a9465011aa0b
+       .quad   0x3ff7ab5339758409
+       .quad   0x3ff7ad605056405d
+       .quad   0x3ff7af6d94b7d027
+       .quad   0x3ff7b17b069e24de
+       .quad   0x3ff7b388a60d3050
+       .quad   0x3ff7b5967308e4a3
+       .quad   0x3ff7b7a46d953455
+       .quad   0x3ff7b9b295b6123a
+       .quad   0x3ff7bbc0eb6f7180
+       .quad   0x3ff7bdcf6ec545aa
+       .quad   0x3ff7bfde1fbb8295
+       .quad   0x3ff7c1ecfe561c73
+       .quad   0x3ff7c3fc0a9907d2
+       .quad   0x3ff7c60b44883993
+       .quad   0x3ff7c81aac27a6f1
+       .quad   0x3ff7ca2a417b4580
+       .quad   0x3ff7cc3a04870b28
+       .quad   0x3ff7ce49f54eee2d
+       .quad   0x3ff7d05a13d6e52a
+       .quad   0x3ff7d26a6022e710
+       .quad   0x3ff7d47ada36eb2a
+       .quad   0x3ff7d68b8216e919
+       .quad   0x3ff7d89c57c6d8d7
+       .quad   0x3ff7daad5b4ab2b8
+       .quad   0x3ff7dcbe8ca66f64
+       .quad   0x3ff7decfebde07de
+       .quad   0x3ff7e0e178f57582
+       .quad   0x3ff7e2f333f0b201
+       .quad   0x3ff7e5051cd3b766
+       .quad   0x3ff7e71733a28014
+       .quad   0x3ff7e929786106c7
+       .quad   0x3ff7eb3beb134693
+       .quad   0x3ff7ed4e8bbd3ae3
+       .quad   0x3ff7ef615a62df7a
+       .quad   0x3ff7f17457083077
+       .quad   0x3ff7f38781b12a4e
+       .quad   0x3ff7f59ada61c9cc
+       .quad   0x3ff7f7ae611e0c17
+       .quad   0x3ff7f9c215e9eeae
+       .quad   0x3ff7fbd5f8c96f66
+       .quad   0x3ff7fdea09c08c72
+       .quad   0x3ff7fffe48d34457
+       .quad   0x3ff80212b60595f7
+       .quad   0x3ff80427515b808b
+       .quad   0x3ff8063c1ad903a4
+       .quad   0x3ff8085112821f2e
+       .quad   0x3ff80a66385ad36d
+       .quad   0x3ff80c7b8c6720fb
+       .quad   0x3ff80e910eab08ce
+       .quad   0x3ff810a6bf2a8c34
+       .quad   0x3ff812bc9de9acd3
+       .quad   0x3ff814d2aaec6cab
+       .quad   0x3ff816e8e636ce15
+       .quad   0x3ff818ff4fccd3c0
+       .quad   0x3ff81b15e7b280b9
+       .quad   0x3ff81d2cadebd863
+       .quad   0x3ff81f43a27cde79
+       .quad   0x3ff8215ac5699711
+       .quad   0x3ff8237216b60699
+       .quad   0x3ff82589966631da
+       .quad   0x3ff827a1447e1df3
+       .quad   0x3ff829b92101d060
+       .quad   0x3ff82bd12bf54ef1
+       .quad   0x3ff82de9655c9fd6
+       .quad   0x3ff83001cd3bc993
+       .quad   0x3ff8321a6396d307
+       .quad   0x3ff834332871c36a
+       .quad   0x3ff8364c1bd0a24e
+       .quad   0x3ff838653db7779f
+       .quad   0x3ff83a7e8e2a4ba1
+       .quad   0x3ff83c980d2d26f1
+       .quad   0x3ff83eb1bac41287
+       .quad   0x3ff840cb96f317b4
+       .quad   0x3ff842e5a1be4023
+       .quad   0x3ff844ffdb2995d7
+       .quad   0x3ff8471a4339232f
+       .quad   0x3ff84934d9f0f2e1
+       .quad   0x3ff84b4f9f550fff
+       .quad   0x3ff84d6a936985f4
+       .quad   0x3ff84f85b6326082
+       .quad   0x3ff851a107b3abca
+       .quad   0x3ff853bc87f17443
+       .quad   0x3ff855d836efc6bd
+       .quad   0x3ff857f414b2b067
+       .quad   0x3ff85a10213e3ec4
+       .quad   0x3ff85c2c5c967fb5
+       .quad   0x3ff85e48c6bf8171
+       .quad   0x3ff860655fbd528d
+       .quad   0x3ff86282279401f7
+       .quad   0x3ff8649f1e479ef5
+       .quad   0x3ff866bc43dc392a
+       .quad   0x3ff868d99855e08f
+       .quad   0x3ff86af71bb8a57c
+       .quad   0x3ff86d14ce08989e
+       .quad   0x3ff86f32af49cb03
+       .quad   0x3ff87150bf804e0b
+       .quad   0x3ff8736efeb03378
+       .quad   0x3ff8758d6cdd8d61
+       .quad   0x3ff877ac0a0c6e38
+       .quad   0x3ff879cad640e8cc
+       .quad   0x3ff87be9d17f1044
+       .quad   0x3ff87e08fbcaf822
+       .quad   0x3ff880285528b444
+       .quad   0x3ff88247dd9c58df
+       .quad   0x3ff884679529fa86
+       .quad   0x3ff886877bd5ae23
+       .quad   0x3ff888a791a388ff
+       .quad   0x3ff88ac7d697a0b9
+       .quad   0x3ff88ce84ab60b4f
+       .quad   0x3ff88f08ee02df15
+       .quad   0x3ff89129c08232be
+       .quad   0x3ff8934ac2381d54
+       .quad   0x3ff8956bf328b63f
+       .quad   0x3ff8978d53581541
+       .quad   0x3ff899aee2ca5273
+       .quad   0x3ff89bd0a183864e
+       .quad   0x3ff89df28f87c9a5
+       .quad   0x3ff8a014acdb35a2
+       .quad   0x3ff8a236f981e3cd
+       .quad   0x3ff8a459757fee0b
+       .quad   0x3ff8a67c20d96e96
+       .quad   0x3ff8a89efb928009
+       .quad   0x3ff8aac205af3d57
+       .quad   0x3ff8ace53f33c1ce
+       .quad   0x3ff8af08a8242919
+       .quad   0x3ff8b12c40848f3b
+       .quad   0x3ff8b35008591095
+       .quad   0x3ff8b573ffa5c9e2
+       .quad   0x3ff8b798266ed839
+       .quad   0x3ff8b9bc7cb8590d
+       .quad   0x3ff8bbe102866a27
+       .quad   0x3ff8be05b7dd29b2
+       .quad   0x3ff8c02a9cc0b632
+       .quad   0x3ff8c24fb1352e86
+       .quad   0x3ff8c474f53eb1e8
+       .quad   0x3ff8c69a68e15fed
+       .quad   0x3ff8c8c00c215887
+       .quad   0x3ff8cae5df02bc04
+       .quad   0x3ff8cd0be189ab0a
+       .quad   0x3ff8cf3213ba46a0
+       .quad   0x3ff8d1587598b023
+       .quad   0x3ff8d37f07290950
+       .quad   0x3ff8d5a5c86f743d
+       .quad   0x3ff8d7ccb970135d
+       .quad   0x3ff8d9f3da2f097f
+       .quad   0x3ff8dc1b2ab079ca
+       .quad   0x3ff8de42aaf887c7
+       .quad   0x3ff8e06a5b0b5758
+       .quad   0x3ff8e2923aed0cb7
+       .quad   0x3ff8e4ba4aa1cc81
+       .quad   0x3ff8e6e28a2dbba9
+       .quad   0x3ff8e90af994ff81
+       .quad   0x3ff8eb3398dbbdb7
+       .quad   0x3ff8ed5c68061c54
+       .quad   0x3ff8ef85671841bc
+       .quad   0x3ff8f1ae961654b0
+       .quad   0x3ff8f3d7f5047c4f
+       .quad   0x3ff8f60183e6e012
+       .quad   0x3ff8f82b42c1a7cf
+       .quad   0x3ff8fa553198fbb8
+       .quad   0x3ff8fc7f5071045a
+       .quad   0x3ff8fea99f4deaa1
+       .quad   0x3ff900d41e33d7d1
+       .quad   0x3ff902fecd26f58f
+       .quad   0x3ff90529ac2b6dda
+       .quad   0x3ff90754bb456b0e
+       .quad   0x3ff9097ffa7917e2
+       .quad   0x3ff90bab69ca9f6c
+       .quad   0x3ff90dd7093e2d1b
+       .quad   0x3ff91002d8d7ecbd
+       .quad   0x3ff9122ed89c0a7e
+       .quad   0x3ff9145b088eb2e4
+       .quad   0x3ff9168768b412d0
+       .quad   0x3ff918b3f9105783
+       .quad   0x3ff91ae0b9a7ae9b
+       .quad   0x3ff91d0daa7e4610
+       .quad   0x3ff91f3acb984c37
+       .quad   0x3ff921681cf9efc3
+       .quad   0x3ff923959ea75fc4
+       .quad   0x3ff925c350a4cba7
+       .quad   0x3ff927f132f66333
+       .quad   0x3ff92a1f45a05690
+       .quad   0x3ff92c4d88a6d63f
+       .quad   0x3ff92e7bfc0e1323
+       .quad   0x3ff930aa9fda3e74
+       .quad   0x3ff932d9740f89d1
+       .quad   0x3ff9350878b2272d
+       .quad   0x3ff93737adc648dd
+       .quad   0x3ff9396713502192
+       .quad   0x3ff93b96a953e45b
+       .quad   0x3ff93dc66fd5c4a2
+       .quad   0x3ff93ff666d9f630
+       .quad   0x3ff942268e64ad2b
+       .quad   0x3ff94456e67a1e16
+       .quad   0x3ff946876f1e7dd2
+       .quad   0x3ff948b82856019b
+       .quad   0x3ff94ae91224df0d
+       .quad   0x3ff94d1a2c8f4c1e
+       .quad   0x3ff94f4b77997f27
+       .quad   0x3ff9517cf347aeda
+       .quad   0x3ff953ae9f9e1246
+       .quad   0x3ff955e07ca0e0dd
+       .quad   0x3ff958128a545266
+       .quad   0x3ff95a44c8bc9f0e
+       .quad   0x3ff95c7737ddff5a
+       .quad   0x3ff95ea9d7bcac2f
+       .quad   0x3ff960dca85cdecf
+       .quad   0x3ff9630fa9c2d0da
+       .quad   0x3ff96542dbf2bc4e
+       .quad   0x3ff967763ef0db86
+       .quad   0x3ff969a9d2c1693a
+       .quad   0x3ff96bdd9768a084
+       .quad   0x3ff96e118ceabcd7
+       .quad   0x3ff97045b34bfa05
+       .quad   0x3ff9727a0a90943f
+       .quad   0x3ff974ae92bcc816
+       .quad   0x3ff976e34bd4d273
+       .quad   0x3ff9791835dcf0a3
+       .quad   0x3ff97b4d50d9604e
+       .quad   0x3ff97d829cce5f7c
+       .quad   0x3ff97fb819c02c8f
+       .quad   0x3ff981edc7b3064d
+       .quad   0x3ff98423a6ab2bd5
+       .quad   0x3ff98659b6acdca7
+       .quad   0x3ff9888ff7bc58a2
+       .quad   0x3ff98ac669dde001
+       .quad   0x3ff98cfd0d15b35d
+       .quad   0x3ff98f33e16813b0
+       .quad   0x3ff9916ae6d94251
+       .quad   0x3ff993a21d6d80f4
+       .quad   0x3ff995d9852911ae
+       .quad   0x3ff998111e1036f2
+       .quad   0x3ff99a48e827338e
+       .quad   0x3ff99c80e3724ab5
+       .quad   0x3ff99eb90ff5bff1
+       .quad   0x3ff9a0f16db5d730
+       .quad   0x3ff9a329fcb6d4be
+       .quad   0x3ff9a562bcfcfd42
+       .quad   0x3ff9a79bae8c95c8
+       .quad   0x3ff9a9d4d169e3b4
+       .quad   0x3ff9ac0e25992ccd
+       .quad   0x3ff9ae47ab1eb739
+       .quad   0x3ff9b08161fec979
+       .quad   0x3ff9b2bb4a3daa71
+       .quad   0x3ff9b4f563dfa161
+       .quad   0x3ff9b72faee8f5e9
+       .quad   0x3ff9b96a2b5df009
+       .quad   0x3ff9bba4d942d81f
+       .quad   0x3ff9bddfb89bf6e9
+       .quad   0x3ff9c01ac96d9580
+       .quad   0x3ff9c2560bbbfd60
+       .quad   0x3ff9c4917f8b7866
+       .quad   0x3ff9c6cd24e050c8
+       .quad   0x3ff9c908fbbed121
+       .quad   0x3ff9cb45042b4467
+       .quad   0x3ff9cd813e29f5f2
+       .quad   0x3ff9cfbda9bf3179
+       .quad   0x3ff9d1fa46ef430e
+       .quad   0x3ff9d43715be772a
+       .quad   0x3ff9d67416311aa0
+       .quad   0x3ff9d8b1484b7aa2
+       .quad   0x3ff9daeeac11e4c5
+       .quad   0x3ff9dd2c4188a6fb
+       .quad   0x3ff9df6a08b40f94
+       .quad   0x3ff9e1a801986d45
+       .quad   0x3ff9e3e62c3a0f1d
+       .quad   0x3ff9e624889d448d
+       .quad   0x3ff9e86316c65d65
+       .quad   0x3ff9eaa1d6b9a9d6
+       .quad   0x3ff9ece0c87b7a6f
+       .quad   0x3ff9ef1fec102020
+       .quad   0x3ff9f15f417bec36
+       .quad   0x3ff9f39ec8c33062
+       .quad   0x3ff9f5de81ea3eb2
+       .quad   0x3ff9f81e6cf56995
+       .quad   0x3ff9fa5e89e903d9
+       .quad   0x3ff9fc9ed8c960ac
+       .quad   0x3ff9fedf599ad39d
+       .quad   0x3ffa01200c61b09a
+       .quad   0x3ffa0360f1224bf2
+       .quad   0x3ffa05a207e0fa53
+       .quad   0x3ffa07e350a210ca
+       .quad   0x3ffa0a24cb69e4c7
+       .quad   0x3ffa0c66783ccc19
+       .quad   0x3ffa0ea8571f1ced
+       .quad   0x3ffa10ea68152dd4
+       .quad   0x3ffa132cab2355bc
+       .quad   0x3ffa156f204debf5
+       .quad   0x3ffa17b1c7994830
+       .quad   0x3ffa19f4a109c27b
+       .quad   0x3ffa1c37aca3b348
+       .quad   0x3ffa1e7aea6b7367
+       .quad   0x3ffa20be5a655c0a
+       .quad   0x3ffa2301fc95c6c4
+       .quad   0x3ffa2545d1010d86
+       .quad   0x3ffa2789d7ab8aa3
+       .quad   0x3ffa29ce109998cf
+       .quad   0x3ffa2c127bcf931c
+       .quad   0x3ffa2e571951d502
+       .quad   0x3ffa309be924ba55
+       .quad   0x3ffa32e0eb4c9f4a
+       .quad   0x3ffa35261fcde079
+       .quad   0x3ffa376b86acdad9
+       .quad   0x3ffa39b11fedebc2
+       .quad   0x3ffa3bf6eb9570ef
+       .quad   0x3ffa3e3ce9a7c878
+       .quad   0x3ffa40831a2950d8
+       .quad   0x3ffa42c97d1e68ec
+       .quad   0x3ffa4510128b6ff1
+       .quad   0x3ffa4756da74c583
+       .quad   0x3ffa499dd4dec9a2
+       .quad   0x3ffa4be501cddcad
+       .quad   0x3ffa4e2c61465f66
+       .quad   0x3ffa5073f34cb2f0
+       .quad   0x3ffa52bbb7e538cc
+       .quad   0x3ffa5503af1452e0
+       .quad   0x3ffa574bd8de6371
+       .quad   0x3ffa59943547cd25
+       .quad   0x3ffa5bdcc454f307
+       .quad   0x3ffa5e25860a387d
+       .quad   0x3ffa606e7a6c0154
+       .quad   0x3ffa62b7a17eb1b8
+       .quad   0x3ffa6500fb46ae37
+       .quad   0x3ffa674a87c85bbf
+       .quad   0x3ffa699447081fa2
+       .quad   0x3ffa6bde390a5f91
+       .quad   0x3ffa6e285dd3819f
+       .quad   0x3ffa7072b567ec43
+       .quad   0x3ffa72bd3fcc0653
+       .quad   0x3ffa7507fd043708
+       .quad   0x3ffa7752ed14e5fb
+       .quad   0x3ffa799e10027b29
+       .quad   0x3ffa7be965d15ef0
+       .quad   0x3ffa7e34ee85fa0f
+       .quad   0x3ffa8080aa24b5a6
+       .quad   0x3ffa82cc98b1fb3a
+       .quad   0x3ffa8518ba3234b0
+       .quad   0x3ffa87650ea9cc4d
+       .quad   0x3ffa89b1961d2cbb
+       .quad   0x3ffa8bfe5090c106
+       .quad   0x3ffa8e4b3e08f499
+       .quad   0x3ffa90985e8a3344
+       .quad   0x3ffa92e5b218e937
+       .quad   0x3ffa953338b98307
+       .quad   0x3ffa9780f2706da6
+       .quad   0x3ffa99cedf42166e
+       .quad   0x3ffa9c1cff32eb19
+       .quad   0x3ffa9e6b524759c1
+       .quad   0x3ffaa0b9d883d0e6
+       .quad   0x3ffaa30891ecbf66
+       .quad   0x3ffaa5577e869486
+       .quad   0x3ffaa7a69e55bfea
+       .quad   0x3ffaa9f5f15eb19b
+       .quad   0x3ffaac4577a5da02
+       .quad   0x3ffaae95312fa9ec
+       .quad   0x3ffab0e51e009287
+       .quad   0x3ffab3353e1d0565
+       .quad   0x3ffab5859189747c
+       .quad   0x3ffab7d6184a5220
+       .quad   0x3ffaba26d264110c
+       .quad   0x3ffabc77bfdb245d
+       .quad   0x3ffabec8e0b3ff90
+       .quad   0x3ffac11a34f31687
+       .quad   0x3ffac36bbc9cdd87
+       .quad   0x3ffac5bd77b5c936
+       .quad   0x3ffac80f66424e9f
+       .quad   0x3ffaca618846e330
+       .quad   0x3ffaccb3ddc7fcb7
+       .quad   0x3ffacf0666ca1167
+       .quad   0x3ffad159235197d6
+       .quad   0x3ffad3ac136306fc
+       .quad   0x3ffad5ff3702d636
+       .quad   0x3ffad8528e357d43
+       .quad   0x3ffadaa618ff7445
+       .quad   0x3ffadcf9d76533bf
+       .quad   0x3ffadf4dc96b349b
+       .quad   0x3ffae1a1ef15f025
+       .quad   0x3ffae3f64869e00c
+       .quad   0x3ffae64ad56b7e60
+       .quad   0x3ffae89f961f4598
+       .quad   0x3ffaeaf48a89b08d
+       .quad   0x3ffaed49b2af3a7a
+       .quad   0x3ffaef9f0e945eff
+       .quad   0x3ffaf1f49e3d9a1f
+       .quad   0x3ffaf44a61af6840
+       .quad   0x3ffaf6a058ee462d
+       .quad   0x3ffaf8f683feb114
+       .quad   0x3ffafb4ce2e52685
+       .quad   0x3ffafda375a62474
+       .quad   0x3ffafffa3c46293a
+       .quad   0x3ffb025136c9b394
+       .quad   0x3ffb04a8653542a2
+       .quad   0x3ffb06ffc78d55e6
+       .quad   0x3ffb09575dd66d48
+       .quad   0x3ffb0baf28150913
+       .quad   0x3ffb0e07264da9f8
+       .quad   0x3ffb105f5884d106
+       .quad   0x3ffb12b7bebeffb8
+       .quad   0x3ffb15105900b7e6
+       .quad   0x3ffb1769274e7bcf
+       .quad   0x3ffb19c229acce18
+       .quad   0x3ffb1c1b602031c6
+       .quad   0x3ffb1e74caad2a44
+       .quad   0x3ffb20ce69583b61
+       .quad   0x3ffb23283c25e951
+       .quad   0x3ffb2582431ab8ab
+       .quad   0x3ffb27dc7e3b2e6b
+       .quad   0x3ffb2a36ed8bcff1
+       .quad   0x3ffb2c9191112300
+       .quad   0x3ffb2eec68cfadc2
+       .quad   0x3ffb314774cbf6c3
+       .quad   0x3ffb33a2b50a84f5
+       .quad   0x3ffb35fe298fdfad
+       .quad   0x3ffb3859d2608ea7
+       .quad   0x3ffb3ab5af811a00
+       .quad   0x3ffb3d11c0f60a3b
+       .quad   0x3ffb3f6e06c3e840
+       .quad   0x3ffb41ca80ef3d5d
+       .quad   0x3ffb44272f7c9343
+       .quad   0x3ffb468412707405
+       .quad   0x3ffb48e129cf6a20
+       .quad   0x3ffb4b3e759e0071
+       .quad   0x3ffb4d9bf5e0c23e
+       .quad   0x3ffb4ff9aa9c3b30
+       .quad   0x3ffb525793d4f751
+       .quad   0x3ffb54b5b18f8319
+       .quad   0x3ffb571403d06b5b
+       .quad   0x3ffb59728a9c3d55
+       .quad   0x3ffb5bd145f786a7
+       .quad   0x3ffb5e3035e6d559
+       .quad   0x3ffb608f5a6eb7d6
+       .quad   0x3ffb62eeb393bcee
+       .quad   0x3ffb654e415a73d6
+       .quad   0x3ffb67ae03c76c2a
+       .quad   0x3ffb6a0dfadf35e8
+       .quad   0x3ffb6c6e26a66177
+       .quad   0x3ffb6ece87217fa1
+       .quad   0x3ffb712f1c552196
+       .quad   0x3ffb738fe645d8e9
+       .quad   0x3ffb75f0e4f83795
+       .quad   0x3ffb78521870cffb
+       .quad   0x3ffb7ab380b434df
+       .quad   0x3ffb7d151dc6f96c
+       .quad   0x3ffb7f76efadb132
+       .quad   0x3ffb81d8f66cf026
+       .quad   0x3ffb843b32094aa4
+       .quad   0x3ffb869da287556c
+       .quad   0x3ffb890047eba5a5
+       .quad   0x3ffb8b63223ad0da
+       .quad   0x3ffb8dc631796cfe
+       .quad   0x3ffb902975ac1068
+       .quad   0x3ffb928ceed751d6
+       .quad   0x3ffb94f09cffc869
+       .quad   0x3ffb9754802a0bab
+       .quad   0x3ffb99b8985ab38a
+       .quad   0x3ffb9c1ce596585d
+       .quad   0x3ffb9e8167e192dc
+       .quad   0x3ffba0e61f40fc29
+       .quad   0x3ffba34b0bb92dca
+       .quad   0x3ffba5b02d4ec1ab
+       .quad   0x3ffba81584065220
+       .quad   0x3ffbaa7b0fe479e1
+       .quad   0x3ffbace0d0edd40c
+       .quad   0x3ffbaf46c726fc27
+       .quad   0x3ffbb1acf2948e1f
+       .quad   0x3ffbb413533b2643
+       .quad   0x3ffbb679e91f614c
+       .quad   0x3ffbb8e0b445dc58
+       .quad   0x3ffbbb47b4b334eb
+       .quad   0x3ffbbdaeea6c08f0
+       .quad   0x3ffbc0165574f6bb
+       .quad   0x3ffbc27df5d29d00
+       .quad   0x3ffbc4e5cb899adf
+       .quad   0x3ffbc74dd69e8fdc
+       .quad   0x3ffbc9b617161be5
+       .quad   0x3ffbcc1e8cf4df48
+       .quad   0x3ffbce87383f7ac1
+       .quad   0x3ffbd0f018fa8f6d
+       .quad   0x3ffbd3592f2abed3
+       .quad   0x3ffbd5c27ad4aae0
+       .quad   0x3ffbd82bfbfcf5e7
+       .quad   0x3ffbda95b2a842a2
+       .quad   0x3ffbdcff9edb3432
+       .quad   0x3ffbdf69c09a6e20
+       .quad   0x3ffbe1d417ea945a
+       .quad   0x3ffbe43ea4d04b36
+       .quad   0x3ffbe6a967503772
+       .quad   0x3ffbe9145f6efe30
+       .quad   0x3ffbeb7f8d3144fc
+       .quad   0x3ffbedeaf09bb1c7
+       .quad   0x3ffbf05689b2eaec
+       .quad   0x3ffbf2c2587b9729
+       .quad   0x3ffbf52e5cfa5da6
+       .quad   0x3ffbf79a9733e5f3
+       .quad   0x3ffbfa07072cd804
+       .quad   0x3ffbfc73ace9dc39
+       .quad   0x3ffbfee0886f9b53
+       .quad   0x3ffc014d99c2be80
+       .quad   0x3ffc03bae0e7ef53
+       .quad   0x3ffc06285de3d7c7
+       .quad   0x3ffc089610bb223d
+       .quad   0x3ffc0b03f9727980
+       .quad   0x3ffc0d72180e88c1
+       .quad   0x3ffc0fe06c93fb98
+       .quad   0x3ffc124ef7077e06
+       .quad   0x3ffc14bdb76dbc74
+       .quad   0x3ffc172cadcb63b0
+       .quad   0x3ffc199bda2520f2
+       .quad   0x3ffc1c0b3c7fa1d9
+       .quad   0x3ffc1e7ad4df946e
+       .quad   0x3ffc20eaa349a71c
+       .quad   0x3ffc235aa7c288be
+       .quad   0x3ffc25cae24ee890
+       .quad   0x3ffc283b52f37637
+       .quad   0x3ffc2aabf9b4e1c5
+       .quad   0x3ffc2d1cd697dbaf
+       .quad   0x3ffc2f8de9a114d2
+       .quad   0x3ffc31ff32d53e76
+       .quad   0x3ffc3470b2390a49
+       .quad   0x3ffc36e267d12a62
+       .quad   0x3ffc395453a25140
+       .quad   0x3ffc3bc675b131cb
+       .quad   0x3ffc3e38ce027f50
+       .quad   0x3ffc40ab5c9aed89
+       .quad   0x3ffc431e217f3095
+       .quad   0x3ffc45911cb3fcfd
+       .quad   0x3ffc48044e3e07b0
+       .quad   0x3ffc4a77b6220609
+       .quad   0x3ffc4ceb5464adc8
+       .quad   0x3ffc4f5f290ab517
+       .quad   0x3ffc51d33418d28a
+       .quad   0x3ffc54477593bd1c
+       .quad   0x3ffc56bbed802c30
+       .quad   0x3ffc59309be2d792
+       .quad   0x3ffc5ba580c07778
+       .quad   0x3ffc5e1a9c1dc47f
+       .quad   0x3ffc608fedff77ae
+       .quad   0x3ffc6305766a4a74
+       .quad   0x3ffc657b3562f6a9
+       .quad   0x3ffc67f12aee368d
+       .quad   0x3ffc6a675710c4cc
+       .quad   0x3ffc6cddb9cf5c77
+       .quad   0x3ffc6f54532eb909
+       .quad   0x3ffc71cb23339668
+       .quad   0x3ffc744229e2b0e1
+       .quad   0x3ffc76b96740c52b
+       .quad   0x3ffc7930db529065
+       .quad   0x3ffc7ba8861cd01a
+       .quad   0x3ffc7e2067a44239
+       .quad   0x3ffc80987feda51f
+       .quad   0x3ffc8310cefdb791
+       .quad   0x3ffc858954d938bc
+       .quad   0x3ffc88021184e837
+       .quad   0x3ffc8a7b05058602
+       .quad   0x3ffc8cf42f5fd289
+       .quad   0x3ffc8f6d90988e9c
+       .quad   0x3ffc91e728b47b79
+       .quad   0x3ffc9460f7b85ac7
+       .quad   0x3ffc96dafda8ee95
+       .quad   0x3ffc99553a8af95b
+       .quad   0x3ffc9bcfae633dfe
+       .quad   0x3ffc9e4a59367fca
+       .quad   0x3ffca0c53b098273
+       .quad   0x3ffca34053e10a1b
+       .quad   0x3ffca5bba3c1db4b
+       .quad   0x3ffca8372ab0baf6
+       .quad   0x3ffcaab2e8b26e78
+       .quad   0x3ffcad2eddcbbb9a
+       .quad   0x3ffcafab0a01688c
+       .quad   0x3ffcb2276d583be7
+       .quad   0x3ffcb4a407d4fcb3
+       .quad   0x3ffcb720d97c725c
+       .quad   0x3ffcb99de25364bb
+       .quad   0x3ffcbc1b225e9c14
+       .quad   0x3ffcbe9899a2e114
+       .quad   0x3ffcc1164824fcd0
+       .quad   0x3ffcc3942de9b8ca
+       .quad   0x3ffcc6124af5deee
+       .quad   0x3ffcc8909f4e3990
+       .quad   0x3ffccb0f2af79372
+       .quad   0x3ffccd8dedf6b7bd
+       .quad   0x3ffcd00ce8507204
+       .quad   0x3ffcd28c1a098e48
+       .quad   0x3ffcd50b8326d8f2
+       .quad   0x3ffcd78b23ad1ed5
+       .quad   0x3ffcda0afba12d30
+       .quad   0x3ffcdc8b0b07d1aa
+       .quad   0x3ffcdf0b51e5da58
+       .quad   0x3ffce18bd04015b7
+       .quad   0x3ffce40c861b52b1
+       .quad   0x3ffce68d737c6096
+       .quad   0x3ffce90e98680f28
+       .quad   0x3ffceb8ff4e32e8c
+       .quad   0x3ffcee1188f28f58
+       .quad   0x3ffcf093549b0289
+       .quad   0x3ffcf31557e15988
+       .quad   0x3ffcf59792ca6629
+       .quad   0x3ffcf81a055afaab
+       .quad   0x3ffcfa9caf97e9b8
+       .quad   0x3ffcfd1f91860666
+       .quad   0x3ffcffa2ab2a2432
+       .quad   0x3ffd0225fc891709
+       .quad   0x3ffd04a985a7b341
+       .quad   0x3ffd072d468acd9b
+       .quad   0x3ffd09b13f373b42
+       .quad   0x3ffd0c356fb1d1ce
+       .quad   0x3ffd0eb9d7ff6743
+       .quad   0x3ffd113e7824d20f
+       .quad   0x3ffd13c35026e90b
+       .quad   0x3ffd1648600a837b
+       .quad   0x3ffd18cda7d4790f
+       .quad   0x3ffd1b532789a1e4
+       .quad   0x3ffd1dd8df2ed681
+       .quad   0x3ffd205ecec8efd8
+       .quad   0x3ffd22e4f65cc746
+       .quad   0x3ffd256b55ef3696
+       .quad   0x3ffd27f1ed8517fd
+       .quad   0x3ffd2a78bd23461a
+       .quad   0x3ffd2cffc4ce9bfe
+       .quad   0x3ffd2f87048bf51e
+       .quad   0x3ffd320e7c602d5e
+       .quad   0x3ffd34962c50210e
+       .quad   0x3ffd371e1460aced
+       .quad   0x3ffd39a63496ae1e
+       .quad   0x3ffd3c2e8cf70237
+       .quad   0x3ffd3eb71d868736
+       .quad   0x3ffd413fe64a1b88
+       .quad   0x3ffd43c8e7469e02
+       .quad   0x3ffd46522080edeb
+       .quad   0x3ffd48db91fdeaf0
+       .quad   0x3ffd4b653bc2752c
+       .quad   0x3ffd4def1dd36d29
+       .quad   0x3ffd50793835b3da
+       .quad   0x3ffd53038aee2a9f
+       .quad   0x3ffd558e1601b344
+       .quad   0x3ffd5818d9753003
+       .quad   0x3ffd5aa3d54d8381
+       .quad   0x3ffd5d2f098f90cf
+       .quad   0x3ffd5fba76403b6b
+       .quad   0x3ffd62461b64673f
+       .quad   0x3ffd64d1f900f8a4
+       .quad   0x3ffd675e0f1ad45a
+       .quad   0x3ffd69ea5db6df94
+       .quad   0x3ffd6c76e4d9ffed
+       .quad   0x3ffd6f03a4891b6e
+       .quad   0x3ffd71909cc9188f
+       .quad   0x3ffd741dcd9ede30
+       .quad   0x3ffd76ab370f53a1
+       .quad   0x3ffd7938d91f609f
+       .quad   0x3ffd7bc6b3d3ed53
+       .quad   0x3ffd7e54c731e251
+       .quad   0x3ffd80e3133e289e
+       .quad   0x3ffd837197fda9a8
+       .quad   0x3ffd860055754f4c
+       .quad   0x3ffd888f4baa03d3
+       .quad   0x3ffd8b1e7aa0b1f5
+       .quad   0x3ffd8dade25e44d5
+       .quad   0x3ffd903d82e7a803
+       .quad   0x3ffd92cd5c41c77f
+       .quad   0x3ffd955d6e718fb2
+       .quad   0x3ffd97edb97bed76
+       .quad   0x3ffd9a7e3d65ce10
+       .quad   0x3ffd9d0efa341f33
+       .quad   0x3ffd9f9fefebceff
+       .quad   0x3ffda2311e91cc02
+       .quad   0x3ffda4c2862b0536
+       .quad   0x3ffda75426bc6a05
+       .quad   0x3ffda9e6004aea45
+       .quad   0x3ffdac7812db7638
+       .quad   0x3ffdaf0a5e72fe91
+       .quad   0x3ffdb19ce316746e
+       .quad   0x3ffdb42fa0cac95a
+       .quad   0x3ffdb6c29794ef50
+       .quad   0x3ffdb955c779d8b8
+       .quad   0x3ffdbbe9307e7867
+       .quad   0x3ffdbe7cd2a7c1a1
+       .quad   0x3ffdc110adfaa815
+       .quad   0x3ffdc3a4c27c1fe4
+       .quad   0x3ffdc63910311d9a
+       .quad   0x3ffdc8cd971e9631
+       .quad   0x3ffdcb6257497f13
+       .quad   0x3ffdcdf750b6ce17
+       .quad   0x3ffdd08c836b797f
+       .quad   0x3ffdd321ef6c7800
+       .quad   0x3ffdd5b794bec0bc
+       .quad   0x3ffdd84d73674b3f
+       .quad   0x3ffddae38b6b0f89
+       .quad   0x3ffddd79dccf0603
+       .quad   0x3ffde01067982789
+       .quad   0x3ffde2a72bcb6d61
+       .quad   0x3ffde53e296dd143
+       .quad   0x3ffde7d560844d54
+       .quad   0x3ffdea6cd113dc26
+       .quad   0x3ffded047b2178bb
+       .quad   0x3ffdef9c5eb21e83
+       .quad   0x3ffdf2347bcac95e
+       .quad   0x3ffdf4ccd2707596
+       .quad   0x3ffdf76562a81feb
+       .quad   0x3ffdf9fe2c76c585
+       .quad   0x3ffdfc972fe163fd
+       .quad   0x3ffdff306cecf95b
+       .quad   0x3ffe01c9e39e8418
+       .quad   0x3ffe046393fb0315
+       .quad   0x3ffe06fd7e0775aa
+       .quad   0x3ffe0997a1c8db99
+       .quad   0x3ffe0c31ff443512
+       .quad   0x3ffe0ecc967e82b9
+       .quad   0x3ffe1167677cc59c
+       .quad   0x3ffe14027243ff3b
+       .quad   0x3ffe169db6d93183
+       .quad   0x3ffe193935415ed1
+       .quad   0x3ffe1bd4ed8189f2
+       .quad   0x3ffe1e70df9eb621
+       .quad   0x3ffe210d0b9de709
+       .quad   0x3ffe23a9718420c3
+       .quad   0x3ffe2646115667d9
+       .quad   0x3ffe28e2eb19c142
+       .quad   0x3ffe2b7ffed33266
+       .quad   0x3ffe2e1d4c87c11e
+       .quad   0x3ffe30bad43c73ae
+       .quad   0x3ffe335895f650cf
+       .quad   0x3ffe35f691ba5fa4
+       .quad   0x3ffe3894c78da7c2
+       .quad   0x3ffe3b333775312f
+       .quad   0x3ffe3dd1e176045e
+       .quad   0x3ffe4070c5952a35
+       .quad   0x3ffe430fe3d7ac06
+       .quad   0x3ffe45af3c429394
+       .quad   0x3ffe484ecedaeb14
+       .quad   0x3ffe4aee9ba5bd26
+       .quad   0x3ffe4d8ea2a814df
+       .quad   0x3ffe502ee3e6fdc2
+       .quad   0x3ffe52cf5f6783c0
+       .quad   0x3ffe5570152eb33c
+       .quad   0x3ffe581105419909
+       .quad   0x3ffe5ab22fa54269
+       .quad   0x3ffe5d53945ebd0f
+       .quad   0x3ffe5ff53373171e
+       .quad   0x3ffe62970ce75f28
+       .quad   0x3ffe653920c0a430
+       .quad   0x3ffe67db6f03f5ab
+       .quad   0x3ffe6a7df7b6637a
+       .quad   0x3ffe6d20badcfdf3
+       .quad   0x3ffe6fc3b87cd5d9
+       .quad   0x3ffe7266f09afc62
+       .quad   0x3ffe750a633c8332
+       .quad   0x3ffe77ae10667c5d
+       .quad   0x3ffe7a51f81dfa6b
+       .quad   0x3ffe7cf61a681052
+       .quad   0x3ffe7f9a7749d178
+       .quad   0x3ffe823f0ec851b6
+       .quad   0x3ffe84e3e0e8a554
+       .quad   0x3ffe8788edafe10a
+       .quad   0x3ffe8a2e35231a01
+       .quad   0x3ffe8cd3b74765d6
+       .quad   0x3ffe8f797421da93
+       .quad   0x3ffe921f6bb78eb2
+       .quad   0x3ffe94c59e0d9924
+       .quad   0x3ffe976c0b291144
+       .quad   0x3ffe9a12b30f0ee0
+       .quad   0x3ffe9cb995c4aa3b
+       .quad   0x3ffe9f60b34efc02
+       .quad   0x3ffea2080bb31d5a
+       .quad   0x3ffea4af9ef627d4
+       .quad   0x3ffea7576d1d3575
+       .quad   0x3ffea9ff762d60b2
+       .quad   0x3ffeaca7ba2bc471
+       .quad   0x3ffeaf50391d7c09
+       .quad   0x3ffeb1f8f307a346
+       .quad   0x3ffeb4a1e7ef5660
+       .quad   0x3ffeb74b17d9b203
+       .quad   0x3ffeb9f482cbd34b
+       .quad   0x3ffebc9e28cad7ca
+       .quad   0x3ffebf4809dbdd7c
+       .quad   0x3ffec1f2260402d5
+       .quad   0x3ffec49c7d4866b8
+       .quad   0x3ffec7470fae2879
+       .quad   0x3ffec9f1dd3a67df
+       .quad   0x3ffecc9ce5f24521
+       .quad   0x3ffecf4829dae0eb
+       .quad   0x3ffed1f3a8f95c56
+       .quad   0x3ffed49f6352d8ef
+       .quad   0x3ffed74b58ec78b7
+       .quad   0x3ffed9f789cb5e20
+       .quad   0x3ffedca3f5f4ac0a
+       .quad   0x3ffedf509d6d85cb
+       .quad   0x3ffee1fd803b0f2a
+       .quad   0x3ffee4aa9e626c5f
+       .quad   0x3ffee757f7e8c217
+       .quad   0x3ffeea058cd3356e
+       .quad   0x3ffeecb35d26ebf2
+       .quad   0x3ffeef6168e90ba5
+       .quad   0x3ffef20fb01ebafb
+       .quad   0x3ffef4be32cd20da
+       .quad   0x3ffef76cf0f9649a
+       .quad   0x3ffefa1beaa8ae04
+       .quad   0x3ffefccb1fe02556
+       .quad   0x3ffeff7a90a4f33f
+       .quad   0x3fff022a3cfc40e1
+       .quad   0x3fff04da24eb37d0
+       .quad   0x3fff078a48770213
+       .quad   0x3fff0a3aa7a4ca23
+       .quad   0x3fff0ceb4279baea
+       .quad   0x3fff0f9c18faffca
+       .quad   0x3fff124d2b2dc491
+       .quad   0x3fff14fe79173584
+       .quad   0x3fff17b002bc7f5a
+       .quad   0x3fff1a61c822cf3c
+       .quad   0x3fff1d13c94f52c7
+       .quad   0x3fff1fc606473809
+       .quad   0x3fff22787f0fad85
+       .quad   0x3fff252b33ade22f
+       .quad   0x3fff27de24270571
+       .quad   0x3fff2a9150804723
+       .quad   0x3fff2d44b8bed796
+       .quad   0x3fff2ff85ce7e78a
+       .quad   0x3fff32ac3d00a832
+       .quad   0x3fff3560590e4b38
+       .quad   0x3fff3814b11602b5
+       .quad   0x3fff3ac9451d0138
+       .quad   0x3fff3d7e152879c2
+       .quad   0x3fff4033213d9fc8
+       .quad   0x3fff42e86961a731
+       .quad   0x3fff459ded99c45a
+       .quad   0x3fff4853adeb2c11
+       .quad   0x3fff4b09aa5b1398
+       .quad   0x3fff4dbfe2eeb0a6
+       .quad   0x3fff507657ab3963
+       .quad   0x3fff532d0895e46e
+       .quad   0x3fff55e3f5b3e8d8
+       .quad   0x3fff589b1f0a7e23
+       .quad   0x3fff5b52849edc4a
+       .quad   0x3fff5e0a26763bb8
+       .quad   0x3fff60c20495d54d
+       .quad   0x3fff637a1f02e25c
+       .quad   0x3fff663275c29cab
+       .quad   0x3fff68eb08da3e7a
+       .quad   0x3fff6ba3d84f0275
+       .quad   0x3fff6e5ce42623c1
+       .quad   0x3fff71162c64ddf3
+       .quad   0x3fff73cfb1106d1b
+       .quad   0x3fff7689722e0db5
+       .quad   0x3fff79436fc2fcb6
+       .quad   0x3fff7bfda9d47787
+       .quad   0x3fff7eb82067bc04
+       .quad   0x3fff8172d382087c
+       .quad   0x3fff842dc3289bb5
+       .quad   0x3fff86e8ef60b4ea
+       .quad   0x3fff89a4582f93c7
+       .quad   0x3fff8c5ffd9a786e
+       .quad   0x3fff8f1bdfa6a377
+       .quad   0x3fff91d7fe5955eb
+       .quad   0x3fff949459b7d14b
+       .quad   0x3fff9750f1c7578c
+       .quad   0x3fff9a0dc68d2b16
+       .quad   0x3fff9ccad80e8ec8
+       .quad   0x3fff9f882650c5f2
+       .quad   0x3fffa245b159145c
+       .quad   0x3fffa503792cbe42
+       .quad   0x3fffa7c17dd10856
+       .quad   0x3fffaa7fbf4b37bd
+       .quad   0x3fffad3e3da09211
+       .quad   0x3fffaffcf8d65d61
+       .quad   0x3fffb2bbf0f1e031
+       .quad   0x3fffb57b25f8617d
+       .quad   0x3fffb83a97ef28b2
+       .quad   0x3fffbafa46db7db4
+       .quad   0x3fffbdba32c2a8db
+       .quad   0x3fffc07a5ba9f2f6
+       .quad   0x3fffc33ac196a548
+       .quad   0x3fffc5fb648e098a
+       .quad   0x3fffc8bc449569e9
+       .quad   0x3fffcb7d61b21108
+       .quad   0x3fffce3ebbe94a01
+       .quad   0x3fffd10053406061
+       .quad   0x3fffd3c227bca02c
+       .quad   0x3fffd684396355da
+       .quad   0x3fffd9468839ce5a
+       .quad   0x3fffdc0914455712
+       .quad   0x3fffdecbdd8b3dd8
+       .quad   0x3fffe18ee410d0ff
+       .quad   0x3fffe45227db5f4b
+       .quad   0x3fffe715a8f037f6
+       .quad   0x3fffe9d96754aab1
+       .quad   0x3fffec9d630e07a4
+       .quad   0x3fffef619c219f69
+       .quad   0x3ffff2261294c314
+       .quad   0x3ffff4eac66cc42c
+       .quad   0x3ffff7afb7aef4b0
+       .quad   0x3ffffa74e660a715
+       .quad   0x3ffffd3a52872e44
+       .quad   0x3ffffffffc27dd9e
+       .rept   56
+       .byte   0
+       .endr
+
+/* Other general purpose constants:
+ * _dbInvLn2 */
+double_vector __dbInvLn2 0x40a71547652b82fe
+
+/* _dbShifter */
+double_vector __dbShifter 0x4338000000000000
+
+/* _dbHALF */
+double_vector __dbHALF 0x3fe0000000000000
+
+/* _dbC1 = 2^(1/2^K)-1 */
+double_vector __dbC1 0x3f362f3904051fa1
+
+/* _lbLOWKBITS = 2^K-1 */
+double_vector __lbLOWKBITS 0x00000000000007ff
+
+/* _iAbsMask */
+float_vector __iAbsMask 0x7fffffff
+
+/* _iDomainRange */
+float_vector __iDomainRange 0x4059fe36
+       .type   __svml_spow_data,@object
+       .size __svml_spow_data,.-__svml_spow_data
diff --git a/sysdeps/x86_64/fpu/svml_s_powf_data.h b/sysdeps/x86_64/fpu/svml_s_powf_data.h
new file mode 100644 (file)
index 0000000..d847368
--- /dev/null
@@ -0,0 +1,76 @@
+/* Offsets for data table for function powf.
+   Copyright (C) 2014-2015 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#ifndef S_POWF_DATA_H
+#define S_POWF_DATA_H
+
+#define _Log2Rcp_lookup                -4218496
+#define _NMINNORM                      0
+#define _NMAXVAL                       64
+#define _INF                           128
+#define _ABSMASK                       192
+#define _DOMAINRANGE                   256
+#define _Log_HA_table                  320
+#define _Log_LA_table                  8576
+#define _poly_coeff_1                  12736
+#define _poly_coeff_2                  12800
+#define _poly_coeff_3                  12864
+#define _poly_coeff_4                  12928
+#define _ExpMask                       12992
+#define _Two10                         13056
+#define _MinNorm                       13120
+#define _MaxNorm                       13184
+#define _HalfMask                      13248
+#define _One                           13312
+#define _L2H                           13376
+#define _L2L                           13440
+#define _Threshold                     13504
+#define _Bias                          13568
+#define _Bias1                         13632
+#define _L2                            13696
+#define _dInfs                         13760
+#define _dOnes                         13824
+#define _dZeros                        13888
+#define __dbT                          13952
+#define __dbInvLn2                     30400
+#define __dbShifter                    30464
+#define __dbHALF                       30528
+#define __dbC1                         30592
+#define __lbLOWKBITS                   30656
+#define __iAbsMask                     30720
+#define __iDomainRange                 30784
+
+.macro double_vector offset value
+.if .-__svml_spow_data != \offset
+.err
+.endif
+.rept 8
+.quad \value
+.endr
+.endm
+
+.macro float_vector offset value
+.if .-__svml_spow_data != \offset
+.err
+.endif
+.rept 16
+.long \value
+.endr
+.endm
+
+#endif
index d5b62eea426877897d974853e002f7557d4c3692..f88e30f054e91067575b707fafb77f20a1e414e2 100644 (file)
         ret
 .endm
 
+/* 2 argument SSE2 ISA version as wrapper to scalar.  */
+.macro WRAPPER_IMPL_SSE2_ff callee
+        subq      $56, %rsp
+        cfi_adjust_cfa_offset(56)
+        movaps    %xmm0, (%rsp)
+        movaps    %xmm1, 16(%rsp)
+        call      \callee@PLT
+        movss     %xmm0, 32(%rsp)
+        movss     4(%rsp), %xmm0
+        movss     20(%rsp), %xmm1
+        call      \callee@PLT
+        movss     %xmm0, 36(%rsp)
+        movss     8(%rsp), %xmm0
+        movss     24(%rsp), %xmm1
+        call      \callee@PLT
+        movss     %xmm0, 40(%rsp)
+        movss     12(%rsp), %xmm0
+        movss     28(%rsp), %xmm1
+        call      \callee@PLT
+        movss     32(%rsp), %xmm3
+        movss     36(%rsp), %xmm2
+        movss     40(%rsp), %xmm1
+        movss     %xmm0, 44(%rsp)
+        unpcklps  %xmm1, %xmm3
+        unpcklps  %xmm0, %xmm2
+        unpcklps  %xmm2, %xmm3
+        movaps    %xmm3, %xmm0
+        addq      $56, %rsp
+        cfi_adjust_cfa_offset(-56)
+        ret
+.endm
+
 /* AVX/AVX2 ISA version as wrapper to SSE ISA version.  */
 .macro WRAPPER_IMPL_AVX callee
         pushq          %rbp
         ret
 .endm
 
+/* 2 argument AVX/AVX2 ISA version as wrapper to SSE ISA version.  */
+.macro WRAPPER_IMPL_AVX_ff callee
+        pushq     %rbp
+        cfi_adjust_cfa_offset (8)
+        cfi_rel_offset (%rbp, 0)
+        movq      %rsp, %rbp
+        cfi_def_cfa_register (%rbp)
+        andq      $-32, %rsp
+        subq      $64, %rsp
+        vextractf128 $1, %ymm0, 16(%rsp)
+        vextractf128 $1, %ymm1, (%rsp)
+        vzeroupper
+        call      HIDDEN_JUMPTARGET(\callee)
+        vmovaps   %xmm0, 32(%rsp)
+        vmovaps   16(%rsp), %xmm0
+        vmovaps   (%rsp), %xmm1
+        call      HIDDEN_JUMPTARGET(\callee)
+        vmovaps   %xmm0, %xmm1
+        vmovaps   32(%rsp), %xmm0
+        vinsertf128 $1, %xmm1, %ymm0, %ymm0
+        movq      %rbp, %rsp
+        cfi_def_cfa_register (%rsp)
+        popq      %rbp
+        cfi_adjust_cfa_offset (-8)
+        cfi_restore (%rbp)
+        ret
+.endm
+
 /* AVX512 ISA version as wrapper to AVX2 ISA version.  */
 .macro WRAPPER_IMPL_AVX512 callee
         pushq  %rbp
         cfi_restore (%rbp)
         ret
 .endm
+
+/* 2 argument AVX512 ISA version as wrapper to AVX2 ISA version.  */
+.macro WRAPPER_IMPL_AVX512_ff callee
+        pushq     %rbp
+        cfi_adjust_cfa_offset (8)
+        cfi_rel_offset (%rbp, 0)
+        movq      %rsp, %rbp
+        cfi_def_cfa_register (%rbp)
+        andq      $-64, %rsp
+        subq      $128, %rsp
+/* Below is encoding for vmovaps %zmm0, (%rsp).  */
+        .byte  0x62
+        .byte  0xf1
+        .byte  0x7c
+        .byte  0x48
+        .byte  0x29
+        .byte  0x04
+        .byte  0x24
+/* Below is encoding for vmovaps %zmm1, 64(%rsp).  */
+        .byte  0x62
+        .byte  0xf1
+        .byte  0x7c
+        .byte  0x48
+        .byte  0x29
+        .byte  0x4c
+        .byte  0x24
+/* Below is encoding for vmovaps (%rsp), %ymm0.  */
+        .byte  0xc5
+        .byte  0xfc
+        .byte  0x28
+        .byte  0x04
+        .byte  0x24
+/* Below is encoding for vmovaps 64(%rsp), %ymm1.  */
+        .byte  0xc5
+        .byte  0xfc
+        .byte  0x28
+        .byte  0x4c
+        .byte  0x24
+        .byte  0x40
+        call      HIDDEN_JUMPTARGET(\callee)
+/* Below is encoding for vmovaps 32(%rsp), %ymm0.  */
+        .byte  0xc5
+        .byte  0xfc
+        .byte  0x28
+        .byte  0x44
+        .byte  0x24
+        .byte  0x20
+/* Below is encoding for vmovaps 96(%rsp), %ymm1.  */
+        .byte  0xc5
+        .byte  0xfc
+        .byte  0x28
+        .byte  0x4c
+        .byte  0x24
+        .byte  0x60
+        call      HIDDEN_JUMPTARGET(\callee)
+        movq      %rbp, %rsp
+        cfi_def_cfa_register (%rsp)
+        popq      %rbp
+        cfi_adjust_cfa_offset (-8)
+        cfi_restore (%rbp)
+        ret
+.endm
index 19c249a4f06947e497c87f5121ec2308c7aedea0..00a1074f2cfc205ba9226336a1d263368c615b37 100644 (file)
@@ -26,3 +26,4 @@ VECTOR_WRAPPER (WRAPPER_NAME (cosf), _ZGVeN16v_cosf)
 VECTOR_WRAPPER (WRAPPER_NAME (sinf), _ZGVeN16v_sinf)
 VECTOR_WRAPPER (WRAPPER_NAME (logf), _ZGVeN16v_logf)
 VECTOR_WRAPPER (WRAPPER_NAME (expf), _ZGVeN16v_expf)
+VECTOR_WRAPPER_ff (WRAPPER_NAME (powf), _ZGVeN16vv_powf)
index 09514c4f40edaedb2de7c2cd89a4ed99812604ca..86b8c33632237f54f40cdfc477ed4ae15072ef2e 100644 (file)
@@ -22,6 +22,7 @@
 #define TEST_VECTOR_sinf 1
 #define TEST_VECTOR_logf 1
 #define TEST_VECTOR_expf 1
+#define TEST_VECTOR_powf 1
 
 #define REQUIRE_AVX512F
 
index 55bd026f3ba36e7513c9c97e405866bfde5bea68..7d41e46c4ab6dc8236654cffc1b1f7b216a625d8 100644 (file)
@@ -26,3 +26,4 @@ VECTOR_WRAPPER (WRAPPER_NAME (cosf), _ZGVbN4v_cosf)
 VECTOR_WRAPPER (WRAPPER_NAME (sinf), _ZGVbN4v_sinf)
 VECTOR_WRAPPER (WRAPPER_NAME (logf), _ZGVbN4v_logf)
 VECTOR_WRAPPER (WRAPPER_NAME (expf), _ZGVbN4v_expf)
+VECTOR_WRAPPER_ff (WRAPPER_NAME (powf), _ZGVbN4vv_powf)
index df3159350711b4ad2f53d30930bf5ff10662a0aa..3e74118be08e18809ac52ef0953386656263ed6c 100644 (file)
@@ -22,5 +22,6 @@
 #define TEST_VECTOR_sinf 1
 #define TEST_VECTOR_logf 1
 #define TEST_VECTOR_expf 1
+#define TEST_VECTOR_powf 1
 
 #include "libm-test.c"
index 637949b61c14c107654573d296d1080b86562c2c..ed1c893157537a1d24c8d92d4d3e80572c208f36 100644 (file)
@@ -29,3 +29,4 @@ VECTOR_WRAPPER (WRAPPER_NAME (cosf), _ZGVdN8v_cosf)
 VECTOR_WRAPPER (WRAPPER_NAME (sinf), _ZGVdN8v_sinf)
 VECTOR_WRAPPER (WRAPPER_NAME (logf), _ZGVdN8v_logf)
 VECTOR_WRAPPER (WRAPPER_NAME (expf), _ZGVdN8v_expf)
+VECTOR_WRAPPER_ff (WRAPPER_NAME (powf), _ZGVdN8vv_powf)
index e550f4d0c85606384d2fc300b2fcedd6192c081d..f0aaec17a5265cb0543528dfc4cec47436984840 100644 (file)
@@ -25,6 +25,7 @@
 #define TEST_VECTOR_sinf 1
 #define TEST_VECTOR_logf 1
 #define TEST_VECTOR_expf 1
+#define TEST_VECTOR_powf 1
 
 #define REQUIRE_AVX2
 
index 3b0a63d594f98dc5ec4d8cb2617af108382ae905..37bf7020f9f6392f09de290ad23fa3fbe9471eeb 100644 (file)
@@ -26,3 +26,4 @@ VECTOR_WRAPPER (WRAPPER_NAME (cosf), _ZGVcN8v_cosf)
 VECTOR_WRAPPER (WRAPPER_NAME (sinf), _ZGVcN8v_sinf)
 VECTOR_WRAPPER (WRAPPER_NAME (logf), _ZGVcN8v_logf)
 VECTOR_WRAPPER (WRAPPER_NAME (expf), _ZGVcN8v_expf)
+VECTOR_WRAPPER_ff (WRAPPER_NAME (powf), _ZGVcN8vv_powf)
index db5b2e592bf28c777affb17d8d8216789784dc32..ef2aedc845881a8f2267b578bdd8703d60a108aa 100644 (file)
@@ -22,5 +22,6 @@
 #define TEST_VECTOR_sinf 1
 #define TEST_VECTOR_logf 1
 #define TEST_VECTOR_expf 1
+#define TEST_VECTOR_powf 1
 
 #include "libm-test.c"
This page took 0.261132 seconds and 5 git commands to generate.