Average Error: 0.0 → 0.0
Time: 9.6s
Precision: binary64
Cost: 704
\[\left(\left(d1 \cdot d2 - d1 \cdot d3\right) + d4 \cdot d1\right) - d1 \cdot d1\]
\[d1 \cdot d4 + d1 \cdot \left(\left(d2 - d3\right) - d1\right)\]
\left(\left(d1 \cdot d2 - d1 \cdot d3\right) + d4 \cdot d1\right) - d1 \cdot d1
d1 \cdot d4 + d1 \cdot \left(\left(d2 - d3\right) - d1\right)
(FPCore (d1 d2 d3 d4)
 :precision binary64
 (- (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (* d1 d1)))
(FPCore (d1 d2 d3 d4)
 :precision binary64
 (+ (* d1 d4) (* d1 (- (- d2 d3) d1))))
double code(double d1, double d2, double d3, double d4) {
	return (((d1 * d2) - (d1 * d3)) + (d4 * d1)) - (d1 * d1);
}
double code(double d1, double d2, double d3, double d4) {
	return (d1 * d4) + (d1 * ((d2 - d3) - d1));
}

Error

Bits error versus d1

Bits error versus d2

Bits error versus d3

Bits error versus d4

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original0.0
Target0.0
Herbie0.0
\[d1 \cdot \left(\left(\left(d2 - d3\right) + d4\right) - d1\right)\]

Alternatives

Alternative 1
Error47.3
Cost26752
\[\sqrt{d4 + \left(\left(d2 - d3\right) - d1\right)} \cdot \sqrt[3]{{\left(d1 \cdot \sqrt{d4 + \left(\left(d2 - d3\right) - d1\right)}\right)}^{3}}\]
Alternative 2
Error35.5
Cost14016
\[\sqrt{d1 \cdot \left(d4 + \left(\left(d2 - d3\right) - d1\right)\right)} \cdot \sqrt{d1 \cdot \left(d4 + \left(\left(d2 - d3\right) - d1\right)\right)}\]
Alternative 3
Error31.7
Cost13888
\[\sqrt{d4 + \left(\left(d2 - d3\right) - d1\right)} \cdot \left(d1 \cdot \sqrt{d4 + \left(\left(d2 - d3\right) - d1\right)}\right)\]
Alternative 4
Error35.5
Cost13760
\[\sqrt{d4 + \left(\left(d2 - d3\right) - d1\right)} \cdot \left(d1 \cdot \sqrt{d4 + \left(d2 - d3\right)}\right)\]
Alternative 5
Error35.6
Cost13440
\[\sqrt[3]{{\left(d1 \cdot \left(d4 + \left(\left(d2 - d3\right) - d1\right)\right)\right)}^{3}}\]
Alternative 6
Error35.6
Cost8256
\[\sqrt[3]{\left(d1 \cdot \left(d4 + \left(\left(d2 - d3\right) - d1\right)\right)\right) \cdot \left(\left(d1 \cdot \left(d4 + \left(\left(d2 - d3\right) - d1\right)\right)\right) \cdot \left(d1 \cdot \left(d4 + \left(\left(d2 - d3\right) - d1\right)\right)\right)\right)}\]
Alternative 7
Error0.0
Cost960
\[\left(d1 \cdot d4 + \left(d1 \cdot d2 - d1 \cdot d3\right)\right) - d1 \cdot d1\]
Alternative 8
Error18.2
Cost576
\[d1 \cdot d4 + d1 \cdot \left(d2 - d1\right)\]
Alternative 9
Error7.7
Cost576
\[d1 \cdot d4 + d1 \cdot \left(d2 - d3\right)\]
Alternative 10
Error0.0
Cost576
\[d1 \cdot \left(d4 + \left(\left(d2 - d3\right) - d1\right)\right)\]
Alternative 11
Error18.5
Cost448
\[d1 \cdot \left(d4 - \left(d1 + d3\right)\right)\]
Alternative 12
Error18.3
Cost448
\[d1 \cdot \left(\left(d2 - d3\right) - d1\right)\]
Alternative 13
Error7.7
Cost448
\[d1 \cdot \left(d4 + \left(d2 - d3\right)\right)\]
Alternative 14
Error25.6
Cost448
\[d1 \cdot d4 + d1 \cdot d2\]
Alternative 15
Error18.2
Cost448
\[d1 \cdot \left(\left(d4 + d2\right) - d1\right)\]
Alternative 16
Error53.8
Cost256
\[-d1 \cdot d1\]
Alternative 17
Error43.7
Cost256
\[-d1 \cdot d3\]
Alternative 18
Error43.4
Cost192
\[d1 \cdot d4\]
Alternative 19
Error43.4
Cost192
\[d1 \cdot d2\]
Alternative 20
Error61.8
Cost64
\[1\]
Alternative 21
Error61.0
Cost64
\[0\]
Alternative 22
Error61.5
Cost64
\[-1\]

Error

Derivation

  1. Initial program 0.0

    \[\left(\left(d1 \cdot d2 - d1 \cdot d3\right) + d4 \cdot d1\right) - d1 \cdot d1\]
  2. Simplified0.0

    \[\leadsto \color{blue}{d1 \cdot \left(d4 + \left(\left(d2 - d3\right) - d1\right)\right)}\]
  3. Using strategy rm
  4. Applied distribute-rgt-in_binary64_37790.0

    \[\leadsto \color{blue}{d4 \cdot d1 + \left(\left(d2 - d3\right) - d1\right) \cdot d1}\]
  5. Simplified0.0

    \[\leadsto \color{blue}{d1 \cdot d4} + \left(\left(d2 - d3\right) - d1\right) \cdot d1\]
  6. Simplified0.0

    \[\leadsto d1 \cdot d4 + \color{blue}{d1 \cdot \left(\left(d2 - d3\right) - d1\right)}\]
  7. Simplified0.0

    \[\leadsto \color{blue}{d1 \cdot d4 + d1 \cdot \left(\left(d2 - d3\right) - d1\right)}\]
  8. Final simplification0.0

    \[\leadsto d1 \cdot d4 + d1 \cdot \left(\left(d2 - d3\right) - d1\right)\]

Reproduce

herbie shell --seed 2021022 
(FPCore (d1 d2 d3 d4)
  :name "FastMath dist4"
  :precision binary64

  :herbie-target
  (* d1 (- (+ (- d2 d3) d4) d1))

  (- (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (* d1 d1)))