
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)) (t_1 (+ t_0 7.0)) (t_2 (+ t_1 0.5)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(* (* (sqrt (* (PI) 2.0)) (pow t_2 (+ t_0 0.5))) (exp (- t_2)))
(+
(+
(+
(+
(+
(+
(+
(+ 0.9999999999998099 (/ 676.5203681218851 (+ t_0 1.0)))
(/ -1259.1392167224028 (+ t_0 2.0)))
(/ 771.3234287776531 (+ t_0 3.0)))
(/ -176.6150291621406 (+ t_0 4.0)))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 t_1))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
t_1 := t\_0 + 7\\
t_2 := t\_1 + 0.5\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(\left(\left(\sqrt{\mathsf{PI}\left(\right) \cdot 2} \cdot {t\_2}^{\left(t\_0 + 0.5\right)}\right) \cdot e^{-t\_2}\right) \cdot \left(\left(\left(\left(\left(\left(\left(\left(0.9999999999998099 + \frac{676.5203681218851}{t\_0 + 1}\right) + \frac{-1259.1392167224028}{t\_0 + 2}\right) + \frac{771.3234287776531}{t\_0 + 3}\right) + \frac{-176.6150291621406}{t\_0 + 4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{t\_1}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 11 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)) (t_1 (+ t_0 7.0)) (t_2 (+ t_1 0.5)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(* (* (sqrt (* (PI) 2.0)) (pow t_2 (+ t_0 0.5))) (exp (- t_2)))
(+
(+
(+
(+
(+
(+
(+
(+ 0.9999999999998099 (/ 676.5203681218851 (+ t_0 1.0)))
(/ -1259.1392167224028 (+ t_0 2.0)))
(/ 771.3234287776531 (+ t_0 3.0)))
(/ -176.6150291621406 (+ t_0 4.0)))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 t_1))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
t_1 := t\_0 + 7\\
t_2 := t\_1 + 0.5\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(\left(\left(\sqrt{\mathsf{PI}\left(\right) \cdot 2} \cdot {t\_2}^{\left(t\_0 + 0.5\right)}\right) \cdot e^{-t\_2}\right) \cdot \left(\left(\left(\left(\left(\left(\left(\left(0.9999999999998099 + \frac{676.5203681218851}{t\_0 + 1}\right) + \frac{-1259.1392167224028}{t\_0 + 2}\right) + \frac{771.3234287776531}{t\_0 + 3}\right) + \frac{-176.6150291621406}{t\_0 + 4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{t\_1}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0))
(t_1 (/ (PI) (sin (* (PI) z))))
(t_2 (/ 12.507343278686905 (+ t_0 5.0)))
(t_3 (/ -0.13857109526572012 (+ t_0 6.0)))
(t_4 (/ 771.3234287776531 (+ t_0 3.0)))
(t_5 (/ 1.5056327351493116e-7 (+ t_0 8.0)))
(t_6 (+ t_0 7.0))
(t_7 (* (sqrt (* (PI) 2.0)) (pow (+ t_6 0.5) (+ t_0 0.5))))
(t_8 (/ -176.6150291621406 (+ t_0 4.0)))
(t_9
(+
(+
(+
(+
(+
(+
(+
(+ 0.9999999999998099 (/ 676.5203681218851 (+ t_0 1.0)))
(/ -1259.1392167224028 (+ t_0 2.0)))
t_4)
t_8)
t_2)
t_3)
(/ 9.984369578019572e-6 t_6))
t_5)))
(if (<=
(* t_1 (* (* t_7 (exp (- (- (- (+ -1.0 z) -1.0) 7.0) 0.5))) t_9))
2e+145)
(*
t_1
(*
(*
(* (* (exp (+ -7.5 z)) (sqrt (PI))) (sqrt 2.0))
(pow (- 7.5 z) (- 0.5 z)))
t_9))
(*
t_1
(*
(* t_7 (exp (- (+ 7.0 0.5))))
(+
(+
(+
(+
(+
(+
(fma
(fma 519.1279660315847 z 361.7355639412844)
z
47.95075976068351)
t_4)
t_8)
t_2)
t_3)
(/ 9.984369578019572e-6 7.0))
t_5))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
t_1 := \frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)}\\
t_2 := \frac{12.507343278686905}{t\_0 + 5}\\
t_3 := \frac{-0.13857109526572012}{t\_0 + 6}\\
t_4 := \frac{771.3234287776531}{t\_0 + 3}\\
t_5 := \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\\
t_6 := t\_0 + 7\\
t_7 := \sqrt{\mathsf{PI}\left(\right) \cdot 2} \cdot {\left(t\_6 + 0.5\right)}^{\left(t\_0 + 0.5\right)}\\
t_8 := \frac{-176.6150291621406}{t\_0 + 4}\\
t_9 := \left(\left(\left(\left(\left(\left(\left(0.9999999999998099 + \frac{676.5203681218851}{t\_0 + 1}\right) + \frac{-1259.1392167224028}{t\_0 + 2}\right) + t\_4\right) + t\_8\right) + t\_2\right) + t\_3\right) + \frac{9.984369578019572 \cdot 10^{-6}}{t\_6}\right) + t\_5\\
\mathbf{if}\;t\_1 \cdot \left(\left(t\_7 \cdot e^{\left(\left(\left(-1 + z\right) - -1\right) - 7\right) - 0.5}\right) \cdot t\_9\right) \leq 2 \cdot 10^{+145}:\\
\;\;\;\;t\_1 \cdot \left(\left(\left(\left(e^{-7.5 + z} \cdot \sqrt{\mathsf{PI}\left(\right)}\right) \cdot \sqrt{2}\right) \cdot {\left(7.5 - z\right)}^{\left(0.5 - z\right)}\right) \cdot t\_9\right)\\
\mathbf{else}:\\
\;\;\;\;t\_1 \cdot \left(\left(t\_7 \cdot e^{-\left(7 + 0.5\right)}\right) \cdot \left(\left(\left(\left(\left(\left(\mathsf{fma}\left(\mathsf{fma}\left(519.1279660315847, z, 361.7355639412844\right), z, 47.95075976068351\right) + t\_4\right) + t\_8\right) + t\_2\right) + t\_3\right) + \frac{9.984369578019572 \cdot 10^{-6}}{7}\right) + t\_5\right)\right)\\
\end{array}
\end{array}
if (*.f64 (/.f64 (PI.f64) (sin.f64 (*.f64 (PI.f64) z))) (*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 (PI.f64) #s(literal 2 binary64))) (pow.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64)) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1/2 binary64)))) (exp.f64 (neg.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64))))) (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 #s(literal 9999999999998099/10000000000000000 binary64) (/.f64 #s(literal 6765203681218851/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1 binary64)))) (/.f64 #s(literal -3147848041806007/2500000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 2 binary64)))) (/.f64 #s(literal 7713234287776531/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 3 binary64)))) (/.f64 #s(literal -883075145810703/5000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 4 binary64)))) (/.f64 #s(literal 2501468655737381/200000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 5 binary64)))) (/.f64 #s(literal -3464277381643003/25000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 6 binary64)))) (/.f64 #s(literal 2496092394504893/250000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)))) (/.f64 #s(literal 3764081837873279/25000000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 8 binary64)))))) < 2e145Initial program 97.4%
Taylor expanded in z around -inf
associate-*r*N/A
*-commutativeN/A
associate-*r*N/A
*-commutativeN/A
*-commutativeN/A
distribute-rgt-inN/A
mul-1-negN/A
fp-cancel-sub-signN/A
distribute-rgt-out--N/A
Applied rewrites98.5%
if 2e145 < (*.f64 (/.f64 (PI.f64) (sin.f64 (*.f64 (PI.f64) z))) (*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 (PI.f64) #s(literal 2 binary64))) (pow.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64)) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1/2 binary64)))) (exp.f64 (neg.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64))))) (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 #s(literal 9999999999998099/10000000000000000 binary64) (/.f64 #s(literal 6765203681218851/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1 binary64)))) (/.f64 #s(literal -3147848041806007/2500000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 2 binary64)))) (/.f64 #s(literal 7713234287776531/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 3 binary64)))) (/.f64 #s(literal -883075145810703/5000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 4 binary64)))) (/.f64 #s(literal 2501468655737381/200000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 5 binary64)))) (/.f64 #s(literal -3464277381643003/25000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 6 binary64)))) (/.f64 #s(literal 2496092394504893/250000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)))) (/.f64 #s(literal 3764081837873279/25000000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 8 binary64)))))) Initial program 91.5%
Taylor expanded in z around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
+-commutativeN/A
lower-fma.f6492.5
Applied rewrites92.5%
Taylor expanded in z around 0
Applied rewrites92.5%
Taylor expanded in z around 0
Applied rewrites98.6%
Final simplification98.5%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0))
(t_1 (/ (PI) (sin (* (PI) z))))
(t_2 (/ 12.507343278686905 (+ t_0 5.0)))
(t_3 (exp (- (- (- (+ -1.0 z) -1.0) 7.0) 0.5)))
(t_4 (/ -0.13857109526572012 (+ t_0 6.0)))
(t_5 (+ t_0 7.0))
(t_6 (/ -176.6150291621406 (+ t_0 4.0)))
(t_7
(fma (fma 519.1279660315847 z 361.7355639412844) z 47.95075976068351))
(t_8 (/ 771.3234287776531 (+ t_0 3.0)))
(t_9 (/ 9.984369578019572e-6 t_5))
(t_10 (pow (+ t_5 0.5) (+ t_0 0.5)))
(t_11 (* (sqrt (* (PI) 2.0)) t_10))
(t_12 (/ 1.5056327351493116e-7 (+ t_0 8.0))))
(if (<=
(*
t_1
(*
(* t_11 t_3)
(+
(+
(+
(+
(+
(+
(+
(+ 0.9999999999998099 (/ 676.5203681218851 (+ t_0 1.0)))
(/ -1259.1392167224028 (+ t_0 2.0)))
t_8)
t_6)
t_2)
t_4)
t_9)
t_12)))
1e+306)
(*
t_1
(*
(* (* (* (sqrt (PI)) (sqrt 2.0)) t_10) t_3)
(+ (+ (+ (+ (+ (+ t_7 t_8) t_6) t_2) t_4) t_9) t_12)))
(*
t_1
(*
(* t_11 (exp (- (+ 7.0 0.5))))
(+
(+
(+ (+ (+ (+ t_7 (/ 771.3234287776531 3.0)) t_6) t_2) t_4)
(/ 9.984369578019572e-6 7.0))
t_12))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
t_1 := \frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)}\\
t_2 := \frac{12.507343278686905}{t\_0 + 5}\\
t_3 := e^{\left(\left(\left(-1 + z\right) - -1\right) - 7\right) - 0.5}\\
t_4 := \frac{-0.13857109526572012}{t\_0 + 6}\\
t_5 := t\_0 + 7\\
t_6 := \frac{-176.6150291621406}{t\_0 + 4}\\
t_7 := \mathsf{fma}\left(\mathsf{fma}\left(519.1279660315847, z, 361.7355639412844\right), z, 47.95075976068351\right)\\
t_8 := \frac{771.3234287776531}{t\_0 + 3}\\
t_9 := \frac{9.984369578019572 \cdot 10^{-6}}{t\_5}\\
t_10 := {\left(t\_5 + 0.5\right)}^{\left(t\_0 + 0.5\right)}\\
t_11 := \sqrt{\mathsf{PI}\left(\right) \cdot 2} \cdot t\_10\\
t_12 := \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\\
\mathbf{if}\;t\_1 \cdot \left(\left(t\_11 \cdot t\_3\right) \cdot \left(\left(\left(\left(\left(\left(\left(\left(0.9999999999998099 + \frac{676.5203681218851}{t\_0 + 1}\right) + \frac{-1259.1392167224028}{t\_0 + 2}\right) + t\_8\right) + t\_6\right) + t\_2\right) + t\_4\right) + t\_9\right) + t\_12\right)\right) \leq 10^{+306}:\\
\;\;\;\;t\_1 \cdot \left(\left(\left(\left(\sqrt{\mathsf{PI}\left(\right)} \cdot \sqrt{2}\right) \cdot t\_10\right) \cdot t\_3\right) \cdot \left(\left(\left(\left(\left(\left(t\_7 + t\_8\right) + t\_6\right) + t\_2\right) + t\_4\right) + t\_9\right) + t\_12\right)\right)\\
\mathbf{else}:\\
\;\;\;\;t\_1 \cdot \left(\left(t\_11 \cdot e^{-\left(7 + 0.5\right)}\right) \cdot \left(\left(\left(\left(\left(\left(t\_7 + \frac{771.3234287776531}{3}\right) + t\_6\right) + t\_2\right) + t\_4\right) + \frac{9.984369578019572 \cdot 10^{-6}}{7}\right) + t\_12\right)\right)\\
\end{array}
\end{array}
if (*.f64 (/.f64 (PI.f64) (sin.f64 (*.f64 (PI.f64) z))) (*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 (PI.f64) #s(literal 2 binary64))) (pow.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64)) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1/2 binary64)))) (exp.f64 (neg.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64))))) (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 #s(literal 9999999999998099/10000000000000000 binary64) (/.f64 #s(literal 6765203681218851/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1 binary64)))) (/.f64 #s(literal -3147848041806007/2500000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 2 binary64)))) (/.f64 #s(literal 7713234287776531/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 3 binary64)))) (/.f64 #s(literal -883075145810703/5000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 4 binary64)))) (/.f64 #s(literal 2501468655737381/200000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 5 binary64)))) (/.f64 #s(literal -3464277381643003/25000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 6 binary64)))) (/.f64 #s(literal 2496092394504893/250000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)))) (/.f64 #s(literal 3764081837873279/25000000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 8 binary64)))))) < 1.00000000000000002e306Initial program 97.4%
Taylor expanded in z around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
+-commutativeN/A
lower-fma.f6497.7
Applied rewrites97.7%
lift-sqrt.f64N/A
lift-*.f64N/A
sqrt-prodN/A
lift-sqrt.f64N/A
lift-sqrt.f64N/A
lower-*.f6498.4
Applied rewrites98.4%
if 1.00000000000000002e306 < (*.f64 (/.f64 (PI.f64) (sin.f64 (*.f64 (PI.f64) z))) (*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 (PI.f64) #s(literal 2 binary64))) (pow.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64)) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1/2 binary64)))) (exp.f64 (neg.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64))))) (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 #s(literal 9999999999998099/10000000000000000 binary64) (/.f64 #s(literal 6765203681218851/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1 binary64)))) (/.f64 #s(literal -3147848041806007/2500000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 2 binary64)))) (/.f64 #s(literal 7713234287776531/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 3 binary64)))) (/.f64 #s(literal -883075145810703/5000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 4 binary64)))) (/.f64 #s(literal 2501468655737381/200000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 5 binary64)))) (/.f64 #s(literal -3464277381643003/25000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 6 binary64)))) (/.f64 #s(literal 2496092394504893/250000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)))) (/.f64 #s(literal 3764081837873279/25000000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 8 binary64)))))) Initial program 0.0%
Taylor expanded in z around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
+-commutativeN/A
lower-fma.f640.0
Applied rewrites0.0%
Taylor expanded in z around 0
Applied rewrites0.0%
Taylor expanded in z around 0
Applied rewrites0.0%
Taylor expanded in z around 0
Applied rewrites100.0%
Final simplification98.4%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0))
(t_1 (/ (PI) (sin (* (PI) z))))
(t_2 (/ 12.507343278686905 (+ t_0 5.0)))
(t_3 (exp (- (- (- (+ -1.0 z) -1.0) 7.0) 0.5)))
(t_4 (/ -0.13857109526572012 (+ t_0 6.0)))
(t_5 (/ 771.3234287776531 (+ t_0 3.0)))
(t_6 (+ t_0 7.0))
(t_7 (/ -176.6150291621406 (+ t_0 4.0)))
(t_8
(fma (fma 519.1279660315847 z 361.7355639412844) z 47.95075976068351))
(t_9 (pow (+ t_6 0.5) (+ t_0 0.5)))
(t_10 (* (sqrt (* (PI) 2.0)) t_9))
(t_11 (/ 1.5056327351493116e-7 (+ t_0 8.0))))
(if (<=
(*
t_1
(*
(* t_10 t_3)
(+
(+
(+
(+
(+
(+
(+
(+ 0.9999999999998099 (/ 676.5203681218851 (+ t_0 1.0)))
(/ -1259.1392167224028 (+ t_0 2.0)))
t_5)
t_7)
t_2)
t_4)
(/ 9.984369578019572e-6 t_6))
t_11)))
1e+306)
(*
t_1
(*
(* (* (* (sqrt (PI)) (sqrt 2.0)) t_9) t_3)
(+
(+ (+ (+ (+ (+ t_8 t_5) t_7) t_2) t_4) (/ 9.984369578019572e-6 7.0))
t_11)))
(*
t_1
(*
(* t_10 (exp (- (+ 7.0 0.5))))
(+
(+
(+ (+ (+ (+ t_8 (/ 771.3234287776531 3.0)) t_7) t_2) t_4)
(/ 9.984369578019572e-6 7.0))
t_11))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
t_1 := \frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)}\\
t_2 := \frac{12.507343278686905}{t\_0 + 5}\\
t_3 := e^{\left(\left(\left(-1 + z\right) - -1\right) - 7\right) - 0.5}\\
t_4 := \frac{-0.13857109526572012}{t\_0 + 6}\\
t_5 := \frac{771.3234287776531}{t\_0 + 3}\\
t_6 := t\_0 + 7\\
t_7 := \frac{-176.6150291621406}{t\_0 + 4}\\
t_8 := \mathsf{fma}\left(\mathsf{fma}\left(519.1279660315847, z, 361.7355639412844\right), z, 47.95075976068351\right)\\
t_9 := {\left(t\_6 + 0.5\right)}^{\left(t\_0 + 0.5\right)}\\
t_10 := \sqrt{\mathsf{PI}\left(\right) \cdot 2} \cdot t\_9\\
t_11 := \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\\
\mathbf{if}\;t\_1 \cdot \left(\left(t\_10 \cdot t\_3\right) \cdot \left(\left(\left(\left(\left(\left(\left(\left(0.9999999999998099 + \frac{676.5203681218851}{t\_0 + 1}\right) + \frac{-1259.1392167224028}{t\_0 + 2}\right) + t\_5\right) + t\_7\right) + t\_2\right) + t\_4\right) + \frac{9.984369578019572 \cdot 10^{-6}}{t\_6}\right) + t\_11\right)\right) \leq 10^{+306}:\\
\;\;\;\;t\_1 \cdot \left(\left(\left(\left(\sqrt{\mathsf{PI}\left(\right)} \cdot \sqrt{2}\right) \cdot t\_9\right) \cdot t\_3\right) \cdot \left(\left(\left(\left(\left(\left(t\_8 + t\_5\right) + t\_7\right) + t\_2\right) + t\_4\right) + \frac{9.984369578019572 \cdot 10^{-6}}{7}\right) + t\_11\right)\right)\\
\mathbf{else}:\\
\;\;\;\;t\_1 \cdot \left(\left(t\_10 \cdot e^{-\left(7 + 0.5\right)}\right) \cdot \left(\left(\left(\left(\left(\left(t\_8 + \frac{771.3234287776531}{3}\right) + t\_7\right) + t\_2\right) + t\_4\right) + \frac{9.984369578019572 \cdot 10^{-6}}{7}\right) + t\_11\right)\right)\\
\end{array}
\end{array}
if (*.f64 (/.f64 (PI.f64) (sin.f64 (*.f64 (PI.f64) z))) (*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 (PI.f64) #s(literal 2 binary64))) (pow.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64)) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1/2 binary64)))) (exp.f64 (neg.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64))))) (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 #s(literal 9999999999998099/10000000000000000 binary64) (/.f64 #s(literal 6765203681218851/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1 binary64)))) (/.f64 #s(literal -3147848041806007/2500000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 2 binary64)))) (/.f64 #s(literal 7713234287776531/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 3 binary64)))) (/.f64 #s(literal -883075145810703/5000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 4 binary64)))) (/.f64 #s(literal 2501468655737381/200000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 5 binary64)))) (/.f64 #s(literal -3464277381643003/25000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 6 binary64)))) (/.f64 #s(literal 2496092394504893/250000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)))) (/.f64 #s(literal 3764081837873279/25000000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 8 binary64)))))) < 1.00000000000000002e306Initial program 97.4%
Taylor expanded in z around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
+-commutativeN/A
lower-fma.f6497.7
Applied rewrites97.7%
Taylor expanded in z around 0
Applied rewrites97.7%
lift-sqrt.f64N/A
lift-*.f64N/A
sqrt-prodN/A
lift-sqrt.f64N/A
lift-sqrt.f64N/A
lower-*.f6498.4
Applied rewrites98.4%
if 1.00000000000000002e306 < (*.f64 (/.f64 (PI.f64) (sin.f64 (*.f64 (PI.f64) z))) (*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 (PI.f64) #s(literal 2 binary64))) (pow.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64)) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1/2 binary64)))) (exp.f64 (neg.f64 (+.f64 (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)) #s(literal 1/2 binary64))))) (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 (+.f64 #s(literal 9999999999998099/10000000000000000 binary64) (/.f64 #s(literal 6765203681218851/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 1 binary64)))) (/.f64 #s(literal -3147848041806007/2500000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 2 binary64)))) (/.f64 #s(literal 7713234287776531/10000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 3 binary64)))) (/.f64 #s(literal -883075145810703/5000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 4 binary64)))) (/.f64 #s(literal 2501468655737381/200000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 5 binary64)))) (/.f64 #s(literal -3464277381643003/25000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 6 binary64)))) (/.f64 #s(literal 2496092394504893/250000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 7 binary64)))) (/.f64 #s(literal 3764081837873279/25000000000000000000000 binary64) (+.f64 (-.f64 (-.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) #s(literal 8 binary64)))))) Initial program 0.0%
Taylor expanded in z around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
+-commutativeN/A
lower-fma.f640.0
Applied rewrites0.0%
Taylor expanded in z around 0
Applied rewrites0.0%
Taylor expanded in z around 0
Applied rewrites0.0%
Taylor expanded in z around 0
Applied rewrites100.0%
Final simplification98.4%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(exp
(fma
(log (* (PI) 2.0))
0.5
(fma (log (- (- 1.0 z) -6.5)) (- (- 1.0 z) 0.5) (+ (+ -1.0 z) -6.5))))
(+
(+
(+
(+
(+
(+
(+
(/ 676.5203681218851 (- 1.0 z))
(+
0.9999999999998099
(/ -1259.1392167224028 (* (- (/ 2.0 z) 1.0) z))))
(/ 771.3234287776531 (+ t_0 3.0)))
(/ -176.6150291621406 (+ t_0 4.0)))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 (- 7.0 z)))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(e^{\mathsf{fma}\left(\log \left(\mathsf{PI}\left(\right) \cdot 2\right), 0.5, \mathsf{fma}\left(\log \left(\left(1 - z\right) - -6.5\right), \left(1 - z\right) - 0.5, \left(-1 + z\right) + -6.5\right)\right)} \cdot \left(\left(\left(\left(\left(\left(\left(\frac{676.5203681218851}{1 - z} + \left(0.9999999999998099 + \frac{-1259.1392167224028}{\left(\frac{2}{z} - 1\right) \cdot z}\right)\right) + \frac{771.3234287776531}{t\_0 + 3}\right) + \frac{-176.6150291621406}{t\_0 + 4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{7 - z}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
Initial program 95.8%
lift-*.f64N/A
lift-*.f64N/A
associate-*l*N/A
lift-sqrt.f64N/A
pow1/2N/A
pow-to-expN/A
lift-pow.f64N/A
pow-to-expN/A
lift-exp.f64N/A
prod-expN/A
Applied rewrites97.8%
Taylor expanded in z around inf
*-commutativeN/A
lower-*.f64N/A
lower--.f64N/A
associate-*r/N/A
metadata-evalN/A
lower-/.f6498.0
Applied rewrites98.0%
lift-+.f64N/A
lift-+.f64N/A
+-commutativeN/A
associate-+l+N/A
lower-+.f64N/A
lift-+.f64N/A
lift--.f64N/A
associate-+l-N/A
metadata-evalN/A
--rgt-identityN/A
lower-+.f6498.0
Applied rewrites98.0%
Taylor expanded in z around 0
fp-cancel-sign-sub-invN/A
metadata-evalN/A
*-lft-identityN/A
lower--.f6498.0
Applied rewrites98.0%
Final simplification98.0%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(exp
(fma
(log (* (PI) 2.0))
0.5
(fma (log (- (- 1.0 z) -6.5)) (- (- 1.0 z) 0.5) (+ (+ -1.0 z) -6.5))))
(+
(+
(+
(+
(+
(+
(+
(/ 676.5203681218851 (- 1.0 z))
(+ 0.9999999999998099 (/ -1259.1392167224028 (- (- 1.0 z) -1.0))))
(/ 771.3234287776531 (+ t_0 3.0)))
(/ -176.6150291621406 (+ t_0 4.0)))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 (+ t_0 7.0)))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(e^{\mathsf{fma}\left(\log \left(\mathsf{PI}\left(\right) \cdot 2\right), 0.5, \mathsf{fma}\left(\log \left(\left(1 - z\right) - -6.5\right), \left(1 - z\right) - 0.5, \left(-1 + z\right) + -6.5\right)\right)} \cdot \left(\left(\left(\left(\left(\left(\left(\frac{676.5203681218851}{1 - z} + \left(0.9999999999998099 + \frac{-1259.1392167224028}{\left(1 - z\right) - -1}\right)\right) + \frac{771.3234287776531}{t\_0 + 3}\right) + \frac{-176.6150291621406}{t\_0 + 4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{t\_0 + 7}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
Initial program 95.8%
lift-*.f64N/A
lift-*.f64N/A
associate-*l*N/A
lift-sqrt.f64N/A
pow1/2N/A
pow-to-expN/A
lift-pow.f64N/A
pow-to-expN/A
lift-exp.f64N/A
prod-expN/A
Applied rewrites97.8%
lift-+.f64N/A
lift-+.f64N/A
+-commutativeN/A
associate-+l+N/A
lower-+.f64N/A
lift-+.f64N/A
lift--.f64N/A
associate-+l-N/A
metadata-evalN/A
--rgt-identityN/A
lower-+.f6497.8
lift-+.f64N/A
lift--.f64N/A
associate-+l-N/A
lower--.f64N/A
metadata-eval97.8
Applied rewrites97.8%
Final simplification97.8%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)) (t_1 (+ t_0 7.0)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(*
(* (sqrt (* (PI) 2.0)) (pow (+ t_1 0.5) (+ t_0 0.5)))
(exp (- (+ 7.0 0.5))))
(+
(+
(+
(+
(+
(+
(fma
(fma 519.1279660315847 z 361.7355639412844)
z
47.95075976068351)
(/ 771.3234287776531 (+ t_0 3.0)))
(/ -176.6150291621406 (+ t_0 4.0)))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 t_1))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
t_1 := t\_0 + 7\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(\left(\left(\sqrt{\mathsf{PI}\left(\right) \cdot 2} \cdot {\left(t\_1 + 0.5\right)}^{\left(t\_0 + 0.5\right)}\right) \cdot e^{-\left(7 + 0.5\right)}\right) \cdot \left(\left(\left(\left(\left(\left(\mathsf{fma}\left(\mathsf{fma}\left(519.1279660315847, z, 361.7355639412844\right), z, 47.95075976068351\right) + \frac{771.3234287776531}{t\_0 + 3}\right) + \frac{-176.6150291621406}{t\_0 + 4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{t\_1}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
Initial program 95.8%
Taylor expanded in z around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
+-commutativeN/A
lower-fma.f6496.2
Applied rewrites96.2%
Taylor expanded in z around 0
Applied rewrites96.3%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(*
(* (sqrt (* (PI) 2.0)) (pow (+ (+ t_0 7.0) 0.5) (+ t_0 0.5)))
(exp (- (+ 7.0 0.5))))
(+
(+
(+
(+
(+
(+
(fma
(fma 519.1279660315847 z 361.7355639412844)
z
47.95075976068351)
(/ 771.3234287776531 (+ t_0 3.0)))
(/ -176.6150291621406 (+ t_0 4.0)))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 7.0))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(\left(\left(\sqrt{\mathsf{PI}\left(\right) \cdot 2} \cdot {\left(\left(t\_0 + 7\right) + 0.5\right)}^{\left(t\_0 + 0.5\right)}\right) \cdot e^{-\left(7 + 0.5\right)}\right) \cdot \left(\left(\left(\left(\left(\left(\mathsf{fma}\left(\mathsf{fma}\left(519.1279660315847, z, 361.7355639412844\right), z, 47.95075976068351\right) + \frac{771.3234287776531}{t\_0 + 3}\right) + \frac{-176.6150291621406}{t\_0 + 4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{7}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
Initial program 95.8%
Taylor expanded in z around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
+-commutativeN/A
lower-fma.f6496.2
Applied rewrites96.2%
Taylor expanded in z around 0
Applied rewrites96.2%
Taylor expanded in z around 0
Applied rewrites96.3%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(*
(* (sqrt (* (PI) 2.0)) (pow (+ (+ t_0 7.0) 0.5) (+ t_0 0.5)))
(exp (- (+ 7.0 0.5))))
(+
(+
(+
(+
(+
(+
(fma
(fma 519.1279660315847 z 361.7355639412844)
z
47.95075976068351)
(/ 771.3234287776531 3.0))
(/ -176.6150291621406 (+ t_0 4.0)))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 7.0))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(\left(\left(\sqrt{\mathsf{PI}\left(\right) \cdot 2} \cdot {\left(\left(t\_0 + 7\right) + 0.5\right)}^{\left(t\_0 + 0.5\right)}\right) \cdot e^{-\left(7 + 0.5\right)}\right) \cdot \left(\left(\left(\left(\left(\left(\mathsf{fma}\left(\mathsf{fma}\left(519.1279660315847, z, 361.7355639412844\right), z, 47.95075976068351\right) + \frac{771.3234287776531}{3}\right) + \frac{-176.6150291621406}{t\_0 + 4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{7}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
Initial program 95.8%
Taylor expanded in z around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
+-commutativeN/A
lower-fma.f6496.2
Applied rewrites96.2%
Taylor expanded in z around 0
Applied rewrites96.2%
Taylor expanded in z around 0
Applied rewrites94.9%
Taylor expanded in z around 0
Applied rewrites96.3%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(* (pow (* (PI) (PI)) 0.25) (* (exp -7.5) (sqrt 15.0)))
(+
(+
(+
(+
(+
(+ 47.95075976068351 (/ 771.3234287776531 (+ t_0 3.0)))
(/ -176.6150291621406 (+ t_0 4.0)))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 (+ t_0 7.0)))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(\left({\left(\mathsf{PI}\left(\right) \cdot \mathsf{PI}\left(\right)\right)}^{0.25} \cdot \left(e^{-7.5} \cdot \sqrt{15}\right)\right) \cdot \left(\left(\left(\left(\left(\left(47.95075976068351 + \frac{771.3234287776531}{t\_0 + 3}\right) + \frac{-176.6150291621406}{t\_0 + 4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{t\_0 + 7}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
Initial program 95.8%
Taylor expanded in z around 0
*-commutativeN/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sqrt.f64N/A
lower-sqrt.f64N/A
lower-exp.f64N/A
lower-sqrt.f64N/A
lower-PI.f6493.7
Applied rewrites93.7%
Taylor expanded in z around 0
Applied rewrites95.0%
Applied rewrites95.0%
Applied rewrites95.7%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(* (sqrt (PI)) (* (exp -7.5) (sqrt 15.0)))
(+
(+
(+
(+
(+
(+ 47.95075976068351 (/ 771.3234287776531 (+ t_0 3.0)))
(/ -176.6150291621406 4.0))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 (+ t_0 7.0)))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(\left(\sqrt{\mathsf{PI}\left(\right)} \cdot \left(e^{-7.5} \cdot \sqrt{15}\right)\right) \cdot \left(\left(\left(\left(\left(\left(47.95075976068351 + \frac{771.3234287776531}{t\_0 + 3}\right) + \frac{-176.6150291621406}{4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{t\_0 + 7}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
Initial program 95.8%
Taylor expanded in z around 0
*-commutativeN/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sqrt.f64N/A
lower-sqrt.f64N/A
lower-exp.f64N/A
lower-sqrt.f64N/A
lower-PI.f6493.7
Applied rewrites93.7%
Taylor expanded in z around 0
Applied rewrites95.0%
Applied rewrites95.0%
Taylor expanded in z around 0
Applied rewrites95.0%
(FPCore (z)
:precision binary64
(let* ((t_0 (- (- 1.0 z) 1.0)))
(*
(/ (PI) (sin (* (PI) z)))
(*
(* (sqrt (PI)) (* (exp -7.5) (sqrt 15.0)))
(+
(+
(+
(+
(+
(+ 47.95075976068351 (/ 771.3234287776531 3.0))
(/ -176.6150291621406 (+ t_0 4.0)))
(/ 12.507343278686905 (+ t_0 5.0)))
(/ -0.13857109526572012 (+ t_0 6.0)))
(/ 9.984369578019572e-6 (+ t_0 7.0)))
(/ 1.5056327351493116e-7 (+ t_0 8.0)))))))\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(1 - z\right) - 1\\
\frac{\mathsf{PI}\left(\right)}{\sin \left(\mathsf{PI}\left(\right) \cdot z\right)} \cdot \left(\left(\sqrt{\mathsf{PI}\left(\right)} \cdot \left(e^{-7.5} \cdot \sqrt{15}\right)\right) \cdot \left(\left(\left(\left(\left(\left(47.95075976068351 + \frac{771.3234287776531}{3}\right) + \frac{-176.6150291621406}{t\_0 + 4}\right) + \frac{12.507343278686905}{t\_0 + 5}\right) + \frac{-0.13857109526572012}{t\_0 + 6}\right) + \frac{9.984369578019572 \cdot 10^{-6}}{t\_0 + 7}\right) + \frac{1.5056327351493116 \cdot 10^{-7}}{t\_0 + 8}\right)\right)
\end{array}
\end{array}
Initial program 95.8%
Taylor expanded in z around 0
*-commutativeN/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sqrt.f64N/A
lower-sqrt.f64N/A
lower-exp.f64N/A
lower-sqrt.f64N/A
lower-PI.f6493.7
Applied rewrites93.7%
Taylor expanded in z around 0
Applied rewrites95.0%
Applied rewrites95.0%
Taylor expanded in z around 0
Applied rewrites94.9%
herbie shell --seed 2024329
(FPCore (z)
:name "Jmat.Real.gamma, branch z less than 0.5"
:precision binary64
:pre (<= z 0.5)
(* (/ (PI) (sin (* (PI) z))) (* (* (* (sqrt (* (PI) 2.0)) (pow (+ (+ (- (- 1.0 z) 1.0) 7.0) 0.5) (+ (- (- 1.0 z) 1.0) 0.5))) (exp (- (+ (+ (- (- 1.0 z) 1.0) 7.0) 0.5)))) (+ (+ (+ (+ (+ (+ (+ (+ 0.9999999999998099 (/ 676.5203681218851 (+ (- (- 1.0 z) 1.0) 1.0))) (/ -1259.1392167224028 (+ (- (- 1.0 z) 1.0) 2.0))) (/ 771.3234287776531 (+ (- (- 1.0 z) 1.0) 3.0))) (/ -176.6150291621406 (+ (- (- 1.0 z) 1.0) 4.0))) (/ 12.507343278686905 (+ (- (- 1.0 z) 1.0) 5.0))) (/ -0.13857109526572012 (+ (- (- 1.0 z) 1.0) 6.0))) (/ 9.984369578019572e-6 (+ (- (- 1.0 z) 1.0) 7.0))) (/ 1.5056327351493116e-7 (+ (- (- 1.0 z) 1.0) 8.0))))))