Mercurial > dive4elements > river
changeset 3051:49727e9dcfde
Polished Gauge Discharges in computed discharge curves.
flys-artifacts/trunk@4625 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Felix Wolfsteller <felix.wolfsteller@intevation.de> |
---|---|
date | Thu, 07 Jun 2012 20:47:17 +0000 (2012-06-07) |
parents | 02254d763bc0 |
children | acd89b7970dd |
files | flys-artifacts/ChangeLog flys-artifacts/doc/conf/meta-data.xml flys-artifacts/src/main/java/de/intevation/flys/artifacts/GaugeDischargeArtifact.java flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/GaugeDischargeState.java flys-artifacts/src/main/resources/messages.properties flys-artifacts/src/main/resources/messages_de_DE.properties flys-artifacts/src/main/resources/messages_en.properties |
diffstat | 7 files changed, 118 insertions(+), 77 deletions(-) [+] |
line wrap: on
line diff
--- a/flys-artifacts/ChangeLog Thu Jun 07 13:13:13 2012 +0000 +++ b/flys-artifacts/ChangeLog Thu Jun 07 20:47:17 2012 +0000 @@ -1,3 +1,17 @@ +2012-06-07 Felix Wolfsteller <felix.wolfsteller@intevation.de> + + * doc/conf/meta-data.xml: Simplified choice of gauges for discharge c. + + * src/main/java/de/intevation/flys/artifacts/GaugeDischargeArtifact.java, + src/main/java/de/intevation/flys/artifacts/states/GaugeDischargeState.java: + Create better name for facets, minor refactoring, polishing. + + * src/main/resources/messages.properties, + src/main/resources/messages_de_DE.properties, + src/main/resources/messages_en.properties, + src/main/resources/messages_de.properties: + Added i18n strings. + 2012-06-07 Felix Wolfsteller <felix.wolfsteller@intevation.de> * src/main/java/de/intevation/flys/artifacts/model/DischargeTables.java,
--- a/flys-artifacts/doc/conf/meta-data.xml Thu Jun 07 13:13:13 2012 +0000 +++ b/flys-artifacts/doc/conf/meta-data.xml Thu Jun 07 20:47:17 2012 +0000 @@ -616,6 +616,15 @@ <gauge> <dc:attribute name="name" value="${gauge_name}"/> <dc:attribute name="db-id" value="${gauge_id}"/> + <dc:attribute name="factory" value="gaugedischarge"/> + <dc:attribute name="from" value="${g_start}"/> + <dc:attribute name="to" value="${g_stop}"/> + <dc:attribute name="ids" value="${gauge_name}"/> + </gauge> + <!-- + <gauge> + <dc:attribute name="name" value="${gauge_name}"/> + <dc:attribute name="db-id" value="${gauge_id}"/> <dc:context> <dc:statement> SELECT description AS gauge_desc, @@ -637,6 +646,7 @@ </dc:elements> </dc:context> </gauge> + --> </dc:elements> </dc:context> </discharge_table_gauge>
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/GaugeDischargeArtifact.java Thu Jun 07 13:13:13 2012 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/GaugeDischargeArtifact.java Thu Jun 07 20:47:17 2012 +0000 @@ -69,9 +69,10 @@ Document data) { logger.debug("GaugeDischargeArtifact.setup"); + String ids = StaticFLYSArtifact.getDatacageIDValue(data); + addStringData("ids", ids); + logger.debug("id for gaugedischarge: " + ids); super.setup(identifier, factory, context, callMeta, data); - String ids = StaticFLYSArtifact.getDatacageIDValue(data); - logger.debug("id for gaugedischarge: " + ids); } @@ -81,12 +82,6 @@ } - /** Access state data storing the jsonstring with points. - public String getPointsData(String facetName) { - return getDataAsString(facetName + ".data"); - }*/ - - /** * Setup state and facet, copy from master artifact. */ @@ -98,10 +93,7 @@ importData(artifact, "river"); // Get the location(s) - //importData(artifact, "ld_mode"); - //importData(artifact, "ld_from"); - //importData(artifact, "ld_to"); - //importData(artifact, "ld_locations"); + //importData(artifact, "ld_mode", ld_from, ld_to, ld_locations addStringData("ld_from", "0"); addStringData("ld_to", "1000"); addStringData("ld_mode", "distance"); @@ -120,28 +112,22 @@ } - /** - * Determines Facets initial disposition regarding activity (think of - * selection in Client ThemeList GUI). This will be checked one time - * when the facet enters a collections describe document. - * - * @param facetName name of the facet. - * @param index index of the facet. - * @return 0 if not active - */ - @Override - public int getInitialFacetActivity( - String outputName, - String facetName, - int index) - { - return 1; + /** Get the Gauges name which came with datacage data-document. */ + public String getGaugeName() { + return this.getDataAsString("ids"); + } + + + /** Get the Gauges which came with datacage data-document. */ + public Gauge getGauge() { + River river = FLYSUtils.getRiver(this); + return river.determineGaugeByName(getGaugeName()); } /** * Returns the data that is used to create discharge curves. - * + * @return CalculationResult with WQKms. */ public CalculationResult getDischargeCurveData() { @@ -149,7 +135,8 @@ if (river == null) { return error(new WQKms[0], "no.river.selected"); } - + /* + // This one would allow to automatically pick the right Gauge. double [] distance = FLYSUtils.getKmRange(this); logger.debug("getDischargeCurveData: get range"); @@ -158,7 +145,7 @@ } List<Gauge> gauges = river.determineGauges(distance[0], distance[1]); - logger.debug("getDischargeCurveData: get gauges"); + logger.debug("getDischargeCurveData: got " + gauges.size() + " gauges"); if (gauges.isEmpty()) { return error(new WQKms[0], "no.gauge.selected"); @@ -170,29 +157,50 @@ names[i] = gauges.get(i).getName(); logger.debug("getDischargeCurveData: name " + names[i]); } + */ - DischargeTables dt = new DischargeTables(river.getName(), names); + DischargeTables dt = new DischargeTables(river.getName(), getDataAsString("ids")); - Map<String, double [][]> map = dt.getValues(100d); + Map<String, double [][]> map = dt.getValues(100); ArrayList<WQKms> res = new ArrayList<WQKms>(); - for (Gauge gauge: gauges) { - String name = gauge.getName(); - double [][] values = map.get(name); - if (values == null) { - continue; - } - double [] kms = new double[values[0].length]; - Arrays.fill(kms, gauge.getStation().doubleValue()); - res.add(new WQKms(kms, values[0], values[1], name)); - logger.debug("getDischargeCurveData: add one res gauge"); + Gauge gauge = river.determineGaugeByName(this.getDataAsString("ids")); + + String name = getGaugeName(); + double [][] values = map.get(name); + if (values == null) { + logger.error("No values for this gauge / discharge found."); } + for (int i = 0 ; i < values[0].length; i++) { + values[0][i] += gauge.getDatum().doubleValue(); + } + double [] kms = new double[values[0].length]; + Arrays.fill(kms, gauge.getStation().doubleValue()); + res.add(new WQKms(kms, values[0], values[1], name)); return new CalculationResult( res.toArray(new WQKms[res.size()]), new Calculation()); } + + /** + * Determines Facets initial disposition regarding activity (think of + * selection in Client ThemeList GUI). This will be checked one time + * when the facet enters a collections describe document. + * + * @param facetName name of the facet. + * @param index index of the facet. + * @return 1 - all Facets enter activated. + */ + @Override + public int getInitialFacetActivity( + String outputName, + String facetName, + int index) + { + return 1; + } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/GaugeDischargeState.java Thu Jun 07 13:13:13 2012 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/GaugeDischargeState.java Thu Jun 07 20:47:17 2012 +0000 @@ -23,6 +23,8 @@ import de.intevation.flys.artifacts.resources.Resources; import de.intevation.flys.utils.FLYSUtils; +import de.intevation.flys.model.Gauge; + /** * The only state for an GaugeDischargeState (River and km known). @@ -35,7 +37,33 @@ public static final String I18N_DESCRIPTION = "facet.discharge.curve"; /** The logger that is used in this state. */ - private static final Logger logger = Logger.getLogger(GaugeDischargeState.class); + private static final Logger logger = + Logger.getLogger(GaugeDischargeState.class); + + + /** + * Create i18ned name for gaugedischargeFacet. + * @param artifact The artifact which has information about the gauge. + * @param meta used for i18n. + * @return localized name for gaugedischargefacet. + */ + protected String createFacetName(GaugeDischargeArtifact artifact, + CallMeta meta) { + + Gauge gauge = artifact.getGauge(); + Object[] args = new Object[] { + gauge.getName(), + gauge.getStation() + }; + + String name = Resources.getMsg( + meta, + "chart.computed.discharge.curve.gauge", + "", + args); + + return name; + } /** @@ -59,20 +87,22 @@ ) { logger.debug("GaugeDischargeState.computeInit()"); - // TODO caching, / CalculationResultusage + // TODO caching, / CalculationResultUsage GaugeDischargeFacet facet = new GaugeDischargeFacet( 0, DISCHARGE_CURVE, - DISCHARGE_CURVE); - //Resources.getMsg(meta, I18N_DESCRIPTION, I18N_DESCRIPTION)); + createFacetName((GaugeDischargeArtifact) artifact, meta)); + facets.add(facet); return null; } - //WINFOArtifact#getDischargeCurveData + /** + * 'Calculate' Discharge at Gauge. + */ @Override public Object computeAdvance( FLYSArtifact artifact, @@ -81,8 +111,6 @@ List<Facet> facets, Object old ) { - // TODO why are the facets null here? - //if (facets == null) facets = new List<Facet>(); if (artifact instanceof GaugeDischargeArtifact) { logger.debug("GaugeDischargeState.computeAdvance()"); GaugeDischargeArtifact dischargeArtifact = (GaugeDischargeArtifact) artifact; @@ -100,33 +128,12 @@ if (wqkms != null && facets != null) { logger.debug("GaugeDischargeState.computeAdvance(): create facets"); - // Create an i18ed name for a (w or q) duration curve facet. - Object[] args = new Object[] { - FLYSUtils.getRiver(dischargeArtifact).getName(), - FLYSUtils.getLocations(dischargeArtifact)[0] - }; - String nameW = Resources.getMsg( - context.getMeta(), - "chart.duration.curve.curve.w", - "", - args); - - String nameQ = Resources.getMsg( - context.getMeta(), - "chart.duration.curve.curve.q", - "", - args); - - /*Facet w = new DurationCurveFacet(DURATION_W, nameW); - Facet q = new DurationCurveFacet(DURATION_Q, nameQ); - - facets.add(w);*/ GaugeDischargeFacet facet = new GaugeDischargeFacet( 0, - "A"+DISCHARGE_CURVE, - "A"+DISCHARGE_CURVE); - //Resources.getMsg(meta, I18N_DESCRIPTION, I18N_DESCRIPTION)); + DISCHARGE_CURVE, + createFacetName(dischargeArtifact, context.getMeta())); + facets.add(facet); //facets.add(new DataFacet(CSV, "CSV data")); @@ -138,9 +145,9 @@ } else { if (wqkms == null) - logger.debug("GaugeDischargeState.computeAdvance(): wqkms 0"); + logger.debug("GaugeDischargeState.computeAdvance(): wqkms 0"); else - logger.debug("GaugeDischargeState.computeAdvance(): facets 0"); + logger.debug("GaugeDischargeState.computeAdvance(): facets 0"); } return res; @@ -152,6 +159,5 @@ } return null; } - } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :
--- a/flys-artifacts/src/main/resources/messages.properties Thu Jun 07 13:13:13 2012 +0000 +++ b/flys-artifacts/src/main/resources/messages.properties Thu Jun 07 20:47:17 2012 +0000 @@ -108,6 +108,7 @@ chart.computed.discharge.curve.subtitle = {0}-km: {1,number,#.###} chart.computed.discharge.curve.yaxis.label = W [NN + m] chart.computed.discharge.curve.curve.label = Discharge Curve {0} km {1} +chart.computed.discharge.curve.gauge = Discharge curve at gauge {0} (km {1}) chart.duration.curve.title = Duration Curve chart.duration.curve.subtitle = {0}-km: {1,number,#.###} chart.duration.curve.xaxis.label = Duration of Non-Exceedence [Days]
--- a/flys-artifacts/src/main/resources/messages_de_DE.properties Thu Jun 07 13:13:13 2012 +0000 +++ b/flys-artifacts/src/main/resources/messages_de_DE.properties Thu Jun 07 20:47:17 2012 +0000 @@ -105,6 +105,7 @@ chart.computed.discharge.curve.subtitle = {0}-km: {1,number,#.###} chart.computed.discharge.curve.yaxis.label = W [NN + m] chart.computed.discharge.curve.curve.label = Abflusskurve {0} km {1} +chart.computed.discharge.curve.gauge = Abflusskurve an Pegel {0} (km {1}) chart.duration.curve.title = Dauerlinie chart.duration.curve.subtitle = {0}-km: {1,number,#.###} chart.duration.curve.xaxis.label = Unterschreitungsdauer [Tage]
--- a/flys-artifacts/src/main/resources/messages_en.properties Thu Jun 07 13:13:13 2012 +0000 +++ b/flys-artifacts/src/main/resources/messages_en.properties Thu Jun 07 20:47:17 2012 +0000 @@ -98,6 +98,7 @@ chart.longitudinal.section.yaxis.label = W [{0}] chart.longitudinal.section.yaxis.second.label = Q [m\u00b3/s] chart.longitudinal.annotations.label = {0}.km +chart.computed.discharge.curve.gauge = Discharge curve at gauge {0} (km {1}) chart.discharge.curve.title = Discharge Curve chart.discharge.curve.xaxis.label = Q [m\u00b3/s] chart.discharge.curve.yaxis.label = W [cm]