Mercurial > dive4elements > river
changeset 9460:8d6e56e57c4a
log-Ausgaben crossSection isStart
author | gernotbelger |
---|---|
date | Wed, 29 Aug 2018 16:57:13 +0200 (2018-08-29) |
parents | f06e3766997f |
children | da7b5f07303d |
files | artifacts/src/main/java/org/dive4elements/river/artifacts/CrossSectionArtifact.java artifacts/src/main/java/org/dive4elements/river/artifacts/FixationArtifact.java artifacts/src/main/java/org/dive4elements/river/artifacts/bundu/BUNDUArtifact.java artifacts/src/main/java/org/dive4elements/river/artifacts/model/CrossSectionFactory.java artifacts/src/main/java/org/dive4elements/river/exports/WaterlevelExporter.java backend/src/main/java/org/dive4elements/river/model/CrossSection.java |
diffstat | 6 files changed, 114 insertions(+), 184 deletions(-) [+] |
line wrap: on
line diff
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/CrossSectionArtifact.java Tue Aug 28 19:21:44 2018 +0200 +++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/CrossSectionArtifact.java Wed Aug 29 16:57:13 2018 +0200 @@ -13,31 +13,22 @@ import java.util.NavigableMap; import org.apache.log4j.Logger; - -import org.w3c.dom.Document; - +import org.dive4elements.artifactdatabase.state.Facet; +import org.dive4elements.artifactdatabase.state.FacetActivity; +import org.dive4elements.artifactdatabase.state.State; import org.dive4elements.artifacts.Artifact; import org.dive4elements.artifacts.ArtifactFactory; import org.dive4elements.artifacts.CallMeta; - import org.dive4elements.river.artifacts.access.RangeAccess; import org.dive4elements.river.artifacts.model.CrossSectionFacet; +import org.dive4elements.river.artifacts.model.CrossSectionFactory; import org.dive4elements.river.artifacts.model.FastCrossSectionLineFactory; - -import org.dive4elements.river.model.FastCrossSectionLine; - +import org.dive4elements.river.artifacts.services.CrossSectionKMService; +import org.dive4elements.river.artifacts.states.StaticState; import org.dive4elements.river.model.CrossSection; import org.dive4elements.river.model.CrossSectionLine; -import org.dive4elements.river.artifacts.model.CrossSectionFactory; - -import org.dive4elements.river.artifacts.states.StaticState; - -import org.dive4elements.artifactdatabase.state.Facet; -import org.dive4elements.artifactdatabase.state.FacetActivity; -import org.dive4elements.artifactdatabase.state.State; - -import org.dive4elements.river.artifacts.services.CrossSectionKMService; - +import org.dive4elements.river.model.FastCrossSectionLine; +import org.w3c.dom.Document; /** * Artifact describing a cross-section. @@ -60,10 +51,10 @@ public static final String DATA_DBID = "cross_section.dbid"; /** Name of data item flagging whether we think that we are master. */ - public static final String DATA_IS_MASTER = "cross_section.master?"; + private static final String DATA_IS_MASTER = "cross_section.master?"; /** Name of data item flagging whether we are the newest. */ - public static final String DATA_IS_NEWEST = "cross_section.newest?"; + private static final String DATA_IS_NEWEST = "cross_section.newest?"; /** Name of data item storing the previous possible km. */ public static final String DATA_PREV_KM = "cross_section.km.previous"; @@ -72,28 +63,21 @@ public static final String DATA_NEXT_KM = "cross_section.km.next"; /** Own log. */ - private static final Logger log = - Logger.getLogger(CrossSectionArtifact.class); + private static final Logger log = Logger.getLogger(CrossSectionArtifact.class); static { // TODO: Move to configuration. - FacetActivity.Registry.getInstance().register( - CS_ARTIFACT_NAME, - new FacetActivity() { - @Override - public Boolean isInitialActive( - Artifact artifact, - Facet facet, - String outputName - ) { - if (artifact instanceof D4EArtifact) { - D4EArtifact flys = (D4EArtifact)artifact; - String data = flys.getDataAsString(DATA_IS_NEWEST); - return data != null && data.equals("1"); - } - return null; + FacetActivity.Registry.getInstance().register(CS_ARTIFACT_NAME, new FacetActivity() { + @Override + public Boolean isInitialActive(final Artifact artifact, final Facet facet, final String outputName) { + if (artifact instanceof D4EArtifact) { + final D4EArtifact flys = (D4EArtifact) artifact; + final String data = flys.getDataAsString(DATA_IS_NEWEST); + return data != null && data.equals("1"); } - }); + return null; + } + }); } /** Return given name. */ @@ -102,44 +86,33 @@ return CS_ARTIFACT_NAME; } - /** Store ids, create a CrossSectionFacet. */ @Override - public void setup( - String identifier, - ArtifactFactory factory, - Object context, - CallMeta callMeta, - Document data, - List<Class> loadFacets) - { + public void setup(final String identifier, final ArtifactFactory factory, final Object context, final CallMeta callMeta, final Document data, + final List<Class> loadFacets) { log.info("CrossSectionArtifact.setup"); super.setup(identifier, factory, context, callMeta, data, loadFacets); - String ids = getDatacageIDValue(data); + final String ids = getDatacageIDValue(data); if (ids != null && ids.length() > 0) { addStringData(DATA_DBID, ids); log.debug("CrossSectionArtifacts db-id: " + ids); - } - else { + } else { throw new IllegalArgumentException("No attribute 'ids' found!"); } - List<Facet> fs = new ArrayList<Facet>(); - CrossSection cs = CrossSectionFactory.getCrossSection( - Integer.parseInt(ids)); + final List<Facet> fs = new ArrayList<>(); + final CrossSection cs = CrossSectionFactory.getCrossSection(Integer.parseInt(ids)); - List<CrossSectionLine> csls = cs.getLines(); + final List<CrossSectionLine> csls = cs.getLines(); if (!csls.isEmpty()) { - CrossSectionLine csl = csls.get(0); + final CrossSectionLine csl = csls.get(0); // Find min-km of cross sections, // then set DATA_KM to min(DATA_KM, minCross). - String dataKmValue = getDataAsString(DATA_KM); - double dataKm = (dataKmValue != null) - ? Double.valueOf(dataKmValue) - : Double.MIN_VALUE; + final String dataKmValue = getDataAsString(DATA_KM); + final double dataKm = (dataKmValue != null) ? Double.valueOf(dataKmValue) : Double.MIN_VALUE; if (dataKm < csl.getKm().doubleValue()) { addStringData(DATA_KM, csl.getKm().toString()); } @@ -147,57 +120,54 @@ fs.add(new CrossSectionFacet(0, cs.getDescription())); // Find out if we are newest and become master if so. - boolean isNewest = cs.shouldBeMaster(getParentKm()); - String newString = (isNewest) ? "1" : "0"; + final boolean isNewest = cs.shouldBeMaster(getParentKm()); + final String newString = (isNewest) ? "1" : "0"; addStringData(DATA_IS_NEWEST, newString); addStringData(DATA_IS_MASTER, newString); + final StringBuilder builder = new StringBuilder(); + builder.append("CrossSectionArtifact line 128 cross_section_id = ").append(cs.getId()).append(" IS_START? : ").append(String.valueOf(isNewest)); + log.info(builder.toString()); // TODO: remove ALL + log.debug(builder.toString()); + log.warn(builder.toString()); if (!fs.isEmpty()) { addFacets(getCurrentStateId(), fs); } } - /** Copy km where master-artifact "starts". */ @Override - protected void initialize( - Artifact master, - Object context, - CallMeta callMeta) - { - D4EArtifact masterArtifact = (D4EArtifact) master; + protected void initialize(final Artifact master, final Object context, final CallMeta callMeta) { + final D4EArtifact masterArtifact = (D4EArtifact) master; - RangeAccess rangeAccess = new RangeAccess(masterArtifact); - double[] range = rangeAccess.getKmRange(); + final RangeAccess rangeAccess = new RangeAccess(masterArtifact); + final double[] range = rangeAccess.getKmRange(); if (range != null && range.length > 0) { this.addStringData(DATA_KM, Double.toString(range[0])); this.addStringData(PARENT_KM, Double.toString(range[0])); } } - /** Returns next possible km for a cross-section. */ public Double getNextKm() { return getDataAsDouble(DATA_NEXT_KM); } - /** Returns previous possible km for a cross-section. */ public Double getPrevKm() { return getDataAsDouble(DATA_PREV_KM); } - /** * Create and return a new StaticState with charting output. */ @Override - public State getCurrentState(Object cc) { + public State getCurrentState(final Object cc) { final List<Facet> fs = getFacets(getCurrentStateId()); - StaticState state = new StaticState(STATIC_STATE_NAME) { + final StaticState state = new StaticState(STATIC_STATE_NAME) { @Override - public Object staticCompute(List<Facet> facets) { + public Object staticCompute(final List<Facet> facets) { if (facets != null) { facets.addAll(fs); } @@ -210,15 +180,16 @@ return state; } - /** * Get a list containing the one and only State. - * @param context ignored. + * + * @param context + * ignored. * @return list with one and only state. */ @Override - protected List<State> getStates(Object context) { - ArrayList<State> states = new ArrayList<State>(); + protected List<State> getStates(final Object context) { + final ArrayList<State> states = new ArrayList<>(); states.add(getCurrentState(context)); return states; @@ -229,29 +200,27 @@ /** * Get a DataItem casted to int (0 if fails). */ - public int getDataAsIntNull(String dataName) { - String val = getDataAsString(dataName); + public int getDataAsIntNull(final String dataName) { + final String val = getDataAsString(dataName); try { return Integer.parseInt(val); } - catch (NumberFormatException e) { + catch (final NumberFormatException e) { log.warn("Could not get data " + dataName + " as int", e); return 0; } } - /** Returns database-id of cross-section (from data). */ protected int getDBID() { return getDataAsIntNull(DATA_DBID); } - /** * Return position (km) from parent (initial km), 0 if not found. */ private double getParentKm() { - String val = getDataAsString(PARENT_KM); + final String val = getDataAsString(PARENT_KM); if (val == null) { log.warn("Empty data: " + PARENT_KM); return 0; @@ -259,7 +228,7 @@ try { return Double.valueOf(val); } - catch (NumberFormatException e) { + catch (final NumberFormatException e) { log.warn("Could not get data " + PARENT_KM + " as double", e); return 0; } @@ -269,41 +238,37 @@ * Return position (km) from data, 0 if not found. */ protected double getKm() { - String val = getDataAsString(DATA_KM); + final String val = getDataAsString(DATA_KM); try { return Double.valueOf(val); } - catch (NumberFormatException e) { + catch (final NumberFormatException e) { log.warn("Could not get data " + DATA_KM + " as double", e); return 0; } } - - /** Returns true if artifact is set to be a "master" (other facets will - * refer to this). */ + /** + * Returns true if artifact is set to be a "master" (other facets will + * refer to this). + */ public boolean isMaster() { return !getDataAsString(DATA_IS_MASTER).equals("0"); } - /** * Get points of Profile of cross section at given kilometer. * * @return an array holding coordinates of points of profile ( * in the form {{x1, x2} {y1, y2}} ). */ - public double [][] getCrossSectionData() { - log.info("getCrossSectionData() for cross_section.km " - + getDataAsString(DATA_KM)); - FastCrossSectionLine line = searchCrossSectionLine(); + public double[][] getCrossSectionData() { + log.info("getCrossSectionData() for cross_section.km " + getDataAsString(DATA_KM)); + final FastCrossSectionLine line = searchCrossSectionLine(); - return line != null - ? line.fetchCrossSectionProfile() - : null; + return line != null ? line.fetchCrossSectionProfile() : null; } - /** * Get CrossSectionLine spatially closest to what is specified in the data * "cross_section.km", null if considered too far. @@ -315,38 +280,31 @@ * if considered too far. */ public FastCrossSectionLine searchCrossSectionLine() { - double TOO_FAR = 1d; - CrossSection crossSection = CrossSectionFactory - .getCrossSection(getDBID()); + final double TOO_FAR = 1d; + final CrossSection crossSection = CrossSectionFactory.getCrossSection(getDBID()); if (log.isDebugEnabled()) { log.debug("dbid " + getDBID() + " : " + crossSection); } - NavigableMap<Double, Integer> kms = CrossSectionKMService - .getKms(crossSection.getId()); + final NavigableMap<Double, Integer> kms = CrossSectionKMService.getKms(crossSection.getId()); - Double wishKM = getKm(); + final Double wishKM = getKm(); - Double floor = kms.floorKey(wishKM); - Double ceil = kms.ceilingKey(wishKM); + final Double floor = kms.floorKey(wishKM); + final Double ceil = kms.ceilingKey(wishKM); Double nextKm; Double prevKm; - double floorD = floor != null - ? Math.abs(floor - wishKM) - : Double.MAX_VALUE; + final double floorD = floor != null ? Math.abs(floor - wishKM) : Double.MAX_VALUE; - double ceilD = ceil != null - ? Math.abs(ceil - wishKM) - : Double.MAX_VALUE; + final double ceilD = ceil != null ? Math.abs(ceil - wishKM) : Double.MAX_VALUE; double km; if (floorD < ceilD) { km = floor; - } - else { + } else { km = ceil; } @@ -369,8 +327,7 @@ addStringData(DATA_PREV_KM, prevKm.toString()); addStringData(DATA_NEXT_KM, nextKm.toString()); - return FastCrossSectionLineFactory - .getCrossSectionLine(crossSection, km); + return FastCrossSectionLineFactory.getCrossSectionLine(crossSection, km); } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/FixationArtifact.java Tue Aug 28 19:21:44 2018 +0200 +++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/FixationArtifact.java Wed Aug 29 16:57:13 2018 +0200 @@ -8,21 +8,14 @@ package org.dive4elements.river.artifacts; -import java.io.Serializable; - import org.apache.log4j.Logger; -import org.dive4elements.artifacts.CallContext; -import org.dive4elements.river.artifacts.model.CalculationResult; -import org.dive4elements.river.artifacts.model.WKms; -import org.dive4elements.river.artifacts.model.fixings.FixRealizingResult; -import org.dive4elements.river.artifacts.states.DefaultState.ComputeType; /** * The default fixation analysis artifact. * * @author <a href="mailto:raimund.renkert@intevation.de">Raimund Renkert</a> */ -public class FixationArtifact extends D4EArtifact implements WaterLineArtifact { +public class FixationArtifact extends AbstractFixBunduArtifact { private static final long serialVersionUID = 1L; @@ -38,7 +31,7 @@ * The default constructor. */ public FixationArtifact() { - log.debug("ctor()"); + super(); } /** @@ -51,24 +44,4 @@ return ARTIFACT_NAME; } - /** Calculate waterlines against a cross section. */ - @Override - public double getWaterLevel(final ComputeType type, final String hash, final String stateId, final double currentKm, final Serializable waterLineIndex, - final double nextKm, final double prevKm, final CallContext context) { - final FixRealizingResult result = (FixRealizingResult) ((CalculationResult) this.compute(context, ComputeType.ADVANCE, false)).getData(); - - final int wstIndex = (Integer) waterLineIndex; - - final WKms wkms = result.getWQKms()[wstIndex]; - - // Find W at km. - final double wAtKm = StaticWKmsArtifact.getWAtKm(wkms, currentKm); - - if (wAtKm == -1 || Double.isNaN(wAtKm)) { - log.warn("Waterlevel at km " + currentKm + " unknown."); - return Double.NaN; - } - - return wAtKm; - } } \ No newline at end of file
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/bundu/BUNDUArtifact.java Tue Aug 28 19:21:44 2018 +0200 +++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/bundu/BUNDUArtifact.java Wed Aug 29 16:57:13 2018 +0200 @@ -13,7 +13,7 @@ import org.dive4elements.artifactdatabase.state.Facet; import org.dive4elements.artifactdatabase.state.FacetActivity; import org.dive4elements.artifacts.Artifact; -import org.dive4elements.river.artifacts.D4EArtifact; +import org.dive4elements.river.artifacts.AbstractFixBunduArtifact; import org.dive4elements.river.artifacts.bundu.bezugswst.BezugswstDepthProcessor; import org.dive4elements.river.artifacts.bundu.bezugswst.BezugswstHeightProcessor; import org.dive4elements.river.artifacts.model.FacetTypes; @@ -23,7 +23,7 @@ * * @author Gernot Belger */ -public class BUNDUArtifact extends D4EArtifact { +public class BUNDUArtifact extends AbstractFixBunduArtifact { private static final long serialVersionUID = 1L; @@ -98,4 +98,5 @@ public String getRiver() { return getDataAsString(FIELD_RIVER); } + } \ No newline at end of file
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/model/CrossSectionFactory.java Tue Aug 28 19:21:44 2018 +0200 +++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/model/CrossSectionFactory.java Wed Aug 29 16:57:13 2018 +0200 @@ -28,35 +28,35 @@ */ public class CrossSectionFactory { - protected final static String CACHE_NAME = "cross_sections"; - - // TODO use caching consistently, streamline access. - /** - * Get CrossSections for an instantiated River. - * - * @param river river object. - * - * @return List of Cross Sections of river. - */ - public static List<CrossSection> getCrossSections(River river) { - return getCrossSections(river.getName()); - } + private final static String CACHE_NAME = "cross_sections"; - - /** - * Get Cross Sections for a river by name. - * - * @param riverName name of the river of interest. - * - * @return List of Cross Sections of river. - */ - public static List<CrossSection> getCrossSections(String riverName) { - Session session = SessionHolder.HOLDER.get(); - Query query = session.createQuery( - "from CrossSection where river.name = :rivername"); - query.setParameter("rivername", riverName); - return query.list(); - } +// // TODO use caching consistently, streamline access. +// /** +// * Get CrossSections for an instantiated River. +// * +// * @param river river object. +// * +// * @return List of Cross Sections of river. +// */ +// public static List<CrossSection> getCrossSections(River river) { +// return getCrossSections(river.getName()); +// } +// +// +// /** +// * Get Cross Sections for a river by name. +// * +// * @param riverName name of the river of interest. +// * +// * @return List of Cross Sections of river. +// */ +// public static List<CrossSection> getCrossSections(String riverName) { +// Session session = SessionHolder.HOLDER.get(); +// Query query = session.createQuery( +// "from CrossSection where river.name = :rivername"); +// query.setParameter("rivername", riverName); +// return query.list(); +// } @@ -84,7 +84,7 @@ /** Get specific CrossSection from database. */ - protected static CrossSection getCrossSectionUncached(int id) { + private static CrossSection getCrossSectionUncached(int id) { Session session = SessionHolder.HOLDER.get(); Query query = session.createQuery( "from CrossSection where id=:id");
--- a/artifacts/src/main/java/org/dive4elements/river/exports/WaterlevelExporter.java Tue Aug 28 19:21:44 2018 +0200 +++ b/artifacts/src/main/java/org/dive4elements/river/exports/WaterlevelExporter.java Wed Aug 29 16:57:13 2018 +0200 @@ -25,14 +25,13 @@ import org.dive4elements.artifacts.Artifact; import org.dive4elements.artifacts.CallMeta; import org.dive4elements.artifacts.common.utils.Config; +import org.dive4elements.river.artifacts.AbstractFixBunduArtifact; import org.dive4elements.river.artifacts.D4EArtifact; -import org.dive4elements.river.artifacts.FixationArtifact; import org.dive4elements.river.artifacts.StaticWQKmsArtifact; import org.dive4elements.river.artifacts.WINFOArtifact; import org.dive4elements.river.artifacts.access.FixRealizingAccess; import org.dive4elements.river.artifacts.access.IsOfficialAccess; import org.dive4elements.river.artifacts.access.RangeAccess; -import org.dive4elements.river.artifacts.bundu.BUNDUArtifact; import org.dive4elements.river.artifacts.model.CalculationResult; import org.dive4elements.river.artifacts.model.ConstantWQKms; import org.dive4elements.river.artifacts.model.Segment; @@ -615,7 +614,7 @@ desc = getDesc(wqkms, isQ); - if (flys instanceof FixationArtifact || flys instanceof BUNDUArtifact) { + if (flys instanceof AbstractFixBunduArtifact) { // Get W/Q input per gauge for this case. final FixRealizingAccess fixAccess = new FixRealizingAccess(flys); segments = fixAccess.getSegments();
--- a/backend/src/main/java/org/dive4elements/river/model/CrossSection.java Tue Aug 28 19:21:44 2018 +0200 +++ b/backend/src/main/java/org/dive4elements/river/model/CrossSection.java Wed Aug 29 16:57:13 2018 +0200 @@ -48,9 +48,9 @@ private static Logger log = Logger.getLogger(CrossSection.class); - public static final MathContext PRECISION = new MathContext(6); + private static final MathContext PRECISION = new MathContext(6); - public static final String SQL_FAST_CROSS_SECTION_LINES = + private static final String SQL_FAST_CROSS_SECTION_LINES = "SELECT km, x, y, csl.id AS csl_id " + "FROM cross_section_lines csl JOIN cross_section_points csp " + "ON csp.cross_section_line_id = csl.id " + @@ -58,7 +58,7 @@ "km between :from_km AND :to_km " + "ORDER BY csl.km, csl.id, csp.col_pos"; - public static final String SQL_MIN_MAX = + private static final String SQL_MIN_MAX = "SELECT * FROM ( "+ "SELECT cross_section_id, MIN(km) AS minkm, MAX(km) AS maxkm " + "FROM cross_section_lines " +