// 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 Deltares.WTIStability; using Ringtoets.MacroStabilityInwards.KernelWrapper.Calculators.UpliftVan; using Ringtoets.MacroStabilityInwards.KernelWrapper.Calculators.UpliftVan.Input; using Ringtoets.MacroStabilityInwards.KernelWrapper.Kernels.UpliftVan; namespace Ringtoets.MacroStabilityInwards.KernelWrapper.Creators.Input { /// /// Creates instances which are required by . /// internal static class SlipPlaneUpliftVanCreator { /// /// Creates a based on the given , /// which can be used by . /// /// The to get the information from. /// A new with the given information from . /// Thrown when is null. public static SlipPlaneUpliftVan Create(UpliftVanSlipPlane slipPlane) { if (slipPlane == null) { throw new ArgumentNullException(nameof(slipPlane)); } var kernelSlipPlane = new SlipPlaneUpliftVan { ActiveSide = ActiveSideType.Left, SlipPlaneTangentLine = CreateTangentline(slipPlane) }; if (!slipPlane.GridAutomaticDetermined) { kernelSlipPlane.SlipPlaneLeftGrid = CreateGrid(slipPlane.LeftGrid); kernelSlipPlane.SlipPlaneRightGrid = CreateGrid(slipPlane.RightGrid); } if (!slipPlane.TangentLinesAutomaticAtBoundaries) { kernelSlipPlane.SlipPlaneTangentLine = CreateTangentline(slipPlane); } return kernelSlipPlane; } private static SlipCircleTangentLine CreateTangentline(UpliftVanSlipPlane slipPlane) { return new SlipCircleTangentLine { AutomaticAtBoundaries = slipPlane.TangentLinesAutomaticAtBoundaries, TangentLineZTop = slipPlane.TangentZTop, TangentLineZBottom = slipPlane.TangentZBottom, TangentLineNumber = slipPlane.TangentLineNumber, MaxSpacingBetweenBoundaries = slipPlane.MaxSpacingBetweenBoundaries }; } private static SlipCircleGrid CreateGrid(UpliftVanGrid grid) { return new SlipCircleGrid { GridXLeft = grid.XLeft, GridXRight = grid.XRight, GridZTop = grid.ZTop, GridZBottom = grid.ZBottom, GridXNumber = grid.NumberOfHorizontalPoints, GridZNumber = grid.NumberOfVerticalPoints }; } } }