using Deltares.Geotechnics; 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 DupuitPLLines DupuitPLLines { get; set; } public SoilProfile1D SoilProfile { get; set; } public string SoilGeometry2DName { get; set; } public double RiverLevel { get; set; } public double DikeTableHeight { get; set; } public double MaxWaterLevel { get; set; } public double RiverLevelDecimateHeight { get; set; } public double RequiredProbabilityOfFailure { 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 failureMechanismeParamatersMStab) { this.Location = failureMechanismeParamatersMStab.Location; this.SurfaceLine = failureMechanismeParamatersMStab.SurfaceLine; this.SoilProfile = failureMechanismeParamatersMStab.SoilProfile; this.SoilGeometry2DName = failureMechanismeParamatersMStab.SoilGeometry2DName; this.PLLines = failureMechanismeParamatersMStab.PLLines; this.RiverLevel = failureMechanismeParamatersMStab.RiverLevel; this.DikeTableHeight = failureMechanismeParamatersMStab.DikeTableHeight; this.MaxWaterLevel = failureMechanismeParamatersMStab.MaxWaterLevel; this.RiverLevelDecimateHeight = failureMechanismeParamatersMStab.RiverLevelDecimateHeight; this.RequiredProbabilityOfFailure = failureMechanismeParamatersMStab.RequiredProbabilityOfFailure; this.TrafficLoad = failureMechanismeParamatersMStab.TrafficLoad; ; this.Design = failureMechanismeParamatersMStab.Design; this.MStabParameters.Assign(failureMechanismeParamatersMStab.MStabParameters); } /// /// Clones the object. /// /// FailureMechanismeParamatersMStab public FailureMechanismeParamatersMStab Clone() { FailureMechanismeParamatersMStab failureMechanismeParamatersMStab = new FailureMechanismeParamatersMStab(); failureMechanismeParamatersMStab.MStabParameters = this.MStabParameters.Clone(); failureMechanismeParamatersMStab.Assign(this); return failureMechanismeParamatersMStab; } } }