How to compute Wasserstein distance?

71 visualizaciones (últimos 30 días)
Arvind Ganesh
Arvind Ganesh el 23 de Mayo de 2019
Editada: Georgios Pyrgiotakis el 14 de Mayo de 2020
I have two probability distributions in arrays P and Q (normalized by area, of same length, and over same sample space). I want to find Wasserstein distance between them.
I tried to use the Earth Mover Distance from here:
My input was [Y, fval] = emd(X, X, P, Q, @gdf)
where X is the sample space. But it is giving output:
No feasible solution found.
Linprog stopped because no point satisfies the constraints.
Is this the way to compute Wasserstein distance? How do I fix this?

Respuestas (1)

Koorosh Aslansefat
Koorosh Aslansefat el 29 de Abr. de 2020
Editada: Koorosh Aslansefat el 29 de Abr. de 2020
I have recently added new set of functions for ECDF-based distance measure to MATLAB Exchange.
I would suggest to have a look.
  3 comentarios
Koorosh Aslansefat
Koorosh Aslansefat el 13 de Mayo de 2020
If P and Q can be considered as empirical distribution function (ECDF), then you can use those functions with a bit of modification.
Georgios Pyrgiotakis
Georgios Pyrgiotakis el 14 de Mayo de 2020
Editada: Georgios Pyrgiotakis el 14 de Mayo de 2020
Yes P and Q are emprical CDF. How can I use these functions? I tried but I get lost. It seems that you start with the data set convert it to CDF and then calculate the area between the two curves?

Iniciar sesión para comentar.

Etiquetas

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by