// Copyright (C) Stichting Deltares 2023. All rights reserved. // // This file is part of the application DAM - UI. // // DAM - UI 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 Deltares.Geotechnics.Soils; using Deltares.Geotechnics.SurfaceLines; using Deltares.Standard; using Deltares.Standard.Validation; namespace Deltares.Dam.Data { public class FailureMechanismeParamatersMStab : IAssignable, ICloneable { /// /// Additinal specifications/settings of calculation using MStab /// public FailureMechanismeParamatersMStab() { this.MStabParameters = new MStabParameters(); this.IsStabilityCheckOnUplift = false; } public Location Location { get; set; } public SurfaceLine2 SurfaceLine { get; set; } public PLLines PLLines { get; set; } public SoilProfile1D SoilProfile { get; set; } public string SoilGeometry2DName { get; set; } public double RiverLevel { get; set; } public double DikeTableHeight { get; set; } public double TrafficLoad { get; set; } /// /// Indicates whether in stability calculation a check on uplift will be performed before performin UpliftVan calculation. /// Default it is false (set in constructor) /// public bool IsStabilityCheckOnUplift { get; set; } public MStabDesignEmbankment Design { get; set; } [Validate] public MStabParameters MStabParameters { get; set; } /// /// Checks whether all rerquired data is there. /// public bool IsComplete { get { return !string.IsNullOrEmpty(this.MStabParameters.SoilDatabaseName) && this.PLLines != null && (this.SoilProfile != null || this.MStabParameters.GeometryCreationOptions.SoilGeometry2DFilename != "") && this.Location != null && this.SurfaceLine != null && !string.IsNullOrEmpty(this.MStabParameters.ProjectFileName); } } /// /// Performs the Assignment /// /// public void Assign(FailureMechanismeParamatersMStab failureMechanismeParametersMStab) { this.Location = failureMechanismeParametersMStab.Location; this.SurfaceLine = failureMechanismeParametersMStab.SurfaceLine; this.SoilProfile = failureMechanismeParametersMStab.SoilProfile; this.SoilGeometry2DName = failureMechanismeParametersMStab.SoilGeometry2DName; this.PLLines = failureMechanismeParametersMStab.PLLines; this.RiverLevel = failureMechanismeParametersMStab.RiverLevel; this.DikeTableHeight = failureMechanismeParametersMStab.DikeTableHeight; this.TrafficLoad = failureMechanismeParametersMStab.TrafficLoad; ; this.Design = failureMechanismeParametersMStab.Design; this.MStabParameters.Assign(failureMechanismeParametersMStab.MStabParameters); } /// /// Clones the object. /// /// FailureMechanismeParamatersMStab public FailureMechanismeParamatersMStab Clone() { FailureMechanismeParamatersMStab failureMechanismeParamatersMStab = new FailureMechanismeParamatersMStab(); failureMechanismeParamatersMStab.MStabParameters = this.MStabParameters.Clone(); failureMechanismeParamatersMStab.Assign(this); return failureMechanismeParamatersMStab; } } }