-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmakeJSON.pl
executable file
·133 lines (114 loc) · 4.34 KB
/
makeJSON.pl
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
#! /usr/bin/perl -w
use strict;
use JSON::XS;
use DBI;
use Data::Dumper;
my $dbh;
eval {
$dbh = DBI->connect("dbi:SQLite:water_1year.db");
};
if ($@) {
die $@;
}
my $rivers = [
{name => "Sacramento River", length => 447, flowdirection => "S", patterns => ['SACRAMENTO R ']},
{name => "San Joaquin River", length => 330, flowdirection => "N", patterns => ['SAN JOAQUIN R ']},
{name => "Klamath River", length => 263, flowdirection => "SW", patterns => ['KLAMATH R ']},
{name => "Russian River", length => 110, flowdirection => "S", patterns => ['RUSSIAN R ']},
{name => "Tuolumne River", length => 150, flowdirection => "W", patterns => ['TUOLUMNE R ']},
{name => "Merced River", length => 112, flowdirection => "W", patterns => ['MERCED R ']},
{name => "Trinity River", length => 130, flowdirection => "S", patterns => ['TRINITY R ']},
{name => "Truckee River", length => 120, flowdirection => "N", patterns => ['TRUCKEE R ']},
# {name => "Coachella Canal", length => 122, flowdirection => "E", patterns => ['COACHELLA CANAL']},
{name => "Colorado River", length => 122, flowdirection => "S", patterns => ['COLORADO RIVER ']},
# {name => "Mokelumne River", length => 122, flowdirection => "W", patterns => ['MOKELUMNE R ']},
# {name => "Mojave River", length => 110, flowdirection => "E", patterns => ['MOJAVE R ']},
];
my $metrics = $dbh->selectall_arrayref("
select * from metric
where
-- (
-- dateTime = '2010-10-16T00:00:00.000-07:00'
-- strftime('%Y-%m', dateTime) = '2010-09'
-- or strftime('%Y-%m-%d', dateTime) = '2010-10-15'
-- or strftime('%Y-%m-%d', dateTime) = '2010-10-14'
-- ) and
valueType = '00060' and
value >= 0
;",
## [ qw(siteCode valueType value dateTime) ],
);
my $site_name_sql_pattern = "";
foreach (@$rivers) {
foreach (@{$_->{patterns}}) {
$site_name_sql_pattern .= " siteName like \'\%$_\%\' or";
}
}
# Remove the final "or"
chop($site_name_sql_pattern);
chop($site_name_sql_pattern);
my $sql_for_sites = <<"END";
select * from site
where $site_name_sql_pattern
group by siteCode;
END
my $sites = $dbh->selectall_arrayref($sql_for_sites);
## [ qw(siteCode siteName latitude longtitude) ],
my %peakStreamflowPerSite;
my $metricsHash = {};
my $dateHash = {};
foreach my $r (@$metrics) {
my ($siteCode, $valueType, $value, $date) = ($r->[0], $r->[1], $r->[2], $r->[3]);
$date =~ s/(.*?)T.*/$1/;
if (not defined $dateHash->{$date}) { $dateHash->{$date} = scalar (keys %{$dateHash}); }
$metricsHash->{$r->[0]}->{$dateHash->{$date}}->{$r->[1]} = $r->[2];
# track the peak streamflow across all dates for any given site
if ($valueType == "00060") {
if (!defined $peakStreamflowPerSite{$siteCode} ||
$value > $peakStreamflowPerSite{$siteCode}) {
$peakStreamflowPerSite{$siteCode} = $value;
}
}
}
# find peakStreamflowPerSite by river now
foreach my $site ( @$sites ) {
my ($code, $name) = ($site->[0], $site->[1]);
for (my $i=0; $i < scalar @$rivers; $i++) {
foreach my $p (@{$rivers->[$i]->{patterns}}) {
if ($name =~ m/$p/) {
if (defined $peakStreamflowPerSite{$code} &&
(!defined $rivers->[$i]->{peaksf} ||
$peakStreamflowPerSite{$code} > $rivers->[$i]->{peaksf})) {
$rivers->[$i]->{peaksf} =
$peakStreamflowPerSite{$code};
#remove before dump
delete $peakStreamflowPerSite{$code};
}
}
}
}
}
# Rank rivers by peakStreamflow and make rank a field
my @sorted_rivers = sort { $b->{peaksf} <=> $a->{peaksf} }
@$rivers;
for (my $i=0; $i < scalar @sorted_rivers; $i++) {
$sorted_rivers[$i]->{rank} = $i+1;
}
# Date indexes coming out of DB might not be in order. Generate an
# ordered list by sorting at the end.
my @sorted_dates = [];
my @sorted_keys = sort keys %$dateHash;
for (my $i=0; $i < scalar @sorted_keys; $i++) {
$sorted_dates[$i] = { ymd => $sorted_keys[$i],
index => $dateHash->{$sorted_keys[$i]}
}
}
open DATAJS, "> data.js" or
die "could not open data.js";
my $coder = JSON::XS->new->ascii->pretty->allow_nonref;
print DATAJS "var rivers = ", $coder->encode (\@sorted_rivers), ";\n\n";
print DATAJS "var dates = ", $coder->encode (\@sorted_dates), ";\n\n";
print DATAJS "var metrics = ", $coder->encode ($metricsHash), ";\n\n";
print DATAJS "var sites = ", $coder->encode ($sites), ";\n";
close DATAJS or
die "could not close DATAJS";