changeset 3079:8ad8a227d983

Added model classes for SQ calculation; generate fake results and improved the SQRelationGenerator which now draws the outliers. flys-artifacts/trunk@4675 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Ingo Weinzierl <ingo.weinzierl@intevation.de>
date Fri, 15 Jun 2012 12:23:08 +0000
parents 0e0efd1acb4f
children dc2765e31e1f
files flys-artifacts/ChangeLog flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQ.java flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQOutlierFacet.java flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQRelationCalculation.java flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQResult.java flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/SQRelation.java flys-artifacts/src/main/java/de/intevation/flys/exports/XYChartGenerator.java flys-artifacts/src/main/java/de/intevation/flys/exports/sq/SQRelationGenerator.java
diffstat 8 files changed, 278 insertions(+), 61 deletions(-) [+]
line wrap: on
line diff
--- a/flys-artifacts/ChangeLog	Fri Jun 15 12:16:49 2012 +0000
+++ b/flys-artifacts/ChangeLog	Fri Jun 15 12:23:08 2012 +0000
@@ -1,3 +1,29 @@
+2012-06-15  Ingo Weinzierl <ingo@intevation.de>
+
+	* src/main/java/de/intevation/flys/artifacts/model/sq/SQ.java: New model to
+	  store values for S/Q.
+
+	* src/main/java/de/intevation/flys/artifacts/model/sq/SQResult.java: New
+	  model class that should be used to store calculation results of SQ
+	  relation.
+
+	* src/main/java/de/intevation/flys/artifacts/model/sq/SQRelationCalculation.java:
+	  Create a fake SQResult.
+
+	* src/main/java/de/intevation/flys/artifacts/model/sq/SQOutlierFacet.java:
+	  Set missing required properties, so that this facet will be able to
+	  re-calculate results again if the results are not in cache.
+
+	* src/main/java/de/intevation/flys/artifacts/states/SQRelation.java: 
+	  Create correct number of facets for parameter A for outliers Facet.
+
+	* src/main/java/de/intevation/flys/exports/sq/SQRelationGenerator.java:
+	  Create a JFreeChart XYSeries from SQResult's outliers Facet.
+
+	* src/main/java/de/intevation/flys/exports/XYChartGenerator.java: Added a
+	  method to create X axes. The SQRelationGenerator overrides this method,
+	  because it requires a logarithmic axis.
+
 2012-06-15  Raimund Renkert <raimund.renkert@intevation.de>
 
 	* src/main/java/de/intevation/flys/exports/ChartGenerator.java:
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQ.java	Fri Jun 15 12:23:08 2012 +0000
@@ -0,0 +1,37 @@
+package de.intevation.flys.artifacts.model.sq;
+
+import java.io.Serializable;
+
+
+public class SQ implements Serializable {
+
+    protected double s;
+    protected double q;
+
+    public SQ() {
+    }
+
+    public SQ(double s, double q) {
+        this.s = s;
+        this.q = q;
+    }
+
+
+    public double getS() {
+        return s;
+    }
+
+    public void setS(double s) {
+        this.s = s;
+    }
+
+
+    public double getQ() {
+        return q;
+    }
+
+    public void setQ(double q) {
+        this.q = q;
+    }
+}
+// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQOutlierFacet.java	Fri Jun 15 12:16:49 2012 +0000
+++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQOutlierFacet.java	Fri Jun 15 12:23:08 2012 +0000
@@ -6,8 +6,10 @@
 import de.intevation.artifacts.CallContext;
 
 
+import de.intevation.flys.artifacts.FLYSArtifact;
+import de.intevation.flys.artifacts.model.CalculationResult;
+import de.intevation.flys.artifacts.model.DataFacet;
 import de.intevation.flys.artifacts.model.FacetTypes;
-import de.intevation.flys.artifacts.model.DataFacet;
 
 import de.intevation.flys.artifacts.states.DefaultState.ComputeType;
 
@@ -22,19 +24,39 @@
     private static final Logger log = Logger.getLogger(SQOutlierFacet.class);
 
 
+    private int iteration;
+
+
     public SQOutlierFacet() {
     }
 
 
-    public SQOutlierFacet(int idx, String name, String description) {
-        super(idx, name, description, ComputeType.ADVANCE, null, null);
+    public SQOutlierFacet(
+        int    idx,
+        int    iteration,
+        String name,
+        String description,
+        String hash,
+        String stateId
+    ) {
+        super(idx, name, description, ComputeType.ADVANCE, hash, stateId);
     }
 
 
     @Override
     public Object getData(Artifact artifact, CallContext context) {
         log.debug("SQOutlierFacet.getData");
-        log.error("NOT IMPLEMENTED!");
+
+        if (artifact instanceof FLYSArtifact) {
+            FLYSArtifact flys = (FLYSArtifact) artifact;
+
+            CalculationResult res = (CalculationResult) flys.compute(
+                context, ComputeType.ADVANCE, false);
+
+            SQResult[] result = (SQResult[]) res.getData();
+
+            return result[index].getOutliers(iteration);
+        }
 
         return null;
     }
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQRelationCalculation.java	Fri Jun 15 12:16:49 2012 +0000
+++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQRelationCalculation.java	Fri Jun 15 12:23:08 2012 +0000
@@ -1,5 +1,8 @@
 package de.intevation.flys.artifacts.model.sq;
 
+import java.util.ArrayList;
+import java.util.List;
+
 import org.apache.log4j.Logger;
 
 import de.intevation.flys.artifacts.model.Calculation;
@@ -27,10 +30,70 @@
         // TODO Insert input params here
     ) {
         logger.info("SQRelationCalculation.buildCalculationResult");
-
         logger.error("Not implemented!");
 
-        return new CalculationResult(new Object[0], this);
+        SQResult[] result = getFakeResult();
+
+        return new CalculationResult(result, this);
+    }
+
+
+    protected SQResult[] getFakeResult() {
+
+        SQ[] measurements = getFakeMeasurements();
+        SQ[] fOutliers    = getFakeOutliers(10);
+        SQ[] tOutliers    = getFakeOutliers(20);
+
+        List<SQ[]> outliers = new ArrayList<SQ[]>();
+        outliers.add(fOutliers);
+        outliers.add(tOutliers);
+
+        return new SQResult[] { new SQResult(null, measurements, outliers) };
+    }
+
+    protected SQ[] getFakeMeasurements() {
+        List<SQ> a = new ArrayList<SQ>();
+
+        a.add(new SQ(11.172500000000001, 1250.0));
+        a.add(new SQ(13.407000000000002, 1500.0));
+        a.add(new SQ(15.641500000000002, 1750.0));
+        a.add(new SQ(17.876000000000005, 2000.0));
+        a.add(new SQ(20.110500000000005, 2250.0));
+        a.add(new SQ(22.345000000000002, 2500.0));
+        a.add(new SQ(24.579500000000003, 2750.0));
+        a.add(new SQ(26.814000000000004, 3000.0));
+        a.add(new SQ(29.048500000000004, 3250.0));
+        a.add(new SQ(31.283000000000005, 3500.0));
+        a.add(new SQ(33.517500000000005, 3750.0));
+        a.add(new SQ(35.75200000000001, 4000.0));
+        a.add(new SQ(37.98650000000001, 4250.0));
+        a.add(new SQ(40.22100000000001, 4500.0));
+        a.add(new SQ(42.45550000000001, 4750.0));
+
+        return (SQ[]) a.toArray(new SQ[a.size()]);
+    }
+
+
+    protected SQ[] getFakeOutliers(int diff) {
+        List<SQ> a = new ArrayList<SQ>();
+
+        a.add(new SQ(11.172500000000001-diff, 1250.0));
+        a.add(new SQ(13.407000000000002+diff, 1500.0));
+        a.add(new SQ(25.641500000000002-diff, 1750.0));
+        a.add(new SQ(17.876000000000005+diff, 2000.0));
+        a.add(new SQ(20.110500000000005-diff, 2250.0));
+        a.add(new SQ(22.345000000000002+diff, 2500.0));
+        a.add(new SQ(24.579500000000003-diff, 2750.0));
+        a.add(new SQ(26.814000000000004+diff, 3000.0));
+        a.add(new SQ(29.048500000000004-diff, 3250.0));
+        a.add(new SQ(31.283000000000005+diff, 3500.0));
+        a.add(new SQ(33.517500000000005-diff, 3750.0));
+        a.add(new SQ(35.75200000000001-diff, 4000.0));
+        a.add(new SQ(37.98650000000001+diff, 4250.0));
+        a.add(new SQ(40.22100000000001+diff, 4500.0));
+        a.add(new SQ(42.45550000000001+diff, 4750.0));
+
+        return (SQ[]) a.toArray(new SQ[a.size()]);
     }
 }
 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/sq/SQResult.java	Fri Jun 15 12:23:08 2012 +0000
@@ -0,0 +1,78 @@
+package de.intevation.flys.artifacts.model.sq;
+
+import java.io.Serializable;
+import java.util.ArrayList;
+import java.util.List;
+
+import de.intevation.flys.artifacts.model.Parameters;
+
+
+public class SQResult implements Serializable {
+
+    protected Parameters parameters;
+
+    protected SQ[] measurements;
+    protected List<SQ[]> outliers;
+
+
+    public SQResult() {
+        this.outliers = new ArrayList<SQ[]>();
+    }
+
+
+    public SQResult(
+        Parameters parameters,
+        SQ[]       measurements,
+        List<SQ[]> outliers
+    ) {
+        this.parameters   = parameters;
+        this.measurements = measurements;
+        this.outliers     = outliers;
+    }
+
+
+    public Parameters getParameters() {
+        return parameters;
+    }
+
+    public void setParameters(Parameters parameters) {
+        this.parameters = parameters;
+    }
+
+
+    public SQ[] getMeasurements() {
+        return measurements;
+    }
+
+    public void setMeasurements(SQ[] measurements) {
+        this.measurements = measurements;
+    }
+
+
+    public List<SQ[]> getOutliers() {
+        return outliers;
+    }
+
+    public void setOutliers(List<SQ[]> outliers) {
+        this.outliers = outliers;
+    }
+
+
+    public int getOutliersCount() {
+        return outliers.size();
+    }
+
+
+    public SQ[] getOutliers(int idx) {
+        if (idx < outliers.size()) {
+            return outliers.get(idx);
+        }
+
+        return null;
+    }
+
+    public void addOutliers(SQ[] outliers) {
+        this.outliers.add(outliers);
+    }
+}
+// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/SQRelation.java	Fri Jun 15 12:16:49 2012 +0000
+++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/SQRelation.java	Fri Jun 15 12:23:08 2012 +0000
@@ -18,6 +18,7 @@
 import de.intevation.flys.artifacts.model.sq.SQMeasurementFacet;
 import de.intevation.flys.artifacts.model.sq.SQOutlierFacet;
 import de.intevation.flys.artifacts.model.sq.SQRelationCalculation;
+import de.intevation.flys.artifacts.model.sq.SQResult;
 import de.intevation.flys.artifacts.states.DefaultState;
 
 /**
@@ -52,12 +53,8 @@
             return res;
         }
 
-        logger.error("Facet creation NOT IMPLEMENTED!");
-        // TODO
-        //for (int idx = 0; idx < res.length; idx++) {
-            int idx = 0;
-            createFacets(newFacets, idx);
-        //}
+        SQResult[] sqr = (SQResult[]) res.getData();
+        createFacets(newFacets, sqr, hash);
 
         Facet csv = new DataFacet(
             CSV, "CSV data", ComputeType.ADVANCE, hash, id);
@@ -76,56 +73,25 @@
     }
 
 
-    protected void createFacets(List<Facet> container, int idx) {
+    protected void createFacets(
+        List<Facet> container,
+        SQResult[]  sqr,
+        String      hash
+    ) {
         // TODO Create facets for each parameter type (A-F)
-        Facet measurements, outliers, curve;
-        measurements = new SQMeasurementFacet(idx, SQ_A_MEASUREMENT, "TODO");
-        outliers     = new SQOutlierFacet(idx, SQ_A_OUTLIER, "TODO");
-        curve        = new SQCurveFacet(idx, SQ_A_CURVE, "TODO");
-
-        container.add(measurements);
-        container.add(outliers);
-        container.add(curve);
-
-        measurements = new SQMeasurementFacet(idx, SQ_B_MEASUREMENT, "TODO");
-        outliers     = new SQOutlierFacet(idx, SQ_B_OUTLIER, "TODO");
-        curve        = new SQCurveFacet(idx, SQ_B_CURVE, "TODO");
-
-        container.add(measurements);
-        container.add(outliers);
-        container.add(curve);
-
-        measurements = new SQMeasurementFacet(idx, SQ_C_MEASUREMENT, "TODO");
-        outliers     = new SQOutlierFacet(idx, SQ_C_OUTLIER, "TODO");
-        curve        = new SQCurveFacet(idx, SQ_C_CURVE, "TODO");
+        container.add(new SQMeasurementFacet(0, SQ_A_MEASUREMENT, "TODO"));
+        container.add(new SQCurveFacet(0, SQ_A_CURVE, "TODO"));
 
-        container.add(measurements);
-        container.add(outliers);
-        container.add(curve);
-
-        measurements = new SQMeasurementFacet(idx, SQ_D_MEASUREMENT, "TODO");
-        outliers     = new SQOutlierFacet(idx, SQ_D_OUTLIER, "TODO");
-        curve        = new SQCurveFacet(idx, SQ_D_CURVE, "TODO");
-
-        container.add(measurements);
-        container.add(outliers);
-        container.add(curve);
-
-        measurements = new SQMeasurementFacet(idx, SQ_E_MEASUREMENT, "TODO");
-        outliers     = new SQOutlierFacet(idx, SQ_E_OUTLIER, "TODO");
-        curve        = new SQCurveFacet(idx, SQ_E_CURVE, "TODO");
-
-        container.add(measurements);
-        container.add(outliers);
-        container.add(curve);
-
-        measurements = new SQMeasurementFacet(idx, SQ_F_MEASUREMENT, "TODO");
-        outliers     = new SQOutlierFacet(idx, SQ_F_OUTLIER, "TODO");
-        curve        = new SQCurveFacet(idx, SQ_F_CURVE, "TODO");
-
-        container.add(measurements);
-        container.add(outliers);
-        container.add(curve);
+        for (int i = 0; i < sqr[0].getOutliersCount(); i++) {
+            container.add(new SQOutlierFacet(
+                0,
+                i,
+                SQ_A_OUTLIER,
+                "OUTLIER AT" + i,
+                getID(),
+                hash
+            ));
+        }
     }
 }
 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :
--- a/flys-artifacts/src/main/java/de/intevation/flys/exports/XYChartGenerator.java	Fri Jun 15 12:16:49 2012 +0000
+++ b/flys-artifacts/src/main/java/de/intevation/flys/exports/XYChartGenerator.java	Fri Jun 15 12:23:08 2012 +0000
@@ -227,6 +227,8 @@
             false);
 
         XYPlot plot = (XYPlot) chart.getPlot();
+        plot.setDomainAxis(createXAxis(getXAxisLabel()));
+
         chart.setBackgroundPaint(Color.WHITE);
         plot.setBackgroundPaint(Color.WHITE);
         addSubtitles(chart);
@@ -258,6 +260,11 @@
     }
 
 
+    protected NumberAxis createXAxis(String label) {
+        return new NumberAxis(label);
+    }
+
+
     @Override
     protected Series getSeriesOf(XYDataset dataset, int idx) {
         return ((XYSeriesCollection) dataset).getSeries(idx);
--- a/flys-artifacts/src/main/java/de/intevation/flys/exports/sq/SQRelationGenerator.java	Fri Jun 15 12:16:49 2012 +0000
+++ b/flys-artifacts/src/main/java/de/intevation/flys/exports/sq/SQRelationGenerator.java	Fri Jun 15 12:23:08 2012 +0000
@@ -4,6 +4,7 @@
 
 import org.jfree.chart.axis.LogarithmicAxis;
 import org.jfree.chart.axis.NumberAxis;
+import org.jfree.data.xy.XYSeries;
 
 import org.w3c.dom.Document;
 
@@ -11,7 +12,9 @@
 import de.intevation.artifactdatabase.state.Facet;
 
 import de.intevation.flys.artifacts.model.FacetTypes;
+import de.intevation.flys.artifacts.model.sq.SQ;
 import de.intevation.flys.exports.XYChartGenerator;
+import de.intevation.flys.jfree.StyledXYSeries;
 
 /**
  * An OutGenerator that generates charts for MINFO sq relation.
@@ -70,6 +73,12 @@
 
 
     @Override
+    protected NumberAxis createXAxis(String label) {
+        return new LogarithmicAxis(label);
+    }
+
+
+    @Override
     protected NumberAxis createYAxis(int index) {
         return new LogarithmicAxis("TODO: LABEL " + index);
     }
@@ -129,7 +138,16 @@
         boolean          visible
     ) {
         logger.debug("doSQOutliersOut");
-        logger.error("NOT IMPLEMENTED: doSQOutliersOut");
+
+        Facet    f      = artifactAndFacet.getFacet();
+        SQ[]     sqs    = (SQ[]) artifactAndFacet.getData(context);
+        XYSeries series = new StyledXYSeries(f.getDescription(), attr);
+
+        for (SQ sq: sqs) {
+            series.add(sq.getQ(), sq.getS());
+        }
+
+        addAxisSeries(series, YAXIS.S.idx, visible);
     }
 }
 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org