# Dattorro Convex Optimization of Eternity II

### From Wikimization

Line 2: | Line 2: | ||

That <math>A\,</math> matrix is obtained by presolving a sparse 864,593 <math>\!\times\!</math> 1,048,576 system. | That <math>A\,</math> matrix is obtained by presolving a sparse 864,593 <math>\!\times\!</math> 1,048,576 system. | ||

This [http://www.convexoptimization.com/TOOLS/EternityII.mat Matlab binary] contains three successive reductions, each equivalent to that larger system: | This [http://www.convexoptimization.com/TOOLS/EternityII.mat Matlab binary] contains three successive reductions, each equivalent to that larger system: | ||

- | *<math>\tau_{\rm orig}\!\in\mathbb{R}^{864593}</math> and <math>\,E_{\rm orig}\!\in\mathbb{R}^{864593\times1048576}</math> is the original Eternity II matrix | + | *<math>\tau_{\rm orig}\!\in\mathbb{R}^{864593}</math> and <math>\,E_{\rm orig}\!\in\mathbb{R}^{864593\times1048576}</math> is the original Eternity II matrix, |

*<math>\tau\!\in\mathbb{R}^{11077}</math> and <math>\,E\!\in\mathbb{R}^{11077\times262144}</math> is the million column Eternity II matrix having redundant rows and columns removed analytically, | *<math>\tau\!\in\mathbb{R}^{11077}</math> and <math>\,E\!\in\mathbb{R}^{11077\times262144}</math> is the million column Eternity II matrix having redundant rows and columns removed analytically, | ||

*<math>\tilde{\tau}\!\in\mathbb{R}^{10054}</math> and <math>\,\tilde{E}\!\in\mathbb{R}^{10054\times204304}</math> has columns removed corresponding to some known zero variables (removal produced dependent rows), | *<math>\tilde{\tau}\!\in\mathbb{R}^{10054}</math> and <math>\,\tilde{E}\!\in\mathbb{R}^{10054\times204304}</math> has columns removed corresponding to some known zero variables (removal produced dependent rows), | ||

Line 16: | Line 16: | ||

All entries of <math>A\,</math> are integers from the set <math>\{{-1},0,1\}\,</math>. | All entries of <math>A\,</math> are integers from the set <math>\{{-1},0,1\}\,</math>. | ||

- | Vector <math>b_{\!}\in\!\{0,1\}^{7362}</math> has only 358 nonzeros. | + | Vector <math>b_{\!}\in\!\{0\,,\,1\}^{7362}</math> has only 358 nonzeros. |

Direction vector <math>z\,</math> is determined by [[Convex Iteration]]: | Direction vector <math>z\,</math> is determined by [[Convex Iteration]]: | ||

Line 26: | Line 26: | ||

</center> | </center> | ||

These two problems are iterated | These two problems are iterated | ||

- | to find a minimal cardinality solution <math>x\,</math>. Constraint <math>A_{}x\!=b\,</math> bounds the variable from above by <math>\mathbf{1}</math>. Any minimal cardinality solution is binary and solves the Eternity II puzzle. | + | to find a minimal cardinality solution <math>x\,</math>. Constraint <math>A_{}x\!=b\,</math> bounds the variable from above by <math>\mathbf{1}</math>. Any minimal cardinality solution is binary and solves the Eternity II puzzle. |

The Eternity II puzzle is solved when | The Eternity II puzzle is solved when | ||

<center><math> | <center><math> |

## Revision as of 17:05, 6 September 2015

An Eternity II puzzle problem formulation is discussed thoroughly in section 4.6.0.0.15 of the book Convex Optimization & Euclidean Distance Geometry which is freely available. That matrix is obtained by presolving a sparse 864,593 1,048,576 system. This Matlab binary contains three successive reductions, each equivalent to that larger system:

- and is the original Eternity II matrix,
- and is the million column Eternity II matrix having redundant rows and columns removed analytically,
- and has columns removed corresponding to some known zero variables (removal produced dependent rows),
- and has columns removed not in smallest face (containing ) of polyhedral cone .

The following linear program is a very difficult problem that remains unsolved:

Matrix is sparse having only 782,087 nonzeros. All entries of are integers from the set .

Vector has only 358 nonzeros.

Direction vector is determined by Convex Iteration:

These two problems are iterated to find a minimal cardinality solution . Constraint bounds the variable from above by . Any minimal cardinality solution is binary and solves the Eternity II puzzle. The Eternity II puzzle is solved when

Minimal cardinality of this Eternity II problem is equal to number of puzzle pieces, 256.

Comment: The technique, convex iteration, requires no modification (and works very well) when applied instead to mixed integer programming (MIP, not discussed in book). There is no modification to the linear program statement here except 256 variables, corresponding to the largest entries of iterate , are declared binary.