// 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.Linq;
using Ringtoets.MacroStabilityInwards.KernelWrapper.Calculators.Waternet.Input;
using Ringtoets.MacroStabilityInwards.KernelWrapper.Calculators.Waternet.Output;
using Ringtoets.MacroStabilityInwards.KernelWrapper.Creators.Input;
using Ringtoets.MacroStabilityInwards.KernelWrapper.Creators.Output;
using Ringtoets.MacroStabilityInwards.KernelWrapper.Kernels;
using Ringtoets.MacroStabilityInwards.KernelWrapper.Kernels.Waternet;
namespace Ringtoets.MacroStabilityInwards.KernelWrapper.Calculators.Waternet
{
///
/// Class representing a Waternet calculator.
///
public abstract class WaternetCalculator : IWaternetCalculator
{
///
/// Creates a new instance of .
///
/// The containing all the values
/// required for performing the Waternet calculation.
/// The factory responsible for creating the Waternet kernel.
/// Thrown when any parameter
/// is null.
protected WaternetCalculator(WaternetCalculatorInput input, IMacroStabilityInwardsKernelFactory factory)
{
if (input == null)
{
throw new ArgumentNullException(nameof(input));
}
if (factory == null)
{
throw new ArgumentNullException(nameof(factory));
}
Input = input;
Factory = factory;
}
public WaternetCalculatorResult Calculate()
{
IWaternetKernel waternetKernel = CalculateWaternet();
return WaternetCalculatorResultCreator.Create(waternetKernel.Waternet);
}
///
/// Gets the factory responsible for creating the Waternet kernel.
///
protected IMacroStabilityInwardsKernelFactory Factory { get; }
///
/// Creates a Waternet kernel.
///
/// The created .
protected abstract IWaternetKernel CreateWaternetKernel();
private WaternetCalculatorInput Input { get; }
///
/// Performs the Waternet calculation.
///
/// The Waternet kernel with output set.
/// Thrown when the Waternet
/// kernel throws a .
private IWaternetKernel CalculateWaternet()
{
IWaternetKernel waternetKernel = CreateWaternetKernel();
SetInputOnKernel(waternetKernel);
try
{
waternetKernel.Calculate();
}
catch (WaternetKernelWrapperException e)
{
throw new WaternetCalculatorException(e.Message, e);
}
return waternetKernel;
}
private void SetInputOnKernel(IWaternetKernel waternetKernel)
{
LayerWithSoil[] layersWithSoils = LayerWithSoilCreator.Create(Input.SoilProfile);
waternetKernel.SoilModel = SoilModelCreator.Create(layersWithSoils.Select(lws => lws.Soil).ToArray());
waternetKernel.SoilProfile = SoilProfileCreator.Create(Input.SoilProfile.PreconsolidationStresses, layersWithSoils);
waternetKernel.Location = WaternetStabilityLocationCreator.Create(Input);
waternetKernel.SurfaceLine = SurfaceLineCreator.Create(Input.SurfaceLine, Input.LandwardDirection);
}
}
}