// Copyright (C) Stichting Deltares 2017. All rights reserved.
//
// This file is part of the DAM Engine.
//
// The DAM Engine is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero 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 Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero 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.DamEngine.Data.Geotechnics;
using Deltares.DamEngine.Data.Standard.Validation;
namespace Deltares.DamEngine.Data.General
{
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;
}
}
}