// Copyright (C) Stichting Deltares 2023. All rights reserved.
//
// This file is part of the application DAM - Live.
//
// DAM - Live 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.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()
{
MStabParameters = new MStabParameters();
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(MStabParameters.SoilDatabaseName) &&
PLLines != null &&
(SoilProfile != null || MStabParameters.GeometryCreationOptions.SoilGeometry2DFilename != "") &&
Location != null &&
SurfaceLine != null &&
!string.IsNullOrEmpty(MStabParameters.ProjectFileName);
}
}
///
/// Performs the Assignment
///
///
public void Assign(FailureMechanismeParamatersMStab failureMechanismeParametersMStab)
{
Location = failureMechanismeParametersMStab.Location;
SurfaceLine = failureMechanismeParametersMStab.SurfaceLine;
SoilProfile = failureMechanismeParametersMStab.SoilProfile;
SoilGeometry2DName = failureMechanismeParametersMStab.SoilGeometry2DName;
PLLines = failureMechanismeParametersMStab.PLLines;
RiverLevel = failureMechanismeParametersMStab.RiverLevel;
DikeTableHeight = failureMechanismeParametersMStab.DikeTableHeight;
TrafficLoad = failureMechanismeParametersMStab.TrafficLoad;
Design = failureMechanismeParametersMStab.Design;
MStabParameters.Assign(failureMechanismeParametersMStab.MStabParameters);
}
///
/// Clones the object.
///
/// FailureMechanismeParamatersMStab
public FailureMechanismeParamatersMStab Clone()
{
var failureMechanismeParamatersMStab = new FailureMechanismeParamatersMStab();
failureMechanismeParamatersMStab.MStabParameters = MStabParameters.Clone();
failureMechanismeParamatersMStab.Assign(this);
return failureMechanismeParamatersMStab;
}
}