Mercurial > dive4elements > river
annotate flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/MeasurementFactory.java @ 4007:d4d272e56d3a
S(Q) Fixed AIOOBE
author | Sascha L. Teichmann <teichmann@intevation.de> |
---|---|
date | Mon, 01 Oct 2012 23:05:21 +0200 |
parents | d4e39cc5c10c |
children | fea3d9210948 |
rev | line source |
---|---|
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
1 package de.intevation.flys.artifacts.model.sq; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
2 |
3992
a9c93b7c9da1
Simpify the S(Q) fraction sieving stuff.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3985
diff
changeset
|
3 import java.util.ArrayList; |
4005
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
4 import java.util.Calendar; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
5 import java.util.Collections; |
4004
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
6 import java.util.Date; |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
7 import java.util.List; |
4001
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
8 import java.util.TreeMap; |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
9 |
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
10 import de.intevation.flys.artifacts.model.DateRange; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
11 |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
12 import de.intevation.flys.backend.SedDBSessionHolder; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
13 |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
14 import java.util.HashMap; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
15 import java.util.Map; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
16 |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
17 import org.apache.log4j.Logger; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
18 |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
19 import org.hibernate.SQLQuery; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
20 import org.hibernate.Session; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
21 |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
22 import org.hibernate.transform.BasicTransformerAdapter; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
23 |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
24 import org.hibernate.type.StandardBasicTypes; |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
25 |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
26 public class MeasurementFactory |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
27 { |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
28 private static final Logger log = |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
29 Logger.getLogger(MeasurementFactory.class); |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
30 |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
31 public static final String SQL_FACTIONS = |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
32 "SELECT m.datum AS DATUM," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
33 "g.GLOTRECHTEID AS GLOTRECHTEID," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
34 "gp.LFDNR AS LFDNR," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
35 "g.UFERABST AS UFERABST," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
36 "g.UFERABLINKS AS UFERABLINKS," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
37 "m.TSCHWEB AS TSCHWEB," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
38 "m.TSAND AS TSAND," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
39 "gp.GTRIEB AS GTRIEB," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
40 "m.TGESCHIEBE AS TGESCHIEBE," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
41 "sie.SIEB01 AS SIEB01, sie.SIEB02 AS SIEB02," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
42 "sie.SIEB03 AS SIEB03, sie.SIEB04 AS SIEB04," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
43 "sie.SIEB05 AS SIEB05, sie.SIEB06 AS SIEB06," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
44 "sie.SIEB07 AS SIEB07, sie.SIEB08 AS SIEB08," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
45 "sie.SIEB09 AS SIEB09, sie.SIEB10 AS SIEB10," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
46 "sie.SIEB11 AS SIEB11, sie.SIEB12 AS SIEB12," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
47 "sie.SIEB13 AS SIEB13, sie.SIEB14 AS SIEB14," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
48 "sie.SIEB15 AS SIEB15, sie.SIEB16 AS SIEB16," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
49 "sie.SIEB17 AS SIEB17, sie.SIEB18 AS SIEB18," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
50 "sie.SIEB19 AS SIEB19, sie.SIEB20 AS SIEB20," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
51 "sie.SIEB21 AS SIEB21," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
52 "gs.RSIEB01 AS RSIEB01, gs.RSIEB02 AS RSIEB02," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
53 "gs.RSIEB03 AS RSIEB03, gs.RSIEB04 AS RSIEB04," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
54 "gs.RSIEB05 AS RSIEB05, gs.RSIEB06 AS RSIEB06," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
55 "gs.RSIEB07 AS RSIEB07, gs.RSIEB08 AS RSIEB08," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
56 "gs.RSIEB09 AS RSIEB09, gs.RSIEB10 AS RSIEB10," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
57 "gs.RSIEB11 AS RSIEB11, gs.RSIEB12 AS RSIEB12," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
58 "gs.RSIEB13 AS RSIEB13, gs.RSIEB14 AS RSIEB14," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
59 "gs.RSIEB15 AS RSIEB15, gs.RSIEB16 AS RSIEB16," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
60 "gs.RSIEB17 AS RSIEB17, gs.RSIEB18 AS RSIEB18," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
61 "gs.RSIEB19 AS RSIEB19, gs.RSIEB20 AS RSIEB20," + |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
62 "gs.RSIEB21 AS RSIEB21, gs.REST AS REST " + |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
63 "FROM MESSUNG m " + |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
64 "JOIN STATION s ON m.STATIONID = s.STATIONID " + |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
65 "JOIN glotrechte g ON m.MESSUNGID = g.MESSUNGID " + |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
66 "JOIN gprobe gp ON g.GLOTRECHTEID = gp.GLOTRECHTEID " + |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
67 "JOIN GSIEBUNG gs ON g.GLOTRECHTEID = gs.GLOTRECHTEID " + |
3310
8af1111af180
SQ relation: More fixes.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3308
diff
changeset
|
68 "WHERE " + |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
69 "g.NAME = :river_name " + |
3396
3bffbf670b49
Removed trailing whitespace.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3393
diff
changeset
|
70 "AND m.Q_BPEGEL IS NOT NULL " + |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
71 "AND s.KM BETWEEN :location - 0.001 AND :location + 0.001 " + |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
72 "AND m.DATUM BETWEEN :from AND :to " + |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
73 "AND m.TGESCHIEBE IS NOT NULL " + |
4004
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
74 "AND m.DATUM IS NOT NULL " + |
3981
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
75 "AND (" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
76 "COALESCE(gs.RSIEB01, 0) + COALESCE(gs.RSIEB02, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
77 "COALESCE(gs.RSIEB03, 0) + COALESCE(gs.RSIEB04, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
78 "COALESCE(gs.RSIEB05, 0) + COALESCE(gs.RSIEB06, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
79 "COALESCE(gs.RSIEB07, 0) + COALESCE(gs.RSIEB08, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
80 "COALESCE(gs.RSIEB09, 0) + COALESCE(gs.RSIEB10, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
81 "COALESCE(gs.RSIEB11, 0) + COALESCE(gs.RSIEB12, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
82 "COALESCE(gs.RSIEB13, 0) + COALESCE(gs.RSIEB14, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
83 "COALESCE(gs.RSIEB15, 0) + COALESCE(gs.RSIEB16, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
84 "COALESCE(gs.RSIEB17, 0) + COALESCE(gs.RSIEB18, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
85 "COALESCE(gs.RSIEB19, 0) + COALESCE(gs.RSIEB20, 0) +" + |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
86 "COALESCE(gs.RSIEB21, 0) + COALESCE(gs.REST, 0)) > 0 " + |
4001
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
87 "ORDER BY m.DATUM, g.UFERABST, g.GLOTRECHTEID, gp.LFDNR"; |
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
88 |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
89 private static final int index(String s) { |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
90 return Integer.parseInt(s.substring(s.length()-2))-1; |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
91 } |
3992
a9c93b7c9da1
Simpify the S(Q) fraction sieving stuff.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3985
diff
changeset
|
92 |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
93 public static final BasicTransformerAdapter FRACTIONS_TRANSFORMER = |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
94 new BasicTransformerAdapter() { |
3992
a9c93b7c9da1
Simpify the S(Q) fraction sieving stuff.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3985
diff
changeset
|
95 |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
96 @Override |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
97 public Object transformTuple(Object [] tuple, String [] aliases) { |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
98 Map<String, Object> map = new HashMap<String, Object>(); |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
99 |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
100 Sieve [] sieves = new Sieve[21]; |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
101 |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
102 List<Sieve> validSieves = new ArrayList<Sieve>(21); |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
103 |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
104 for (int i = 0; i < tuple.length; ++i) { |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
105 Object value = tuple[i]; |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
106 if (value == null) { |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
107 continue; |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
108 } |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
109 String alias = aliases[i]; |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
110 if (alias.startsWith("SIEB")) { |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
111 Sieve s = new Sieve((Double)value, 0d); |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
112 sieves[index(alias)] = s; |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
113 } |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
114 else if (alias.startsWith("RSIEB")) { |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
115 Sieve s = sieves[index(alias)]; |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
116 if (s != null) { |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
117 s.setLoad((Double)value); |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
118 validSieves.add(s); |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
119 } |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
120 } |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
121 else if (alias.equals("REST")) { |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
122 Sieve s = new Sieve(0d, (Double)value); |
3992
a9c93b7c9da1
Simpify the S(Q) fraction sieving stuff.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3985
diff
changeset
|
123 validSieves.add(s); |
a9c93b7c9da1
Simpify the S(Q) fraction sieving stuff.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3985
diff
changeset
|
124 } |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
125 else { |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
126 map.put(alias, value); |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
127 } |
3992
a9c93b7c9da1
Simpify the S(Q) fraction sieving stuff.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3985
diff
changeset
|
128 } |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
129 |
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
130 return new Measurement(map, validSieves); |
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
131 } |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
132 }; |
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
133 |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
134 private MeasurementFactory() { |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
135 } |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
136 |
3290
36f3b53d5cfc
SQ relation: Added infrastructure to extract fractions from measurments.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3289
diff
changeset
|
137 protected static Measurements load( |
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
138 Session session, |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
139 String river, |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
140 double location, |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
141 DateRange dateRange |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
142 ) { |
3308
5ccd51ca11ce
SQ relation: Fixed problem with string operation precedence.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3292
diff
changeset
|
143 boolean debug = log.isDebugEnabled(); |
5ccd51ca11ce
SQ relation: Fixed problem with string operation precedence.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3292
diff
changeset
|
144 |
5ccd51ca11ce
SQ relation: Fixed problem with string operation precedence.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3292
diff
changeset
|
145 if (debug) { |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
146 log.debug(SQL_FACTIONS); |
3308
5ccd51ca11ce
SQ relation: Fixed problem with string operation precedence.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3292
diff
changeset
|
147 } |
5ccd51ca11ce
SQ relation: Fixed problem with string operation precedence.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3292
diff
changeset
|
148 |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
149 SQLQuery query = session.createSQLQuery(SQL_FACTIONS) |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
150 .addScalar("Q_BPEGEL", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
151 .addScalar("DATUM", StandardBasicTypes.DATE) |
3981
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
152 .addScalar("GLOTRECHTEID", StandardBasicTypes.INTEGER) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
153 .addScalar("LFDNR", StandardBasicTypes.INTEGER) |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
154 .addScalar("UFERABST", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
155 .addScalar("UFERABLINKS", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
156 .addScalar("TSCHWEB", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
157 .addScalar("TSAND", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
158 .addScalar("GTRIEB", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
159 .addScalar("TGESCHIEBE", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
160 .addScalar("RSIEB01", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
161 .addScalar("RSIEB02", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
162 .addScalar("RSIEB03", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
163 .addScalar("RSIEB04", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
164 .addScalar("RSIEB05", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
165 .addScalar("RSIEB06", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
166 .addScalar("RSIEB07", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
167 .addScalar("RSIEB08", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
168 .addScalar("RSIEB09", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
169 .addScalar("RSIEB10", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
170 .addScalar("RSIEB11", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
171 .addScalar("RSIEB12", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
172 .addScalar("RSIEB13", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
173 .addScalar("RSIEB14", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
174 .addScalar("RSIEB15", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
175 .addScalar("RSIEB16", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
176 .addScalar("RSIEB17", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
177 .addScalar("RSIEB18", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
178 .addScalar("RSIEB19", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
179 .addScalar("RSIEB20", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
180 .addScalar("RSIEB21", StandardBasicTypes.DOUBLE) |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
181 .addScalar("REST", StandardBasicTypes.DOUBLE) |
3981
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
182 .addScalar("SIEB01", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
183 .addScalar("SIEB02", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
184 .addScalar("SIEB03", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
185 .addScalar("SIEB04", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
186 .addScalar("SIEB05", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
187 .addScalar("SIEB06", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
188 .addScalar("SIEB07", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
189 .addScalar("SIEB08", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
190 .addScalar("SIEB09", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
191 .addScalar("SIEB10", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
192 .addScalar("SIEB11", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
193 .addScalar("SIEB12", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
194 .addScalar("SIEB13", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
195 .addScalar("SIEB14", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
196 .addScalar("SIEB15", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
197 .addScalar("SIEB16", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
198 .addScalar("SIEB17", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
199 .addScalar("SIEB18", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
200 .addScalar("SIEB19", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
201 .addScalar("SIEB20", StandardBasicTypes.DOUBLE) |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
202 .addScalar("SIEB21", StandardBasicTypes.DOUBLE); |
3292
e06036fdf0c7
SQ relation: add left joins to GSIEBSATZ and SSIEBUNG
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3291
diff
changeset
|
203 |
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
204 query.setString("river_name", river); |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
205 query.setDouble("location", location); |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
206 query.setDate("from", dateRange.getFrom()); |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
207 query.setDate("to", dateRange.getTo()); |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
208 |
4007
d4d272e56d3a
S(Q) Fixed AIOOBE
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4006
diff
changeset
|
209 query.setResultTransformer(FRACTIONS_TRANSFORMER); |
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
210 |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
211 @SuppressWarnings("unchecked") |
4006
d4e39cc5c10c
S(Q) relation: Removed unused field from SQL statement.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4005
diff
changeset
|
212 List<Measurement> measuments = (List<Measurement>)query.list(); |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
213 |
4001
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
214 List<Measurement> same = new ArrayList<Measurement>(); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
215 |
3981
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
216 Integer lastLR = null; |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
217 |
4001
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
218 List<Measurement> accumulated = new ArrayList<Measurement>(); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
219 |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
220 for (Measurement m: measuments) { |
3981
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
221 |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
222 Integer currentLR = (Integer)m.getData("GLOTRECHTEID"); |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
223 |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
224 boolean newDS = lastLR == null |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
225 || (currentLR != null && !lastLR.equals(currentLR)); |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
226 |
4001
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
227 if (newDS && !same.isEmpty()) { |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
228 accumulated.add(accumulate(same)); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
229 same.clear(); |
3981
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
230 } |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
231 |
6bcc50e2cc7d
More code for S(Q) relation.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3929
diff
changeset
|
232 lastLR = currentLR; |
3928
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
233 } |
d3e2080d3ada
S(Q) relation. Extract more values from database.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3922
diff
changeset
|
234 |
4001
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
235 if (!same.isEmpty()) { |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
236 accumulated.add(accumulate(same)); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
237 } |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
238 |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
239 for (Measurement m: accumulated) { |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
240 m.adjustSieves(); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
241 } |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
242 |
4005
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
243 return new Measurements(measuments, separateByDate(accumulated)); |
4001
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
244 } |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
245 |
4004
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
246 protected static List<Measurement> separateByDate(List<Measurement> measurements) { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
247 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
248 List<Measurement> result = new ArrayList<Measurement>(); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
249 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
250 List<Measurement> same = new ArrayList<Measurement>(); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
251 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
252 Date lastDate = null; |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
253 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
254 for (Measurement m: measurements) { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
255 Date currentDate = (Date)m.getData("DATUM"); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
256 if ((lastDate == null |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
257 || !equalDate(currentDate, lastDate)) |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
258 && !same.isEmpty() |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
259 ) { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
260 result.add(processSameDate(same)); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
261 same.clear(); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
262 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
263 same.add(m); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
264 lastDate = currentDate; |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
265 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
266 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
267 if (!same.isEmpty()) { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
268 result.add(processSameDate(same)); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
269 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
270 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
271 return result; |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
272 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
273 |
4005
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
274 |
4004
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
275 protected static Measurement processSameDate(List<Measurement> measurements) { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
276 int N = measurements.size(); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
277 if (N == 1) { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
278 Measurement current = measurements.get(0); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
279 double left = current.get("UFERABLINKS"); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
280 double right = current.get("UFERABST"); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
281 current.set("EFFWIDTH", left + right); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
282 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
283 else { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
284 for (int i = 0; i < N; ++i) { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
285 Measurement current = measurements.get(i); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
286 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
287 if (i == 0) { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
288 Measurement next = measurements.get(i+1); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
289 double distCurrent = current.get("UFERABST"); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
290 double distNext = next.get("UFERABST"); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
291 current.set("EFFWIDTH", distNext - distCurrent); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
292 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
293 else if (i == N-1) { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
294 Measurement prev = measurements.get(i-1); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
295 double distCurrent = current.get("UFERABST"); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
296 double distPrev = prev.get("UFERABST"); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
297 current.set("EFFWIDTH", distCurrent - distPrev); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
298 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
299 else { |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
300 Measurement prev = measurements.get(i-1); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
301 Measurement next = measurements.get(i+1); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
302 double distPrev = prev.get("UFERABST"); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
303 double distNext = next.get("UFERABST"); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
304 current.set("EFFWIDTH", 0.5*(distNext - distPrev)); |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
305 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
306 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
307 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
308 |
4005
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
309 double sumSandF = 0d; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
310 double sumCoarseF = 0d; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
311 double sumGravelF = 0d; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
312 double sumNorm = 0d; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
313 |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
314 for (Measurement m: measurements) { |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
315 SieveArray sa = m.getSieveArray(); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
316 double sandF = sa.sandNormFraction(); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
317 double coarseF = sa.coarseNormFraction(); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
318 double gravelF = sa.gravelNormFraction(); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
319 double effWidth = m.get("EFFWIDTH"); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
320 double gt = m.get("GTRIEB"); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
321 double scale = effWidth*gt; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
322 sumSandF += scale*sandF; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
323 sumCoarseF += scale*coarseF; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
324 sumGravelF += scale*gravelF; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
325 sumNorm += scale; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
326 } |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
327 |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
328 Map<String, Object> data = |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
329 new HashMap<String, Object>(measurements.get(0).getData()); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
330 |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
331 Measurement m = new Measurement(data, Collections.<Sieve>emptyList()); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
332 |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
333 sumNorm = 1d/sumNorm; |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
334 |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
335 m.set("BL_S", sumNorm*sumSandF); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
336 m.set("BL_G", sumNorm*sumGravelF); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
337 m.set("BL_C", sumNorm*sumCoarseF); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
338 |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
339 return m; |
4004
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
340 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
341 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
342 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
343 private static final boolean equalDate(Date a, Date b) { |
4005
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
344 Calendar ca = Calendar.getInstance(); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
345 Calendar cb = Calendar.getInstance(); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
346 ca.setTime(a); |
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
347 cb.setTime(b); |
4006
d4e39cc5c10c
S(Q) relation: Removed unused field from SQL statement.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4005
diff
changeset
|
348 return ca.get(Calendar.YEAR) == cb.get(Calendar.YEAR) |
d4e39cc5c10c
S(Q) relation: Removed unused field from SQL statement.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4005
diff
changeset
|
349 && ca.get(Calendar.MONTH) == cb.get(Calendar.MONTH) |
4005
22abdc45869c
Calculate S(Q) fractions
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4004
diff
changeset
|
350 && ca.get(Calendar.DAY_OF_MONTH) == cb.get(Calendar.DAY_OF_MONTH); |
4004
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
351 } |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
352 |
3b79e8afca7e
S(Q) calculate effective width
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4001
diff
changeset
|
353 |
4001
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
354 protected static Measurement accumulate(List<Measurement> measuments) { |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
355 |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
356 int N = measuments.size(); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
357 if (N == 1) { |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
358 return measuments.get(0); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
359 } |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
360 |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
361 TreeMap<Double, double []> diameters = |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
362 new TreeMap<Double, double []>(Sieve.DIAMETER_CMP); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
363 |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
364 for (Measurement m: measuments) { |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
365 for (Sieve s: m.getSieves()) { |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
366 Double key = s.getDiameter(); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
367 double [] sum = diameters.get(key); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
368 if (sum == null) { |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
369 sum = new double[1]; |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
370 diameters.put(key, sum); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
371 } |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
372 sum[0] += s.getLoad(); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
373 } |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
374 } |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
375 List<Sieve> accumulatedSieves = new ArrayList<Sieve>(diameters.size()); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
376 for (Map.Entry<Double, double []> entry: diameters.entrySet()) { |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
377 accumulatedSieves.add( |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
378 new Sieve(entry.getKey(), |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
379 entry.getValue()[0]/N)); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
380 } |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
381 |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
382 Map<String, Object> data = |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
383 new HashMap<String, Object>(measuments.get(0).getData()); |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
384 |
ab3a4ad82ae1
S(Q) accumulated same diameter meassurements per bank distance.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3992
diff
changeset
|
385 return new Measurement(data, accumulatedSieves); |
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
386 } |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
387 |
3290
36f3b53d5cfc
SQ relation: Added infrastructure to extract fractions from measurments.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3289
diff
changeset
|
388 public static Measurements getMeasurements( |
3289
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
389 String river, |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
390 double location, |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
391 DateRange dateRange |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
392 ) { |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
393 Session session = SedDBSessionHolder.HOLDER.get(); |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
394 try { |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
395 return load(session, river, location, dateRange); |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
396 } |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
397 finally { |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
398 session.close(); |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
399 } |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
400 } |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
401 } |
ec9aab93f292
SQ: First peek into fetching relevant data from SedDB
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
diff
changeset
|
402 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 : |