注意
跳转到末尾 以下载完整示例代码。
一维分布的最优运输
这个例子展示了EMD和Sinkhorn传输计划的计算及其可视化。
# Author: Remi Flamary <remi.flamary@unice.fr>
#
# License: MIT License
# sphinx_gallery_thumbnail_number = 3
import numpy as np
import matplotlib.pylab as pl
import ot
import ot.plot
from ot.datasets import make_1D_gauss as gauss
生成数据
绘制分布和损失矩阵

<matplotlib.legend.Legend object at 0x7f590d9f53f0>
pl.figure(2, figsize=(5, 5))
ot.plot.plot1D_mat(a, b, M, "Cost matrix M")

(<Axes: >, <Axes: >, <Axes: >)
解决EMD

(<Axes: >, <Axes: >, <Axes: >)
解决Sinkhorn

It. |Err
-------------------
0|2.861463e-01|
10|1.860154e-01|
20|8.144529e-02|
30|3.130143e-02|
40|1.178815e-02|
50|4.426078e-03|
60|1.661047e-03|
70|6.233110e-04|
80|2.338932e-04|
90|8.776627e-05|
100|3.293340e-05|
110|1.235791e-05|
120|4.637176e-06|
130|1.740051e-06|
140|6.529356e-07|
150|2.450071e-07|
160|9.193632e-08|
170|3.449812e-08|
180|1.294505e-08|
190|4.857493e-09|
It. |Err
-------------------
200|1.822723e-09|
脚本的总运行时间: (0分钟 0.269秒)