// 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));
}
}
}