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