// 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.Collections.Generic;
using Core.Common.Utils;
using Ringtoets.HydraRing.Calculation.Data.Variables;
namespace Ringtoets.HydraRing.Calculation.Data.Input.WaveConditions
{
///
/// Container of all data necessary for performing a wave conditions calculation (Q-variant) via Hydra-Ring.
///
public abstract class WaveConditionsCalculationInput : HydraRingCalculationInput
{
private readonly double waterLevel;
private readonly double a;
private readonly double b;
///
/// Creates a new instance of the class.
///
/// The id of the section.
/// The normal of the section.
/// The id of the hydraulic boundary location.
/// The norm.
/// The foreland points.
/// The break water.
/// The water level to calculate the wave conditions for.
/// The a-value.
/// The b-value.
/// As a part of the constructor, the is automatically converted into a reliability index.
protected WaveConditionsCalculationInput(int sectionId,
double sectionNormal,
long hydraulicBoundaryLocationId,
double norm,
IEnumerable forelandPoints,
HydraRingBreakWater breakWater,
double waterLevel,
double a,
double b)
: base(hydraulicBoundaryLocationId)
{
Section = new HydraRingSection(sectionId, double.NaN, sectionNormal);
Beta = StatisticsConverter.ProbabilityToReliability(norm);
ForelandsPoints = forelandPoints;
BreakWater = breakWater;
this.waterLevel = waterLevel;
this.a = a;
this.b = b;
}
public override HydraRingFailureMechanismType FailureMechanismType
{
get
{
return HydraRingFailureMechanismType.QVariant;
}
}
public override int CalculationTypeId
{
get
{
return 8;
}
}
public override int VariableId
{
get
{
return 114;
}
}
public override HydraRingSection Section { get; }
public override IEnumerable Variables
{
get
{
yield return new DeterministicHydraRingVariable(113, waterLevel);
yield return new DeterministicHydraRingVariable(114, 1.0);
yield return new DeterministicHydraRingVariable(115, a);
yield return new DeterministicHydraRingVariable(116, b);
}
}
public override IEnumerable ForelandsPoints { get; }
public override HydraRingBreakWater BreakWater { get; }
public override double Beta { get; }
}
}