-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathplot_vipir_nmf2.py
More file actions
50 lines (39 loc) · 1.45 KB
/
plot_vipir_nmf2.py
File metadata and controls
50 lines (39 loc) · 1.45 KB
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
import pdb
import datetime as dt
import numpy as np
from plot_lp_radioice import load_hf
import matplotlib.pyplot as plt
import nvector as nv
import pickle
import sys
sys.path.append('/Users/chartat1/fusionpp/src/nimo')
import nc_utils
starttime = dt.datetime(2019, 2, 28)
step = dt.timedelta(days=1)
endtime = dt.datetime(2019, 3, 14)
in_fname_fmt = '/Users/chartat1/xpatch/data/vipir/Result/result_%Y_%m_%d.nc'
def load_vipir_nmf2(starttime, endtime, step, in_fname_fmt):
time = starttime
vipir_out = {}
while time <= endtime:
vipir_fname = time.strftime(in_fname_fmt)
print('Trying to load %s' % vipir_fname)
vipir = nc_utils.ncread_vars(vipir_fname)
if 'time' not in vipir_out.keys():
vipir_out['time'] = []
for ind, yr in enumerate(vipir['yr']):
vipir_out['time'].append(dt.datetime(
yr, vipir['mon'][ind], vipir['day'][ind],
vipir['hr'][ind], vipir['min'][ind], vipir['sec'][ind],
))
if 'foF2' not in vipir_out.keys():
vipir_out['foF2'] = np.ma.filled(vipir['foF2'])
else:
vipir_out['foF2'] = np.concatenate([vipir_out['foF2'], np.ma.filled(vipir['foF2'])], axis=0)
time += step
for k, v in vipir_out.items():
vipir_out[k] = np.array(v)
vipir_out['NmF2'] = (vipir_out['foF2'] * 1E6 / 9) ** 2
return vipir_out
plt.plot(vipir_out['time'], vipir_out['NmF2'], '.')
plt.show()