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 :

http://dive4elements.wald.intevation.org