MVU creates a mapping from the high dimensional input vectors to some low dimensional Euclidean vector space in the following steps:[5]
A neighbourhood graph is created. Each input is connected with its k-nearest input vectors (according to Euclidean distance metric) and all k-nearest neighbors are connected with each other. If the data is sampled well enough, the resulting graph is a discrete approximation of the underlying manifold.
The neighbourhood graph is "unfolded" with the help of semidefinite programming. Instead of learning the output vectors directly, the semidefinite programming aims to find an inner product matrix that maximizes the pairwise distances between any two inputs that are not connected in the neighbourhood graph while preserving the nearest neighbors distances.
The low-dimensional embedding is finally obtained by application of multidimensional scaling on the learned inner product matrix.
The steps of applying semidefinite programming followed by a linear dimensionality reduction step to recover a low-dimensional embedding into a Euclidean space were first proposed by Linial, London, and Rabinovich.[6]
Optimization formulation
Let be the original input and be the embedding. If are two neighbors, then the local isometry constraint that needs to be satisfied is:[7][8][9]
Let be the Gram matrices of and (i.e.: ). We can express the above constraint for every neighbor points in term of :[10][11]
In addition, we also want to constrain the embedding to center at the origin:[12][13][14]
As described above, except the distances of neighbor points are preserved, the algorithm aims to maximize the pairwise distance of every pair of points. The objective function to be maximized is:[15][16][17]
Intuitively, maximizing the function above is equivalent to pulling the points as far away from each other as possible and therefore "unfold" the manifold. The local isometry constraint [18]
Let where
prevents the objective function from diverging (going to infinity).
Since the graph has N points, the distance between any two points . We can then bound the objective function as follows:[19][20]
The objective function can be rewritten purely in the form of the Gram matrix:[21][22][23]
Finally, the optimization can be formulated as:[24][25][26]
After the Gram matrix is learned by semidefinite programming, the output can be obtained via Cholesky decomposition.
In particular, the Gram matrix can be written as where is the i-th element of eigenvector of the eigenvalue .[27][28]
It follows that the -th element of the output is .[29][30]