// Copyright (C) Stichting Deltares 2016. All rights reserved. // // This file is part of Ringtoets. // // Ringtoets is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . // // All names, logos, and references to "Deltares" are registered trademarks of // Stichting Deltares and remain full property of Stichting Deltares at all times. // All rights reserved. using System; using System.Collections.Generic; using System.Linq; using Core.Common.Base; using Core.Common.Base.Data; using Ringtoets.ClosingStructures.Data; using Ringtoets.Common.Data.AssessmentSection; using Ringtoets.Common.IO.FileImporters; using Ringtoets.Common.IO.Structures; namespace Ringtoets.ClosingStructures.IO { /// /// Imports point shapefiles containing closing structure locations /// and csv files containing closing structure schematizations. /// public class ClosingStructuresImporter : StructuresImporter> { /// /// Creates a new instance of . /// /// The closing structures to import on. /// The reference line used to check if the /// objects found in the file are intersecting it. /// The path to the file to import from. /// Thrown when , /// , or is null. public ClosingStructuresImporter(ObservableList importTarget, ReferenceLine referenceLine, string filePath) : base(importTarget, referenceLine, filePath) {} protected override void CreateSpecificStructures(ICollection structureLocations, Dictionary> groupedStructureParameterRows) { IEnumerable importedClosingStructures = CreateClosingStructures(structureLocations.ToList(), groupedStructureParameterRows); foreach (ClosingStructure closingStructure in importedClosingStructures) { ImportTarget.Add(closingStructure); } } private IEnumerable CreateClosingStructures(IEnumerable structureLocations, IDictionary> groupedStructureParameterRows) { var closingStructures = new List(); foreach (StructureLocation structureLocation in structureLocations) { string id = structureLocation.Id; List structureParameterRows = groupedStructureParameterRows.ContainsKey(id) ? groupedStructureParameterRows[id] : new List(); ValidationResult parameterRowsValidationResult = StructuresParameterRowsValidator.ValidateClosingStructuresParameters(structureParameterRows); if (!parameterRowsValidationResult.IsValid) { LogValidationErrorForStructure(structureLocation.Name, structureLocation.Id, parameterRowsValidationResult.ErrorMessages); continue; } ClosingStructure closingStructure = CreateClosingStructure(structureLocation, structureParameterRows); closingStructures.Add(closingStructure); } return closingStructures; } private ClosingStructure CreateClosingStructure(StructureLocation structureLocation, IEnumerable structureParameterRows) { Dictionary rowData = structureParameterRows.ToDictionary( row => row.ParameterId, row => row, StringComparer.OrdinalIgnoreCase); string structureName = structureLocation.Name; var constructionProperties = new ClosingStructure.ConstructionProperties { Name = structureName, Id = structureLocation.Id, Location = structureLocation.Point }; TrySetConstructionProperty((properties, rows, key) => { properties.StorageStructureArea.Mean = (RoundedDouble) rows[key].NumericalValue; properties.StorageStructureArea.CoefficientOfVariation = GetCoefficientOfVariation(rows[key], structureName); }, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword1); TrySetConstructionProperty((properties, rows, key) => { properties.AllowedLevelIncreaseStorage.Mean = (RoundedDouble) rows[key].NumericalValue; properties.AllowedLevelIncreaseStorage.StandardDeviation = GetStandardDeviation(rows[key], structureName); }, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword2); TrySetConstructionProperty((properties, rows, key) => properties.StructureNormalOrientation = (RoundedDouble) rows[key].NumericalValue, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword3); TrySetConstructionProperty((properties, rows, key) => { properties.WidthFlowApertures.Mean = (RoundedDouble) rows[key].NumericalValue; properties.WidthFlowApertures.StandardDeviation = GetStandardDeviation(rows[key], structureName); }, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword4); TrySetConstructionProperty((properties, rows, key) => { properties.LevelCrestStructureNotClosing.Mean = (RoundedDouble) rows[key].NumericalValue; properties.LevelCrestStructureNotClosing.StandardDeviation = GetStandardDeviation(rows[key], structureName); }, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword5); TrySetConstructionProperty((properties, rows, key) => { properties.InsideWaterLevel.Mean = (RoundedDouble) rows[key].NumericalValue; properties.InsideWaterLevel.StandardDeviation = GetStandardDeviation(rows[key], structureName); }, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword6); TrySetConstructionProperty((properties, rows, key) => { properties.ThresholdHeightOpenWeir.Mean = (RoundedDouble) rows[key].NumericalValue; properties.ThresholdHeightOpenWeir.StandardDeviation = GetStandardDeviation(rows[key], structureName); }, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword7); TrySetConstructionProperty((properties, rows, key) => { properties.AreaFlowApertures.Mean = (RoundedDouble) rows[key].NumericalValue; properties.AreaFlowApertures.StandardDeviation = GetStandardDeviation(rows[key], structureName); }, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword8); TrySetConstructionProperty((properties, rows, key) => { properties.CriticalOvertoppingDischarge.Mean = (RoundedDouble) rows[key].NumericalValue; properties.CriticalOvertoppingDischarge.CoefficientOfVariation = GetCoefficientOfVariation(rows[key], structureName); }, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword9); TrySetConstructionProperty((properties, rows, key) => { properties.FlowWidthAtBottomProtection.Mean = (RoundedDouble) rows[key].NumericalValue; properties.FlowWidthAtBottomProtection.StandardDeviation = GetStandardDeviation(rows[key], structureName); }, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword10); TrySetConstructionProperty((properties, rows, key) => properties.ProbabilityOrFrequencyOpenStructureBeforeFlooding = rows[key].NumericalValue, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword11); TrySetConstructionProperty((properties, rows, key) => properties.FailureProbabilityOpenStructure = rows[key].NumericalValue, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword12); TrySetConstructionProperty((properties, rows, key) => properties.IdenticalApertures = (int) rows[key].NumericalValue, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword13); TrySetConstructionProperty((properties, rows, key) => properties.FailureProbabilityReparation = rows[key].NumericalValue, constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword14); TrySetConstructionProperty((properties, rows, key) => properties.InflowModelType = GetClosingStructureInflowModelType(rows[key]), constructionProperties, rowData, StructureFilesKeywords.ClosingStructureParameterKeyword15); return new ClosingStructure(constructionProperties); } private static ClosingStructureInflowModelType GetClosingStructureInflowModelType( StructuresParameterRow structureParameterRow) { string keywordValue = structureParameterRow.AlphanumericValue.ToLower(); switch (keywordValue) { case StructureFilesKeywords.InflowModelTypeVerticalWall: return ClosingStructureInflowModelType.VerticalWall; case StructureFilesKeywords.InflowModelTypeLowSill: return ClosingStructureInflowModelType.LowSill; case StructureFilesKeywords.InflowModelTypeFloodedCulvert: return ClosingStructureInflowModelType.FloodedCulvert; default: throw new NotSupportedException(); } } } }