// Copyright (C) Stichting Deltares 2017. 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.ComponentModel; using Ringtoets.Common.Data.Structures; using Ringtoets.Common.Service; using Ringtoets.Common.Service.Structures; using Ringtoets.HydraRing.Calculation.Data.Input.Structures; using Ringtoets.StabilityPointStructures.Data; namespace Ringtoets.StabilityPointStructures.Service { /// /// Service that provides methods for performing Hydra-ring calculations for stability point structures. /// public class StabilityPointStructuresCalculationService : StructuresCalculationServiceBase { /// /// Creates a new instance of . /// public StabilityPointStructuresCalculationService() : base(new StabilityPointStructuresCalculationMessageProvider()) {} protected override StructuresStabilityPointCalculationInput CreateInput(StructuresCalculation calculation, GeneralStabilityPointStructuresInput generalInput, string hydraulicBoundaryDatabaseFilePath) { StructuresStabilityPointCalculationInput input; switch (calculation.InputParameters.InflowModelType) { case StabilityPointStructureInflowModelType.LowSill: switch (calculation.InputParameters.LoadSchematizationType) { case LoadSchematizationType.Linear: input = CreateLowSillLinearCalculationInput( calculation, generalInput); break; case LoadSchematizationType.Quadratic: input = CreateLowSillQuadraticCalculationInput( calculation, generalInput); break; default: throw new InvalidEnumArgumentException(nameof(calculation), (int) calculation.InputParameters.LoadSchematizationType, typeof(LoadSchematizationType)); } break; case StabilityPointStructureInflowModelType.FloodedCulvert: switch (calculation.InputParameters.LoadSchematizationType) { case LoadSchematizationType.Linear: input = CreateFloodedCulvertLinearCalculationInput( calculation, generalInput); break; case LoadSchematizationType.Quadratic: input = CreateFloodedCulvertQuadraticCalculationInput( calculation, generalInput); break; default: throw new InvalidEnumArgumentException(nameof(calculation), (int) calculation.InputParameters.LoadSchematizationType, typeof(LoadSchematizationType)); } break; default: throw new InvalidEnumArgumentException(nameof(calculation), (int) calculation.InputParameters.InflowModelType, typeof(StabilityPointStructureInflowModelType)); } HydraRingSettingsDatabaseHelper.AssignSettingsFromDatabase(input, hydraulicBoundaryDatabaseFilePath); return input; } private StructuresStabilityPointLowSillLinearCalculationInput CreateLowSillLinearCalculationInput(StructuresCalculation calculation, GeneralStabilityPointStructuresInput generalInput) { var structuresStabilityPointLowSillLinearCalculationInput = new StructuresStabilityPointLowSillLinearCalculationInput( calculation.InputParameters.HydraulicBoundaryLocation.Id, calculation.InputParameters.StructureNormalOrientation, HydraRingInputParser.ParseForeshore(calculation.InputParameters), HydraRingInputParser.ParseBreakWater(calculation.InputParameters), calculation.InputParameters.VolumicWeightWater, generalInput.GravitationalAcceleration, calculation.InputParameters.LevelCrestStructure.Mean, calculation.InputParameters.LevelCrestStructure.StandardDeviation, calculation.InputParameters.StructureNormalOrientation, calculation.InputParameters.FactorStormDurationOpenStructure, generalInput.ModelFactorSubCriticalFlow.Mean, generalInput.ModelFactorSubCriticalFlow.CoefficientOfVariation, calculation.InputParameters.ThresholdHeightOpenWeir.Mean, calculation.InputParameters.ThresholdHeightOpenWeir.StandardDeviation, calculation.InputParameters.InsideWaterLevelFailureConstruction.Mean, calculation.InputParameters.InsideWaterLevelFailureConstruction.StandardDeviation, calculation.InputParameters.FailureProbabilityRepairClosure, calculation.InputParameters.FailureCollisionEnergy.Mean, calculation.InputParameters.FailureCollisionEnergy.CoefficientOfVariation, generalInput.ModelFactorCollisionLoad.Mean, generalInput.ModelFactorCollisionLoad.CoefficientOfVariation, calculation.InputParameters.ShipMass.Mean, calculation.InputParameters.ShipMass.CoefficientOfVariation, calculation.InputParameters.ShipVelocity.Mean, calculation.InputParameters.ShipVelocity.CoefficientOfVariation, calculation.InputParameters.LevellingCount, calculation.InputParameters.ProbabilityCollisionSecondaryStructure, calculation.InputParameters.FlowVelocityStructureClosable.Mean, calculation.InputParameters.FlowVelocityStructureClosable.CoefficientOfVariation, calculation.InputParameters.InsideWaterLevel.Mean, calculation.InputParameters.InsideWaterLevel.StandardDeviation, calculation.InputParameters.AllowedLevelIncreaseStorage.Mean, calculation.InputParameters.AllowedLevelIncreaseStorage.StandardDeviation, generalInput.ModelFactorStorageVolume.Mean, generalInput.ModelFactorStorageVolume.StandardDeviation, calculation.InputParameters.StorageStructureArea.Mean, calculation.InputParameters.StorageStructureArea.CoefficientOfVariation, generalInput.ModelFactorInflowVolume, calculation.InputParameters.FlowWidthAtBottomProtection.Mean, calculation.InputParameters.FlowWidthAtBottomProtection.StandardDeviation, calculation.InputParameters.CriticalOvertoppingDischarge.Mean, calculation.InputParameters.CriticalOvertoppingDischarge.CoefficientOfVariation, calculation.InputParameters.FailureProbabilityStructureWithErosion, calculation.InputParameters.StormDuration.Mean, calculation.InputParameters.StormDuration.CoefficientOfVariation, calculation.InputParameters.BankWidth.Mean, calculation.InputParameters.BankWidth.StandardDeviation, calculation.InputParameters.EvaluationLevel, generalInput.ModelFactorLoadEffect.Mean, generalInput.ModelFactorLoadEffect.StandardDeviation, generalInput.WaveRatioMaxHN, generalInput.WaveRatioMaxHStandardDeviation, calculation.InputParameters.VerticalDistance, generalInput.ModificationFactorWavesSlowlyVaryingPressureComponent, generalInput.ModificationFactorDynamicOrImpulsivePressureComponent, calculation.InputParameters.ModelFactorSuperCriticalFlow.Mean, calculation.InputParameters.ModelFactorSuperCriticalFlow.StandardDeviation, calculation.InputParameters.ConstructiveStrengthLinearLoadModel.Mean, calculation.InputParameters.ConstructiveStrengthLinearLoadModel.CoefficientOfVariation, calculation.InputParameters.StabilityLinearLoadModel.Mean, calculation.InputParameters.StabilityLinearLoadModel.CoefficientOfVariation, calculation.InputParameters.WidthFlowApertures.Mean, calculation.InputParameters.WidthFlowApertures.StandardDeviation); return structuresStabilityPointLowSillLinearCalculationInput; } private StructuresStabilityPointLowSillQuadraticCalculationInput CreateLowSillQuadraticCalculationInput( StructuresCalculation calculation, GeneralStabilityPointStructuresInput generalInput) { return new StructuresStabilityPointLowSillQuadraticCalculationInput( calculation.InputParameters.HydraulicBoundaryLocation.Id, calculation.InputParameters.StructureNormalOrientation, HydraRingInputParser.ParseForeshore(calculation.InputParameters), HydraRingInputParser.ParseBreakWater(calculation.InputParameters), calculation.InputParameters.VolumicWeightWater, generalInput.GravitationalAcceleration, calculation.InputParameters.LevelCrestStructure.Mean, calculation.InputParameters.LevelCrestStructure.StandardDeviation, calculation.InputParameters.StructureNormalOrientation, calculation.InputParameters.FactorStormDurationOpenStructure, generalInput.ModelFactorSubCriticalFlow.Mean, generalInput.ModelFactorSubCriticalFlow.CoefficientOfVariation, calculation.InputParameters.ThresholdHeightOpenWeir.Mean, calculation.InputParameters.ThresholdHeightOpenWeir.StandardDeviation, calculation.InputParameters.InsideWaterLevelFailureConstruction.Mean, calculation.InputParameters.InsideWaterLevelFailureConstruction.StandardDeviation, calculation.InputParameters.FailureProbabilityRepairClosure, calculation.InputParameters.FailureCollisionEnergy.Mean, calculation.InputParameters.FailureCollisionEnergy.CoefficientOfVariation, generalInput.ModelFactorCollisionLoad.Mean, generalInput.ModelFactorCollisionLoad.CoefficientOfVariation, calculation.InputParameters.ShipMass.Mean, calculation.InputParameters.ShipMass.CoefficientOfVariation, calculation.InputParameters.ShipVelocity.Mean, calculation.InputParameters.ShipVelocity.CoefficientOfVariation, calculation.InputParameters.LevellingCount, calculation.InputParameters.ProbabilityCollisionSecondaryStructure, calculation.InputParameters.FlowVelocityStructureClosable.Mean, calculation.InputParameters.FlowVelocityStructureClosable.CoefficientOfVariation, calculation.InputParameters.InsideWaterLevel.Mean, calculation.InputParameters.InsideWaterLevel.StandardDeviation, calculation.InputParameters.AllowedLevelIncreaseStorage.Mean, calculation.InputParameters.AllowedLevelIncreaseStorage.StandardDeviation, generalInput.ModelFactorStorageVolume.Mean, generalInput.ModelFactorStorageVolume.StandardDeviation, calculation.InputParameters.StorageStructureArea.Mean, calculation.InputParameters.StorageStructureArea.CoefficientOfVariation, generalInput.ModelFactorInflowVolume, calculation.InputParameters.FlowWidthAtBottomProtection.Mean, calculation.InputParameters.FlowWidthAtBottomProtection.StandardDeviation, calculation.InputParameters.CriticalOvertoppingDischarge.Mean, calculation.InputParameters.CriticalOvertoppingDischarge.CoefficientOfVariation, calculation.InputParameters.FailureProbabilityStructureWithErosion, calculation.InputParameters.StormDuration.Mean, calculation.InputParameters.StormDuration.CoefficientOfVariation, calculation.InputParameters.BankWidth.Mean, calculation.InputParameters.BankWidth.StandardDeviation, calculation.InputParameters.EvaluationLevel, generalInput.ModelFactorLoadEffect.Mean, generalInput.ModelFactorLoadEffect.StandardDeviation, generalInput.WaveRatioMaxHN, generalInput.WaveRatioMaxHStandardDeviation, calculation.InputParameters.VerticalDistance, generalInput.ModificationFactorWavesSlowlyVaryingPressureComponent, generalInput.ModificationFactorDynamicOrImpulsivePressureComponent, calculation.InputParameters.ModelFactorSuperCriticalFlow.Mean, calculation.InputParameters.ModelFactorSuperCriticalFlow.StandardDeviation, calculation.InputParameters.ConstructiveStrengthQuadraticLoadModel.Mean, calculation.InputParameters.ConstructiveStrengthQuadraticLoadModel.CoefficientOfVariation, calculation.InputParameters.StabilityQuadraticLoadModel.Mean, calculation.InputParameters.StabilityQuadraticLoadModel.CoefficientOfVariation, calculation.InputParameters.WidthFlowApertures.Mean, calculation.InputParameters.WidthFlowApertures.StandardDeviation); } private StructuresStabilityPointFloodedCulvertLinearCalculationInput CreateFloodedCulvertLinearCalculationInput( StructuresCalculation calculation, GeneralStabilityPointStructuresInput generalInput) { return new StructuresStabilityPointFloodedCulvertLinearCalculationInput( calculation.InputParameters.HydraulicBoundaryLocation.Id, calculation.InputParameters.StructureNormalOrientation, HydraRingInputParser.ParseForeshore(calculation.InputParameters), HydraRingInputParser.ParseBreakWater(calculation.InputParameters), calculation.InputParameters.VolumicWeightWater, generalInput.GravitationalAcceleration, calculation.InputParameters.LevelCrestStructure.Mean, calculation.InputParameters.LevelCrestStructure.StandardDeviation, calculation.InputParameters.StructureNormalOrientation, calculation.InputParameters.FactorStormDurationOpenStructure, generalInput.ModelFactorSubCriticalFlow.Mean, generalInput.ModelFactorSubCriticalFlow.CoefficientOfVariation, calculation.InputParameters.ThresholdHeightOpenWeir.Mean, calculation.InputParameters.ThresholdHeightOpenWeir.StandardDeviation, calculation.InputParameters.InsideWaterLevelFailureConstruction.Mean, calculation.InputParameters.InsideWaterLevelFailureConstruction.StandardDeviation, calculation.InputParameters.FailureProbabilityRepairClosure, calculation.InputParameters.FailureCollisionEnergy.Mean, calculation.InputParameters.FailureCollisionEnergy.CoefficientOfVariation, generalInput.ModelFactorCollisionLoad.Mean, generalInput.ModelFactorCollisionLoad.CoefficientOfVariation, calculation.InputParameters.ShipMass.Mean, calculation.InputParameters.ShipMass.CoefficientOfVariation, calculation.InputParameters.ShipVelocity.Mean, calculation.InputParameters.ShipVelocity.CoefficientOfVariation, calculation.InputParameters.LevellingCount, calculation.InputParameters.ProbabilityCollisionSecondaryStructure, calculation.InputParameters.FlowVelocityStructureClosable.Mean, calculation.InputParameters.FlowVelocityStructureClosable.CoefficientOfVariation, calculation.InputParameters.InsideWaterLevel.Mean, calculation.InputParameters.InsideWaterLevel.StandardDeviation, calculation.InputParameters.AllowedLevelIncreaseStorage.Mean, calculation.InputParameters.AllowedLevelIncreaseStorage.StandardDeviation, generalInput.ModelFactorStorageVolume.Mean, generalInput.ModelFactorStorageVolume.StandardDeviation, calculation.InputParameters.StorageStructureArea.Mean, calculation.InputParameters.StorageStructureArea.CoefficientOfVariation, generalInput.ModelFactorInflowVolume, calculation.InputParameters.FlowWidthAtBottomProtection.Mean, calculation.InputParameters.FlowWidthAtBottomProtection.StandardDeviation, calculation.InputParameters.CriticalOvertoppingDischarge.Mean, calculation.InputParameters.CriticalOvertoppingDischarge.CoefficientOfVariation, calculation.InputParameters.FailureProbabilityStructureWithErosion, calculation.InputParameters.StormDuration.Mean, calculation.InputParameters.StormDuration.CoefficientOfVariation, calculation.InputParameters.BankWidth.Mean, calculation.InputParameters.BankWidth.StandardDeviation, calculation.InputParameters.EvaluationLevel, generalInput.ModelFactorLoadEffect.Mean, generalInput.ModelFactorLoadEffect.StandardDeviation, generalInput.WaveRatioMaxHN, generalInput.WaveRatioMaxHStandardDeviation, calculation.InputParameters.VerticalDistance, generalInput.ModificationFactorWavesSlowlyVaryingPressureComponent, generalInput.ModificationFactorDynamicOrImpulsivePressureComponent, calculation.InputParameters.DrainCoefficient.Mean, calculation.InputParameters.DrainCoefficient.StandardDeviation, calculation.InputParameters.AreaFlowApertures.Mean, calculation.InputParameters.AreaFlowApertures.StandardDeviation, calculation.InputParameters.ConstructiveStrengthLinearLoadModel.Mean, calculation.InputParameters.ConstructiveStrengthLinearLoadModel.CoefficientOfVariation, calculation.InputParameters.StabilityLinearLoadModel.Mean, calculation.InputParameters.StabilityLinearLoadModel.CoefficientOfVariation); } private StructuresStabilityPointFloodedCulvertQuadraticCalculationInput CreateFloodedCulvertQuadraticCalculationInput( StructuresCalculation calculation, GeneralStabilityPointStructuresInput generalInput) { return new StructuresStabilityPointFloodedCulvertQuadraticCalculationInput( calculation.InputParameters.HydraulicBoundaryLocation.Id, calculation.InputParameters.StructureNormalOrientation, HydraRingInputParser.ParseForeshore(calculation.InputParameters), HydraRingInputParser.ParseBreakWater(calculation.InputParameters), calculation.InputParameters.VolumicWeightWater, generalInput.GravitationalAcceleration, calculation.InputParameters.LevelCrestStructure.Mean, calculation.InputParameters.LevelCrestStructure.StandardDeviation, calculation.InputParameters.StructureNormalOrientation, calculation.InputParameters.FactorStormDurationOpenStructure, generalInput.ModelFactorSubCriticalFlow.Mean, generalInput.ModelFactorSubCriticalFlow.CoefficientOfVariation, calculation.InputParameters.ThresholdHeightOpenWeir.Mean, calculation.InputParameters.ThresholdHeightOpenWeir.StandardDeviation, calculation.InputParameters.InsideWaterLevelFailureConstruction.Mean, calculation.InputParameters.InsideWaterLevelFailureConstruction.StandardDeviation, calculation.InputParameters.FailureProbabilityRepairClosure, calculation.InputParameters.FailureCollisionEnergy.Mean, calculation.InputParameters.FailureCollisionEnergy.CoefficientOfVariation, generalInput.ModelFactorCollisionLoad.Mean, generalInput.ModelFactorCollisionLoad.CoefficientOfVariation, calculation.InputParameters.ShipMass.Mean, calculation.InputParameters.ShipMass.CoefficientOfVariation, calculation.InputParameters.ShipVelocity.Mean, calculation.InputParameters.ShipVelocity.CoefficientOfVariation, calculation.InputParameters.LevellingCount, calculation.InputParameters.ProbabilityCollisionSecondaryStructure, calculation.InputParameters.FlowVelocityStructureClosable.Mean, calculation.InputParameters.FlowVelocityStructureClosable.CoefficientOfVariation, calculation.InputParameters.InsideWaterLevel.Mean, calculation.InputParameters.InsideWaterLevel.StandardDeviation, calculation.InputParameters.AllowedLevelIncreaseStorage.Mean, calculation.InputParameters.AllowedLevelIncreaseStorage.StandardDeviation, generalInput.ModelFactorStorageVolume.Mean, generalInput.ModelFactorStorageVolume.StandardDeviation, calculation.InputParameters.StorageStructureArea.Mean, calculation.InputParameters.StorageStructureArea.CoefficientOfVariation, generalInput.ModelFactorInflowVolume, calculation.InputParameters.FlowWidthAtBottomProtection.Mean, calculation.InputParameters.FlowWidthAtBottomProtection.StandardDeviation, calculation.InputParameters.CriticalOvertoppingDischarge.Mean, calculation.InputParameters.CriticalOvertoppingDischarge.CoefficientOfVariation, calculation.InputParameters.FailureProbabilityStructureWithErosion, calculation.InputParameters.StormDuration.Mean, calculation.InputParameters.StormDuration.CoefficientOfVariation, calculation.InputParameters.BankWidth.Mean, calculation.InputParameters.BankWidth.StandardDeviation, calculation.InputParameters.EvaluationLevel, generalInput.ModelFactorLoadEffect.Mean, generalInput.ModelFactorLoadEffect.StandardDeviation, generalInput.WaveRatioMaxHN, generalInput.WaveRatioMaxHStandardDeviation, calculation.InputParameters.VerticalDistance, generalInput.ModificationFactorWavesSlowlyVaryingPressureComponent, generalInput.ModificationFactorDynamicOrImpulsivePressureComponent, calculation.InputParameters.DrainCoefficient.Mean, calculation.InputParameters.DrainCoefficient.StandardDeviation, calculation.InputParameters.AreaFlowApertures.Mean, calculation.InputParameters.AreaFlowApertures.StandardDeviation, calculation.InputParameters.ConstructiveStrengthQuadraticLoadModel.Mean, calculation.InputParameters.ConstructiveStrengthQuadraticLoadModel.CoefficientOfVariation, calculation.InputParameters.StabilityQuadraticLoadModel.Mean, calculation.InputParameters.StabilityQuadraticLoadModel.CoefficientOfVariation); } } }