view artifacts/src/main/java/org/dive4elements/river/artifacts/model/minfo/BedQualityInterpolFacet.java @ 8750:69b0a71b4845

(issue1448) Make sq time intervals distinct only for non epoch loads Previously it was random if the loads choosen to be part of the distinct sq time interval loads set were epoch loads or not. This led to wrong results beeing removed in the isEpoch check afterwards.
author Andre Heinecke <andre.heinecke@intevation.de>
date Fri, 19 Jun 2015 16:35:13 +0200
parents 4b00ee858964
children 5e38e2924c07
line wrap: on
line source
/* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
 * Software engineering by Intevation GmbH
 *
 * This file is Free Software under the GNU AGPL (>=v3)
 * and comes with ABSOLUTELY NO WARRANTY! Check out the
 * documentation coming with Dive4Elements River for details.
 */

package org.dive4elements.river.artifacts.model.minfo;

import org.apache.log4j.Logger;

import org.dive4elements.artifactdatabase.state.Facet;
import org.dive4elements.artifacts.Artifact;
import org.dive4elements.artifacts.CallContext;
import org.dive4elements.river.artifacts.D4EArtifact;
import org.dive4elements.river.artifacts.model.CalculationResult;
import org.dive4elements.river.artifacts.model.DataFacet;
import org.dive4elements.river.artifacts.states.DefaultState.ComputeType;
import org.dive4elements.river.artifacts.access.RangeAccess;


/**
 * Facet for serving interpolated BedQualityResults
 */
public class BedQualityInterpolFacet extends DataFacet {

    private static final long serialVersionUID = 1L;

    private static Logger log = Logger.getLogger(BedQualityInterpolFacet.class);

    private String valueName; /* Name of the ResultValue underlying this facet */
    private String valueType; /* Type of the ResultValue underlying this facet */

    public BedQualityInterpolFacet() {
        // required for clone operation deepCopy()
    }

    public BedQualityInterpolFacet(int idx, String name, String description,
        ComputeType type, String stateId, String hash, String valueName, String valueType) {
        super(idx, name, description, type, hash, stateId);
        this.valueName = valueName;
        this.valueType = valueType;
        this.metaData.put("X", "chart.longitudinal.section.xaxis.label");
        if (!valueName.equals("porosity") && !valueName.equals("density")) {
            this.metaData.put("Y", "chart.bedquality.yaxis.label.diameter");
        } else {
            this.metaData.put("Y", "chart.bedquality.yaxis.label." + valueName);
        }
    }

    @Override
    public Object getData(Artifact artifact, CallContext context) {
        log.debug("Get bedquality data: " + valueName + " - " + valueType);

        D4EArtifact flys = (D4EArtifact) artifact;
        double[] kms = new RangeAccess(flys).getKmSteps();

        CalculationResult res = (CalculationResult) flys.compute(context, hash,
            stateId, type, false);

        int ndx = index >> 8;

        BedQualityResultValue value =
            ((BedQualityResult[]) res.getData())[ndx].getValue(valueName, valueType);

        if (value == null) {
            /* Other facets check this so we do too */
            return null;
        }
        return value.getDataInterpolated(kms);
    }

    /** Copy deeply. */
    @Override
    public Facet deepCopy() {
        BedQualityInterpolFacet copy = new BedQualityInterpolFacet();
        copy.set(this);
        copy.type = type;
        copy.hash = hash;
        copy.stateId = stateId;
        copy.valueName = valueName;
        copy.valueType = valueType;
        return copy;
    }
}

http://dive4elements.wald.intevation.org