// 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; using System.Collections.Generic; using System.Linq; using Core.Common.Base; using Ringtoets.Common.Data.Calculation; using Ringtoets.Common.Data.DikeProfiles; using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.Common.Data.Hydraulics; using Ringtoets.GrassCoverErosionOutwards.Data.Properties; using RingtoetsCommonDataResources = Ringtoets.Common.Data.Properties.Resources; namespace Ringtoets.GrassCoverErosionOutwards.Data { /// /// Model containing input and output needed to perform different levels of the /// Grass Cover Erosion Outwards failure mechanism. /// public class GrassCoverErosionOutwardsFailureMechanism : FailureMechanismBase, IHasSectionResults { private readonly ObservableList sectionResults; private readonly IList waterLevelCalculationsForMechanismSpecificFactorizedSignalingNorm = new List(); private readonly IList waterLevelCalculationsForMechanismSpecificSignalingNorm = new List(); private readonly IList waterLevelCalculationsForMechanismSpecificLowerLimitNorm = new List(); private readonly IList waveHeightCalculationsForMechanismSpecificFactorizedSignalingNorm = new List(); private readonly IList waveHeightCalculationsForMechanismSpecificSignalingNorm = new List(); private readonly IList waveHeightCalculationsForMechanismSpecificLowerLimitNorm = new List(); /// /// Initializes a new instance of the class. /// public GrassCoverErosionOutwardsFailureMechanism() : base(Resources.GrassCoverErosionOutwardsFailureMechanism_DisplayName, Resources.GrassCoverErosionOutwardsFailureMechanism_Code) { sectionResults = new ObservableList(); GeneralInput = new GeneralGrassCoverErosionOutwardsInput(); WaveConditionsCalculationGroup = new CalculationGroup { Name = RingtoetsCommonDataResources.FailureMechanism_Calculations_DisplayName }; HydraulicBoundaryLocations = new ObservableList(); ForeshoreProfiles = new ForeshoreProfileCollection(); } public override IEnumerable Calculations { get { return WaveConditionsCalculationGroup.GetCalculations().OfType(); } } /// /// Gets the general grass cover erosion outwards calculation input parameters that apply to each calculation. /// public GeneralGrassCoverErosionOutwardsInput GeneralInput { get; } /// /// Gets the hydraulic boundary locations. /// public ObservableList HydraulicBoundaryLocations { get; } /// /// Gets the container of all wave conditions calculations. /// public CalculationGroup WaveConditionsCalculationGroup { get; } /// /// Gets the available foreshore profiles for this instance. /// public ForeshoreProfileCollection ForeshoreProfiles { get; } public IObservableEnumerable SectionResults { get { return sectionResults; } } /// /// Sets hydraulic boundary location calculations for . /// /// The hydraulic boundary locations to add calculations for. /// Thrown when is null. public void SetHydraulicBoundaryLocationCalculations(IEnumerable hydraulicBoundaryLocations) { if (hydraulicBoundaryLocations == null) { throw new ArgumentNullException(nameof(hydraulicBoundaryLocations)); } ClearHydraulicBoundaryLocationCalculations(); foreach (HydraulicBoundaryLocation hydraulicBoundaryLocation in hydraulicBoundaryLocations) { AddHydraulicBoundaryLocationCalculations(hydraulicBoundaryLocation); } } public override void AddSection(FailureMechanismSection section) { base.AddSection(section); sectionResults.Add(new GrassCoverErosionOutwardsFailureMechanismSectionResult(section)); } public override void ClearAllSections() { base.ClearAllSections(); sectionResults.Clear(); } /// /// Gets the water level calculations corresponding to the mechanism specific factorized signaling norm. /// private IEnumerable WaterLevelCalculationsForMechanismSpecificFactorizedSignalingNorm { get { return waterLevelCalculationsForMechanismSpecificFactorizedSignalingNorm; } } /// /// Gets the water level calculations corresponding to the mechanism specific signaling norm. /// private IEnumerable WaterLevelCalculationsForMechanismSpecificSignalingNorm { get { return waterLevelCalculationsForMechanismSpecificSignalingNorm; } } /// /// Gets the water level calculations corresponding to the mechanism specific lower limit norm. /// private IEnumerable WaterLevelCalculationsForMechanismSpecificLowerLimitNorm { get { return waterLevelCalculationsForMechanismSpecificLowerLimitNorm; } } /// /// Gets the wave height calculations corresponding to the mechanism specific factorized signaling norm. /// private IEnumerable WaveHeightCalculationsForMechanismSpecificFactorizedSignalingNorm { get { return waveHeightCalculationsForMechanismSpecificFactorizedSignalingNorm; } } /// /// Gets the wave height calculations corresponding to the mechanism specific signaling norm. /// private IEnumerable WaveHeightCalculationsForMechanismSpecificSignalingNorm { get { return waveHeightCalculationsForMechanismSpecificSignalingNorm; } } /// /// Gets the wave height calculations corresponding to the mechanism specific lower limit norm. /// private IEnumerable WaveHeightCalculationsForMechanismSpecificLowerLimitNorm { get { return waveHeightCalculationsForMechanismSpecificLowerLimitNorm; } } private void ClearHydraulicBoundaryLocationCalculations() { waterLevelCalculationsForMechanismSpecificFactorizedSignalingNorm.Clear(); waterLevelCalculationsForMechanismSpecificSignalingNorm.Clear(); waterLevelCalculationsForMechanismSpecificLowerLimitNorm.Clear(); waveHeightCalculationsForMechanismSpecificFactorizedSignalingNorm.Clear(); waveHeightCalculationsForMechanismSpecificSignalingNorm.Clear(); waveHeightCalculationsForMechanismSpecificLowerLimitNorm.Clear(); } private void AddHydraulicBoundaryLocationCalculations(HydraulicBoundaryLocation hydraulicBoundaryLocation) { waterLevelCalculationsForMechanismSpecificFactorizedSignalingNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waterLevelCalculationsForMechanismSpecificSignalingNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waterLevelCalculationsForMechanismSpecificLowerLimitNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waveHeightCalculationsForMechanismSpecificFactorizedSignalingNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waveHeightCalculationsForMechanismSpecificSignalingNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waveHeightCalculationsForMechanismSpecificLowerLimitNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); } } }