|
14 | 14 |
|
15 | 15 | # Interpolate to regularly-spaced quad grid.
|
16 | 16 | z = np.cos(1.5*x)*np.cos(1.5*y)
|
17 |
| -interp = mtri.LinearTriInterpolator(triang, z) |
18 | 17 | xi, yi = np.meshgrid(np.linspace(0, 3, 20), np.linspace(0, 3, 20))
|
19 |
| -zi = interp(xi, yi) |
| 18 | + |
| 19 | +interp_lin = mtri.LinearTriInterpolator(triang, z) |
| 20 | +zi_lin = interp_lin(xi, yi) |
| 21 | + |
| 22 | +interp_cubic_geom = mtri.CubicTriInterpolator(triang, z, kind='geom') |
| 23 | +zi_cubic_geom = interp_cubic_geom(xi, yi) |
| 24 | + |
| 25 | +interp_cubic_min_E = mtri.CubicTriInterpolator(triang, z, kind='min_E') |
| 26 | +zi_cubic_min_E = interp_cubic_min_E(xi, yi) |
| 27 | + |
20 | 28 |
|
21 | 29 | # Plot the triangulation.
|
22 | 30 | plt.subplot(221)
|
23 | 31 | plt.tricontourf(triang, z)
|
24 | 32 | plt.triplot(triang, 'ko-')
|
25 | 33 | plt.title('Triangular grid')
|
26 | 34 |
|
27 |
| -# Plot interpolation to quad grid. |
| 35 | +# Plot linear interpolation to quad grid. |
28 | 36 | plt.subplot(222)
|
29 |
| -plt.contourf(xi, yi, zi) |
| 37 | +plt.contourf(xi, yi, zi_lin) |
30 | 38 | plt.plot(xi, yi, 'k-', alpha=0.5)
|
31 | 39 | plt.plot(xi.T, yi.T, 'k-', alpha=0.5)
|
32 |
| -plt.title('Linear interpolation') |
33 |
| - |
34 |
| -interp2 = mtri.CubicTriInterpolator(triang, z, kind='geom') |
35 |
| -zi2 = interp2(xi, yi) |
| 40 | +plt.title("Linear interpolation") |
36 | 41 |
|
| 42 | +# Plot cubic interpolation to quad grid, kind=geom |
37 | 43 | plt.subplot(223)
|
38 |
| -plt.contourf(xi, yi, zi2) |
| 44 | +plt.contourf(xi, yi, zi_cubic_geom) |
39 | 45 | plt.plot(xi, yi, 'k-', alpha=0.5)
|
40 | 46 | plt.plot(xi.T, yi.T, 'k-', alpha=0.5)
|
41 |
| -plt.title('Cubic interpolation (geom)') |
42 |
| - |
43 |
| -interp3 = mtri.CubicTriInterpolator(triang, z, kind='min_E') |
44 |
| -zi3 = interp3(xi, yi) |
| 47 | +plt.title("Cubic interpolation,\nkind='geom'") |
45 | 48 |
|
| 49 | +# Plot cubic interpolation to quad grid, kind=min_E |
46 | 50 | plt.subplot(224)
|
47 |
| -plt.contourf(xi, yi, zi3) |
| 51 | +plt.contourf(xi, yi, zi_cubic_min_E) |
48 | 52 | plt.plot(xi, yi, 'k-', alpha=0.5)
|
49 | 53 | plt.plot(xi.T, yi.T, 'k-', alpha=0.5)
|
50 |
| -plt.title('Cubic interpolation (min_E)') |
| 54 | +plt.title("Cubic interpolation,\nkind='min_E'") |
51 | 55 |
|
| 56 | +plt.tight_layout() |
52 | 57 | plt.show()
|
0 commit comments