forked from abatz/WebInterface
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfigureFormatting.py
80 lines (73 loc) · 2.91 KB
/
figureFormatting.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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
from collections import defaultdict
import datetime
import logging
import ee
import processingMethods
#===========================================
# FORMAT_DATA_FOR_HIGHCHARTS
#===========================================
def set_time_series_data(dataList, template_values):
"""
Args:
dataList: nested list of data from EarthEngine getRegion method
template_values: dictionary
timeSeriesTextData: time series data for displaying as text,
if not empty, data in dataList will be appended
timeSeriesGraphData: time series data for plotting,
if not empty, data in dataList will be appended
Returns:
time series data for displaying as text
time series data for plotting
"""
var = template_values['variable'][1:]
units = template_values['units']
# Format data for highcharts
# Group data by point while reading
ts_dict = defaultdict(list)
graph_dict = defaultdict(list)
#Plot colors should agree with marker colors
#Since defaultdicts are not ordered
#we need to keep track of the points
points = []
for i in range(7):
lon = float(template_values['p' + str(i+1)].replace(' ','').split(',')[0])
lat = float(template_values['p' + str(i+1)].replace(' ','').split(',')[1])
points.append((lon,lat))
m_colors = defaultdict(list)
for row in dataList:
pnt = (float(row[1]), float(row[2]))
#Set the marker color
if pnt not in m_colors.keys():
for i, p in enumerate(points):
if abs(p[0] - pnt[0]) < 0.00001 and abs(p[1] - pnt[1]) < 0.00001:
m_colors[pnt] = [template_values['marker_colors'][i]]
break
time_int = int(row[3])
date_obj = datetime.datetime.utcfromtimestamp(float(time_int) / 1000)
date_str = date_obj.strftime('%Y-%m-%d')
try:
val = processingMethods.modify_units_in_timeseries(float(row[4]),var,units)
ts_dict[pnt].append([date_str, '{0:0.4f}'.format(val)])
graph_dict[pnt].append([time_int, val])
except:
continue
ts_dict[pnt].append([date_str, 'None'])
'''
Note ee spits out data for points in one list,
stringing the point data together
'''
timeSeriesTextData = [];timeSeriesGraphData = []
for pnt, ts_data in sorted(ts_dict.items()):
data_dict = {
'LongLat': '{0:0.4f},{1:0.4f}'.format(*pnt),
'Data':sorted(ts_data)
}
timeSeriesTextData.append(data_dict)
for i, (pnt, graph_data) in enumerate(sorted(graph_dict.items())):
data_dict_graph = {
'MarkerColor':m_colors[pnt][0],
'LongLat': '{0:0.4f},{1:0.4f}'.format(*pnt),
'Data':sorted(graph_data)
}
timeSeriesGraphData.append(data_dict_graph)
return timeSeriesTextData, timeSeriesGraphData