-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathampere_tk.py
More file actions
64 lines (49 loc) · 1.55 KB
/
ampere_tk.py
File metadata and controls
64 lines (49 loc) · 1.55 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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
"""
ampere_tk.py
Created by Alex Chartier on 8/13/2018
"""
import pdb
import pickle
import numpy as np
import matplotlib.pyplot as plt
import datetime as dt
def main(
in_fname = '/media/alex/USB/2016_Ampere_data/%Y%m%dAmp_invert.ncdf',
out_fname = '/media/alex/USB/ampere_pkl/ampere_%y%m%d.pkl',
starttime=dt.datetime(2016, 1, 1),
endtime=dt.datetime(2016, 12, 31),
timestep=dt.timedelta(days=1),
):
time = starttime
rms_B = {'north': [], 'south': []}
while time <= endtime:
try:
with open(time.strftime(out_fname), 'rb') as f:
data = pickle.load(f)
except:
data = ncdf4_to_pkl(time.strftime(in_fname), time.strftime(out_fname))
print('saved %s' % time.strftime(out_fname))
for hem in rms_B.keys():
rms_B[hem].append(rms(data['b_eci']))
time += timestep
plt.plot(rms_B)
plt.show()
def rms(var):
return np.sqrt(np.mean(var ** 2))
def plot_currents(data):
plt.polar()
plt.tricontourf(data['mlt'][0, :], data['colat'][0, :], data['Jr'][0, :], cmap='bwr', vmin=-1, vmax=1)
plt.colorbar()
plt.show()
def ncdf4_to_pkl(in_fname, out_fname):
from netCDF4 import Dataset
rootgrp = Dataset(in_fname)
data = {}
for k, v in rootgrp.variables.items():
data[k] = v[...].filled().astype(float)
data[k][data[k] == v[...].fill_value] = np.nan
with open(out_fname, 'wb') as f:
pickle.dump(data, f)
return data
if __name__ == '__main__':
main()