view artifacts/src/main/java/org/dive4elements/river/artifacts/model/sq/Measurements.java @ 6780:b8f94e865875

S/Q relation: Part I of 'faking' fitting linear data. S/Qs can now be subclassed and processed through views. TODO: Add knob to setup a linear data path.
author Sascha L. Teichmann <teichmann@intevation.de>
date Thu, 08 Aug 2013 12:17:03 +0200
parents 876c797c2805
children e8283197d889
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.sq;

import java.util.ArrayList;
import java.util.List;

import org.apache.log4j.Logger;

public class Measurements
{
    private static final Logger log = Logger.getLogger(Measurements.class);

    public interface SExtractor {
        double getS(Measurement measument);
    } // interface SExtractor

    public static final SExtractor S_SF_EXTRACTOR = new SExtractor() {
        @Override
        public double getS(Measurement measument) {
            return measument.S_SF();
        }
    };

    public static final SExtractor S_SS_EXTRACTOR = new SExtractor() {
        @Override
        public double getS(Measurement measument) {
            return measument.S_SS();
        }
    };

    public static final SExtractor S_BL_S_EXTRACTOR = new SExtractor() {
        @Override
        public double getS(Measurement measument) {
            return measument.S_BL_S();
        }
    };

    public static final SExtractor S_BL_FG_EXTRACTOR = new SExtractor() {
        @Override
        public double getS(Measurement measument) {
            return measument.S_BL_FG();
        }
    };

    public static final SExtractor S_BL_CG_EXTRACTOR = new SExtractor() {
        @Override
        public double getS(Measurement measument) {
            return measument.S_BL_CG();
        }
    };

    public static final SExtractor S_BL_EXTRACTOR = new SExtractor() {
        @Override
        public double getS(Measurement measument) {
            return measument.S_BL_1();
        }
    };

    protected List<Measurement> measuments;
    protected List<Measurement> accumulated;

    protected SQ.Factory sqFactory;

    public Measurements() {
    }

    public Measurements(
        List<Measurement> measuments,
        List<Measurement> accumulated,
        SQ.Factory        sqFactory
    ) {
        this.sqFactory = sqFactory;
        if (log.isDebugEnabled()) {
            log.debug("number of measuments: " + measuments.size());
            log.debug("number of accumulated: " + accumulated.size());
        }
        this.measuments = measuments;
        this.accumulated = accumulated;
    }

    public List<SQ> extractSQ(
        List<Measurement> measuments,
        SExtractor extractor
    ) {
        List<SQ> result = new ArrayList<SQ>(measuments.size());
        int invalid = 0;
        for (Measurement measument: measuments) {
            SQ sq = sqFactory.createSQ(extractor.getS(measument), measument.Q());
            if (sq.isValid()) {
                result.add(sq);
            }
            else {
                ++invalid;
            }
        }
        if (log.isDebugEnabled()) {
            log.debug("Removed num invalid: " + invalid
                + " of " + measuments.size());
        }
        return result;
    }

    public List<SQ> S_SF() {
        return extractSQ(measuments, S_SF_EXTRACTOR);
    }

    public List<SQ> S_SS() {
        return extractSQ(measuments, S_SS_EXTRACTOR);
    }

    public List<SQ> S_BL_S() {
        return extractSQ(accumulated, S_BL_S_EXTRACTOR);
    }

    public List<SQ> S_BL_FG() {
        return extractSQ(accumulated, S_BL_FG_EXTRACTOR);
    }

    public List<SQ> S_BL_CG() {
        return extractSQ(accumulated, S_BL_CG_EXTRACTOR);
    }

    public List<SQ> S_BL() {
        return extractSQ(accumulated, S_BL_EXTRACTOR);
    }

    public List<SQ> getSQs(int index) {
        switch (index) {
            case 0: return S_SF();
            case 1: return S_SS();
            case 2: return S_BL_S();
            case 3: return S_BL_FG();
            case 4: return S_BL_CG();
            case 5: return S_BL();
        }
        log.error("THIS SHOULD NOT HAPPEN: Tried to access SQ[" + index + "]");
        return new ArrayList<SQ>(0);
    }

    /**
     * Gets the accumulated for this instance.
     *
     * @return The accumulated.
     */
    public List<Measurement> getAccumulated() {
        return this.accumulated;
    }

    /**
     * Sets the accumulated for this instance.
     *
     * @param accumulated The accumulated.
     */
    public void setAccumulated(List<Measurement> accumulated) {
        this.accumulated = accumulated;
    }


    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder("Measurements [");
        for (int i = 0, M = measuments.size(); i < M; ++i) {
            if (i > 0) sb.append(", ");
            sb.append(measuments.get(i));
        }
        return sb.append(']').toString();
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :

http://dive4elements.wald.intevation.org