-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathkespectra.py
54 lines (53 loc) · 1.79 KB
/
kespectra.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
from netCDF4 import Dataset
from sqgturb import rfft2, irfft2, SQG
import numpy as np
# plot kinetic energy spectra from netcdf file generated by sqg_run.py
nc = Dataset('sqg_N96_3hrly.nc')
print(nc)
pv = nc.variables['pv']
time = nc.variables['t'][:]/3600.
N = pv.shape[-1]
model =\
SQG(np.empty((2,N,(N//2)+1),np.complex64),U=nc.U,L=nc.L,H=nc.H,dt=nc.dt,r=nc.r,tdiab=nc.tdiab,diff_order=nc.diff_order,diff_efold=nc.diff_efold)
N = model.N
k = np.abs((N*np.fft.fftfreq(N))[0:(N//2)+1])
l = N*np.fft.fftfreq(N)
k,l = np.meshgrid(k,l)
ktot = np.sqrt(k**2+l**2)
kespecmean = None
ncount = 0
for nt,t in enumerate(time):
pvgrd = pv[nt] - model.pvbar
pvspec = rfft2(pvgrd)
psispec = model.invert(pvspec)
psispec = psispec/(model.N*np.sqrt(2.))
kespec = (model.ksqlsq*(psispec*np.conjugate(psispec))).real
if kespecmean is None:
kespecmean = (model.ksqlsq*(psispec*np.conjugate(psispec))).real
else:
kespecmean = kespecmean + kespec
ncount += 1
print(ncount, kespec.mean())
#print(t, kespec.mean(), (u**2+v**2).mean())
kespecmean = kespecmean/ncount
print(kespecmean.mean(), kespecmean.shape)
ktotmax = (model.N//2)+1
kespec = np.zeros(ktotmax,np.float)
for i in range(kespecmean.shape[2]):
for j in range(kespecmean.shape[1]):
totwavenum = ktot[j,i]
if int(totwavenum) < ktotmax:
kespec[int(totwavenum)] = kespec[int(totwavenum)] +\
kespecmean[:,j,i].mean(axis=0)
wavenums = np.arange(ktotmax,dtype=np.float)
wavenums[0] = 1.
idealke1 = 2.*kespec[1]*wavenums**-3
idealke2 = 2.*kespec[1]*wavenums**(-5./3,)
nc.close()
import matplotlib.pyplot as plt
import numpy as np
plt.loglog(wavenums[1:],kespec[1:],color='b')
#plt.loglog(wavenums,idealke1,color='k')
plt.loglog(wavenums,idealke2,color='r')
plt.savefig('kespectrum.png')
plt.show()