Mercurial > dive4elements > river
annotate flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/fixation/FixationCompute.java @ 3035:b388d888330d
Implemented facets and splitted up the event facet.Implemented facets and splitted up the event facet.
flys-artifacts/trunk@4604 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Raimund Renkert <raimund.renkert@intevation.de> |
---|---|
date | Wed, 06 Jun 2012 11:35:32 +0000 |
parents | 77b5f5a26700 |
children | 22da13d1b180 |
rev | line source |
---|---|
2651
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
1 package de.intevation.flys.artifacts.states.fixation; |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
2 |
2784
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
3 import de.intevation.artifactdatabase.state.Facet; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
4 |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
5 import de.intevation.artifacts.CallContext; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
6 |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
7 import de.intevation.flys.artifacts.FLYSArtifact; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
8 import de.intevation.flys.artifacts.FixationArtifactAccess; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
9 |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
10 import de.intevation.flys.artifacts.model.CalculationResult; |
2992
0abdede5a0b8
FixA: Added facet to return delta w/t as CSV
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2784
diff
changeset
|
11 import de.intevation.flys.artifacts.model.DataFacet; |
0abdede5a0b8
FixA: Added facet to return delta w/t as CSV
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2784
diff
changeset
|
12 import de.intevation.flys.artifacts.model.FacetTypes; |
2784
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
13 import de.intevation.flys.artifacts.model.ReportFacet; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
14 |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
15 import de.intevation.flys.artifacts.model.fixings.FixCalculation; |
2651
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
16 |
3028
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
17 import de.intevation.flys.artifacts.model.fixings.FixAvSectorFacet; |
3035
b388d888330d
Implemented facets and splitted up the event facet.Implemented facets and splitted up the event facet.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
3028
diff
changeset
|
18 import de.intevation.flys.artifacts.model.fixings.FixAnalysisEventsFacet; |
b388d888330d
Implemented facets and splitted up the event facet.Implemented facets and splitted up the event facet.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
3028
diff
changeset
|
19 import de.intevation.flys.artifacts.model.fixings.FixReferenceEventsFacet; |
3028
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
20 import de.intevation.flys.artifacts.model.fixings.FixOutlierFacet; |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
21 import de.intevation.flys.artifacts.model.fixings.FixWQCurveFacet; |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
22 |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
23 |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
24 import de.intevation.flys.artifacts.model.fixings.DateRange; |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
25 |
2651
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
26 import de.intevation.flys.artifacts.states.DefaultState; |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
27 |
2784
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
28 import java.util.List; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
29 |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
30 import org.apache.log4j.Logger; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
31 |
2651
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
32 /** |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
33 * @author <a href="mailto:raimund.renkert@intevation.de">Raimund Renkert</a> |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
34 */ |
2992
0abdede5a0b8
FixA: Added facet to return delta w/t as CSV
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2784
diff
changeset
|
35 public class FixationCompute |
0abdede5a0b8
FixA: Added facet to return delta w/t as CSV
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2784
diff
changeset
|
36 extends DefaultState |
0abdede5a0b8
FixA: Added facet to return delta w/t as CSV
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2784
diff
changeset
|
37 implements FacetTypes |
0abdede5a0b8
FixA: Added facet to return delta w/t as CSV
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2784
diff
changeset
|
38 { |
2651
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
39 |
2784
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
40 /** The log used in this class. */ |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
41 private static Logger log = Logger.getLogger(FixationCompute.class); |
2651
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
42 |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
43 |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
44 /** |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
45 * The default constructor that initializes an empty State object. |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
46 */ |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
47 public FixationCompute() { |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
48 } |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
49 |
2784
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
50 @Override |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
51 public Object computeAdvance( |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
52 FLYSArtifact artifact, |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
53 String hash, |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
54 CallContext context, |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
55 List<Facet> facets, |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
56 Object old |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
57 ) { |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
58 log.debug("FixationCompute.computeAdvance"); |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
59 |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
60 CalculationResult res; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
61 |
3028
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
62 FixationArtifactAccess access = |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
63 new FixationArtifactAccess(artifact); |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
64 |
2784
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
65 if (old instanceof CalculationResult) { |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
66 res = (CalculationResult)old; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
67 } |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
68 else { |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
69 FixCalculation calc = |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
70 new FixCalculation(access); |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
71 |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
72 res = calc.calculate(); |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
73 } |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
74 |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
75 if (facets == null) { |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
76 return res; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
77 } |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
78 |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
79 if (res.getReport().hasProblems()) { |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
80 facets.add(new ReportFacet(ComputeType.ADVANCE, hash, id)); |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
81 } |
2992
0abdede5a0b8
FixA: Added facet to return delta w/t as CSV
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2784
diff
changeset
|
82 facets.add( |
0abdede5a0b8
FixA: Added facet to return delta w/t as CSV
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2784
diff
changeset
|
83 new DataFacet(CSV, "CSV data", ComputeType.ADVANCE, hash, id)); |
2784
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
84 |
3028
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
85 int count = access.getAnalysisPeriods().length; |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
86 for (int i = 0; i < count; i++) { |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
87 DateRange period = access.getAnalysisPeriods()[i]; |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
88 for (int j = access.getQSectorStart().intValue(); |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
89 j < access.getQSectorEnd().intValue(); |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
90 j++) { |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
91 //TODO: replace j with q sector string. |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
92 String description = j + ": " + |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
93 period.getFrom().toString() + " - " + |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
94 period.getTo().toString(); |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
95 facets.add( |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
96 new FixAvSectorFacet(j - access.getQSectorStart().intValue(), |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
97 description)); |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
98 } |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
99 String eventDesc = period.getFrom().toString() + |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
100 " - " + |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
101 period.getTo().toString(); |
3035
b388d888330d
Implemented facets and splitted up the event facet.Implemented facets and splitted up the event facet.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
3028
diff
changeset
|
102 facets.add(new FixAnalysisEventsFacet(i, eventDesc)); |
3028
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
103 } |
3035
b388d888330d
Implemented facets and splitted up the event facet.Implemented facets and splitted up the event facet.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
3028
diff
changeset
|
104 facets.add(new FixReferenceEventsFacet(0, "Referenceperiod")); |
3028
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
105 facets.add(new FixWQCurveFacet("W/Q")); |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
106 facets.add(new FixOutlierFacet("Outlier")); |
77b5f5a26700
Added facets for fix analysis.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2992
diff
changeset
|
107 |
2784
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
108 return res; |
156214e3ca55
FixA: Call computing when reaching the compute state.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2699
diff
changeset
|
109 } |
2651
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
110 } |
9e9eb9d97548
Initial transition configuration and artifact/state stubs for fixation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
111 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 : |