Fix axes in finiterectlat-constant-driving.py plots

Former-commit-id: 03758f3af165209dfc10eff9509ea70eb4699223
This commit is contained in:
Marek Nečada 2020-03-29 11:35:41 +03:00
parent a88694e7ef
commit dc503158bf
1 changed files with 16 additions and 7 deletions

View File

@ -65,15 +65,15 @@ def float_nicestr(x, tol=1e-5):
else: else:
return "%+.3g" % x return "%+.3g" % x
def cplx_nicestr(x): def cplx_nicestr(x, tol=1e-5):
x = complex(x) x = complex(x)
if x == 0: if x == 0:
return '0' return '0'
ret = "" ret = ""
if x.real: if x.real:
ret = ret + float_nicestr(x.real) ret = ret + float_nicestr(x.real, tol)
if x.imag: if x.imag:
ret = ret + float_nicestr(x.imag) + 'i' ret = ret + float_nicestr(x.imag, tol) + 'i'
if x.real and x.imag: if x.real and x.imag:
return '(' + ret + ')' return '(' + ret + ')'
else: else:
@ -187,7 +187,7 @@ if not math.isnan(a.ccd_distance):
ccd_x = np.linspace(-ccd_size/2, ccd_size/2, a.ccd_resolution) ccd_x = np.linspace(-ccd_size/2, ccd_size/2, a.ccd_resolution)
ccd_y = np.linspace(-ccd_size/2, ccd_size/2, a.ccd_resolution) ccd_y = np.linspace(-ccd_size/2, ccd_size/2, a.ccd_resolution)
ccd_grid = np.meshgrid(ccd_x, ccd_y, (a.ccd_distance,), indexing='ij') ccd_grid = np.meshgrid(ccd_x, ccd_y, (a.ccd_distance,), indexing='ij')
ccd_points = np.stack(ccd_grid, axis=-1).squeeze(axis=-2) ccd_points = np.swapaxes(np.stack(ccd_grid, axis=-1).squeeze(axis=-2), 0,1) # First axis is y, second is x, because of imshow...
ccd_fields = np.empty((nelem,) + ccd_points.shape, dtype=complex) ccd_fields = np.empty((nelem,) + ccd_points.shape, dtype=complex)
for y in range(nelem): for y in range(nelem):
ccd_fields[y] = ssw.scattered_E(scattered_full[y], ccd_points, btyp=BesselType.HANKEL_PLUS) ccd_fields[y] = ssw.scattered_E(scattered_full[y], ccd_points, btyp=BesselType.HANKEL_PLUS)
@ -223,12 +223,12 @@ if a.plot or (a.plot_out is not None):
posmap[i,0] = np.searchsorted(xpositions, positions[i,0]) posmap[i,0] = np.searchsorted(xpositions, positions[i,0])
posmap[i,1] = np.searchsorted(ypositions, positions[i,1]) posmap[i,1] = np.searchsorted(ypositions, positions[i,1])
def fullvec2grid(fullvec): def fullvec2grid(fullvec, swapxy=False):
arr = np.empty((Nx,Ny,nelem), dtype=complex) arr = np.empty((Nx,Ny,nelem), dtype=complex)
for pi, offset in enumerate(ss.fullvec_poffsets): for pi, offset in enumerate(ss.fullvec_poffsets):
ix, iy = posmap[pi] ix, iy = posmap[pi]
arr[ix, iy] = fullvec[offset:offset+nelem] arr[ix, iy] = fullvec[offset:offset+nelem]
return arr return np.swapaxes(arr, 0, 1) if swapxy else arr
import matplotlib import matplotlib
matplotlib.use('pdf') matplotlib.use('pdf')
@ -251,6 +251,9 @@ if a.plot or (a.plot_out is not None):
axes[0,13].set_title("$|E_{y}|^2$ @ $z = %g\,\mathrm{m}$" % a.ccd_distance) axes[0,13].set_title("$|E_{y}|^2$ @ $z = %g\,\mathrm{m}$" % a.ccd_distance)
axes[0,14].set_title("$|E_x + E_y|^2$ @ $z = %g\,\mathrm{m}$" % a.ccd_distance) axes[0,14].set_title("$|E_x + E_y|^2$ @ $z = %g\,\mathrm{m}$" % a.ccd_distance)
axes[0,15].set_title("$|E_{z}|^2$ @ $z = %g\,\mathrm{m}$" % a.ccd_distance) axes[0,15].set_title("$|E_{z}|^2$ @ $z = %g\,\mathrm{m}$" % a.ccd_distance)
for gg in range(12,16):
axes[-1,gg].set_xlabel("$x/\mathrm{m}$")
for y in range(nelem): for y in range(nelem):
fulvec = scattered_full[y] fulvec = scattered_full[y]
@ -262,7 +265,9 @@ driving_nonzero_y)) # TODO shorten the complex number precision
else: else:
driving_descr = "%s,%d,%+d"%('E' if t[y]==2 else 'M', l[y], m[y],) driving_descr = "%s,%d,%+d"%('E' if t[y]==2 else 'M', l[y], m[y],)
axes[y,0].set_ylabel(driving_descr) axes[y,0].set_ylabel(driving_descr)
vecgrid = fullvec2grid(fulvec) axes[y,-1].yaxis.set_label_position("right")
axes[y,-1].set_ylabel("$y/\mathrm{m}$\n"+driving_descr)
vecgrid = fullvec2grid(fulvec, swapxy=True)
vecgrid_ff = np.fft.fftshift(np.fft.fft2(vecgrid, axes=(0,1)),axes=(0,1)) vecgrid_ff = np.fft.fftshift(np.fft.fft2(vecgrid, axes=(0,1)),axes=(0,1))
lemax = np.amax(abs(vecgrid)) lemax = np.amax(abs(vecgrid))
for yp in range(0,3): for yp in range(0,3):
@ -298,6 +303,10 @@ driving_nonzero_y)) # TODO shorten the complex number precision
horizontalalignment='center', verticalalignment='center', transform=axes[y,14].transAxes) horizontalalignment='center', verticalalignment='center', transform=axes[y,14].transAxes)
axes[y, 15].text(0.5, 0.5, '%g\n%g' % (zintmax,zintmax/e2vmax), axes[y, 15].text(0.5, 0.5, '%g\n%g' % (zintmax,zintmax/e2vmax),
horizontalalignment='center', verticalalignment='center', transform=axes[y,15].transAxes) horizontalalignment='center', verticalalignment='center', transform=axes[y,15].transAxes)
for gg in range(12,16):
axes[y,gg].yaxis.tick_right()
for gg in range(12,15):
axes[y,gg].yaxis.set_major_formatter(plt.NullFormatter())
plotfile = defaultprefix + ".pdf" if a.plot_out is None else a.plot_out plotfile = defaultprefix + ".pdf" if a.plot_out is None else a.plot_out
fig.savefig(plotfile) fig.savefig(plotfile)